Open mqyqingfeng opened 2 years ago
@hakuun 十分感谢勘误~ 这里确实是写错了~ 已更正~
# 跑路
TIL
其中 w r x 代表的数字可以解释一下 这里不是死记硬背的 而是根据二进制来的 以owner为例 0代表无权限 1代表有权限 001 = 1 = 可执行 010 = 2 = 可读 100 = 4 = 可写
我们通常分配权限 755 翻译一下就是
111 011 011 所以权限组合可以通过简单计算得出。只分配读写 那就是 110 = 6
第 2 到第 4 位,表示所有者权限,其中 r 表示读权限,w 表示写权限,x 表示可执行权限, -表示无权限,第 2 到 5 位为 rwx,表示所有者可读可写可执行。
后面的 第 2 到 5 位 是不是写错了?
前言
在翻译完 TypeScript 官方文档后,我用 VuePress 搭建博客,又实现了 GitHub 和 Gitee Pages 的自动部署,但我最终还是决定自己建站,而在建站的过程中,必不可少会用到 Linux 命令,所以此篇写一份基本够用的 Linux 命令,会涵盖博客搭建系列文章用到的各种命令,方便查询和学习使用。
0. Owner、Group、Others、Root
Linux 系统是一种多用户系统,它将文件访问者身份分为三种:
文件所有者(Owner)
当创建一个用户的时候,Linux 会为该用户创建一个主目录,路径为
/home/<username>
,我们可以使用cd ~
,快捷进入主目录。如果你想放一个私密文件,就可以放在自己的主目录里,然后设置只能自己查看。群组(Group)
每个用户都有一个用户组,方便多人操作的时候,为一群人分配权限。当创建用户的时候,会自动创建一个与它同名的用户组。
如果一个用户同时属于多个组,用户需要在用户组之间切换,才能具有其他用户组的权限。
其他人(Others)
既不是文件所有者又不是文件所属群组成员的用户,就是其他人。
超级用户(Root)
Root 用户是一类特殊的用户,该用户可以访问所有文件。
1. adduser 添加用户 和 passwd 更改密码
但是由于创建的用户权限较低,有的时候我们需要为用户提权,此时我们可以这样做:
注意同样是编辑
sudoers
配置文件,使用这个命令会比使用sudo vim /etc/ sudoers
更安全, 除了对语法有校验,并且还会在多用户编辑的时候锁住文件。打开
sudoers
配置文件后,我们添加这样一行配置:简单解释下这句话
git ALL=(ALL:ALL) ALL
:ALL
表示规则应用于所有 hostsALL
表示规则应用于所有 usersALL
表示规则应用于所有 groupsALL
表示规则应用于所有 commands我们保存退出后,
git
用户就会获得 root 权限。2. ls 列出文件和目录
ls
列出文件和目录ls -la
由-a
显示所有文件和目录(包括隐藏)和-l
显示详细列表组成:每一行都有 7 列,我们以
branches
为例讲解每列的含义:重点看第 1 列的内容,以
drwxrwxr-x
为例,这里一共 10 位,第 1 位表示文件类型,其中-
表示普通文件,d
表示目录文件。第 2 到第 4 位,表示所有者权限,其中
r
表示读权限,w
表示写权限,x
表示可执行权限,-
表示无权限,第 2 到 5 位为rwx
,表示所有者可读可写可执行。第 5 到第 7 位,表示组用户权限,这里也是
rwx
。第 8 到第 10 位,表示其他用户权限,这里是
r-x
,表示有可读可执行权限,无写入权限。这里再额外补充一点:
像
root
用户创建文件夹的默认权限为rwxr-xr-x
:而创建文件的默认权限是
rw-r--r--
,注意创建文件默认会去掉x
权限:这就是为什么我们有的时候需要在创建文件后,又加上执行权限。
3. chown 更改文件属主,也可以同时更改文件属组
chown (change owner) 语法:
将
index.html
的所有者更改为git
:将
index.html
的所有者和群组都改为git
:4. chmod 更改文件权限
权限除了用
r
w
x
这种方式表示,也可以用数字表示,数组与字母的对应关系为:之所有如此对应关系,主要还是为了方便推导,比如我们希望一个文件可读可写,那我们可以方便的设置权限为 6(4 + 2),同样,如果我们知道一个权限为 3,我们也可以推导出权限为可写可执行,因为只有 2 + 1 才可能等于 3。
我们看下 chmod (change mode) 的具体语法:
其中 xyz 分别表示 Owner、Group、Others 的权限,如果我们这样设置一个文件的权限:
我们可以得知,Owner 的权限为 7,为可读可写可执行,Group 的权限为 5,为可读可执行,Others 的权限为 0,表示不可读写不可执行。对应字母为:
rwxr-x---
。除了这种数字的方式,还有一种使用符号类型改变权限的方式:
在这种方式里,我们将三种身份
Owner
、Group
、Others
,分别简写为u(User)
、g
、o
,用a
表示所有身份,再使用+
-
=
表示加入、去除、设定一个权限,r
w
x
则继续表示读,写,执行权限,举个例子:意思就是
Owner
加上执行权限,Group
和Others
去除执行权限。当然我们也可以直接设定权限
此时文件的权限就相当于
-rwxr-xr--
。此外,我们还可以省略不写
ugoa
这类身份内容,直接写:此时相当于使用了
a
,会给所有身份添加执行权限。5. su 切换身份
6. whoami 显示用户名
7. pwd 显示当前目录
9. cd 切换工作目录
10. mkdir 创建目录
mkdir
创建目录:mkdir -p
递归创建目录:11. touch 创建文件
用于修改文件或者目录的时间属性,当文件不存在,系统会创建空白文件
12. echo 打印输出
echo 是 Shell 命令,用于打印输出:
创建或覆盖文件内容为 "test content":
如果是想追加内容,就用
>>
:13. cat 连接文件并打印输出
查看文件内容:
清空 index.html 内容:
把 index.html 的内容写入 second.html:
把 index.html 的内容追加写入 second.html:
把 index.html 和 second.html 追加写入 third.html:
14. cp 复制文件或目录
将目录 website/ 下的所有文件复制到新目录 static 下:
15. mv 移动并重命名
文件改名:
隐藏文件:
移动文件:
批量移动:
16. rm 删除一个文件或者目录
17. vi/vim
Linux 内建 vi 文书编辑器,Vim 是从 vi 发展出来的一个文本编辑器。
基本上 vi/vim 共分为三种模式,分别是命令模式(Command mode),输入模式(Insert mode)和底线命令模式(Last line mode)。我们边操作边介绍这三种模式: 我们执行
vim index.html
,如果没有该文件,则会创建文件:此时界面为:
此时是命令模式,在命令模式下,输入的任何字符都会被视为命令,接下来几个常用的命令:
我们按下
i
,便会进入输入模式:输入模式下,左下角有
-- INSERT --
标志:此时我们可以进行各种输入,当输入完毕后,按下 ESC 回到命令模式:
此时左下角的 INSERT已经消失不见了,如果我们要保存退出,我们先输入
:
,进入底线命令模式:在底线命令模式中,常见的命令有:
我们输入
wq
,表示保存并退出,此时我们就会发现并创建了一个 HTML 文件。18. ssh 远程连接工具
注意 ssh 监听是 22 端口。
其基本语法为:
监听端口示例:
打开调试模式:
系列文章
系列文章目录地址:https://github.com/mqyqingfeng/Blog
微信:「mqyqingfeng」,加我进冴羽唯一的读者群。
如果有错误或者不严谨的地方,请务必给予指正,十分感谢。如果喜欢或者 有所启发,欢迎 star,对作者也是一种鼓励。