1.用户Owner、Group、Others、Root

Linux 系统是一种多用户系统,它将文件访问者身份分为三种:

  • 文件所有者(Owner)

    当创建一个用户的时候,Linux 会为该用户创建一个主目录,路径为 /home/<username>,我们可以使用 cd ~,快捷进入主目录。如果你想放一个私密文件,就可以放在自己的主目录里,然后设置只能自己查看。

  • 群组(Group)

    每个用户都有一个用户组,方便多人操作的时候,为一群人分配权限。当创建用户的时候,会自动创建一个与它同名的用户组。

    如果一个用户同时属于多个组,用户需要在用户组之间切换,才能具有其他用户组的权限。

  • 其他人(Others)

    既不是文件所有者又不是文件所属群组成员的用户,就是其他人。

  • 超级用户(Root)

    Root 用户是一类特殊的用户,该用户可以访问所有文件

2.adduser 添加用户 和 passwd 更改密码

1
2
3
4
# 添加一个名为 git 的用户
adduser git
# 设置 git 用户的密码
passwd git

但是由于创建的用户权限较低,有的时候我们需要为用户提权,此时我们可以这样做:

1
2
# 会打开 sudoers 配置文件
sudo visudo

注意同样是编辑 sudoers 配置文件,使用这个命令会比使用 sudo vim /etc/ sudoers 更安全, 除了对语法有校验,并且还会在多用户编辑的时候锁住文件。

打开 sudoers 配置文件后,我们添加这样一行配置:

1
2
# Allow git to run any commands anywhere
git ALL=(ALL:ALL) ALL

简单解释下这句话 git ALL=(ALL:ALL) ALL

  • git 表示规则应用的用户名
  • 第一个 ALL 表示规则应用于所有 hosts
  • 第二个 ALL 表示规则应用于所有 users
  • 第三个 ALL 表示规则应用于所有 groups
  • 第四个 ALL 表示规则应用于所有 commands

我们保存退出后,git 用户就会获得 root 权限。

3. ls 列出文件和目录

  1. ls 列出文件和目录
1
2
[root@zy learn.git]# ls
branches config description HEAD hooks index info objects refs
  1. ls -la-a 显示所有文件和目录(包括隐藏)和 -l 显示详细列表组成:
1
2
3
4
5
6
7
8
9
10
11
12
13
[root@zy learn.git]# ls -la
总用量 20
drwxrwxr-x 7 git git 132 12月 15 12:33 .
drwx------ 3 git git 127 12月 15 14:51 ..
drwxrwxr-x 2 git git 6 12月 15 12:21 branches
-rw-rw-r-- 1 git git 66 12月 15 12:21 config
-rw-rw-r-- 1 git git 73 12月 15 12:21 description
-rw-rw-r-- 1 git git 23 12月 15 12:21 HEAD
drwxrwxr-x 2 git git 4096 12月 15 13:10 hooks
-rw-rw-r-- 1 git git 217 12月 15 12:33 index
drwxrwxr-x 2 git git 21 12月 15 12:21 info
drwxrwxr-x 10 git git 90 12月 15 12:33 objects
drwxrwxr-x 4 git git 31 12月 15 12:21 refs

每一行都有 7 列,我们以 branches 为例讲解每列的含义:

drwxrwxr-x2gitgit612月 15 12:21branches
文件类型和权限信息链接数或者一级子目录数所有者所属组文件大小,单位字节最后修改时间文件名

重点看第 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:

1
2
3
4
[root@iZ2ze www]# mkdir test
[root@iZ2ze www]# ls -l

drwxr-xr-x 2 root root 6 12月 17 23:53 test

创建文件的默认权限是 rw-r--r--,注意创建文件默认会去掉 x(可执行) 权限:

1
2
3
4
[root@iZ2ze www]# touch index.html
[root@iZ2ze www]# ls -l

-rw-r--r-- 1 root root 0 12月 17 23:54 index.html

这就是为什么我们有的时候需要在创建文件后,又加上执行权限。

4. chown 更改文件属主,也可以同时更改文件属组

chown (change owner) 语法:

1
2
3
# -R:递归更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名

index.html 的所有者更改为 git

1
2
3
4
[root@zy www]# chown git index.html
[root@zy www]# ls -

-rw-r--r-- 1 git root 0 12月 17 23:54 index.html

index.html 的所有者和群组都改为 git

1
2
3
4
[root@zy www]# chown git:git index.html
[root@zy www]# ls -l

-rw-r--r-- 1 git git 0 12月 17 23:54 index.html

5. chmod 更改文件权限

权限除了用 r w x 这种方式表示,也可以用数字表示,数组与字母的对应关系为:

  • r:4
  • w:2
  • x:1

之所有如此对应关系,是根据二进制所来的

0代表无权限
1代表有权限
001 = 1 = 可执行
010 = 2 = 可读
100 = 4 = 可写

我们看下 chmod (change mode) 的具体语法:

1
2
# -R:递归更改文件属组
chmod [-R] xyz 文件或目录

其中 xyz 分别表示 Owner、Group、Others 的权限,如果我们这样设置一个文件的权限:

1
chmod 750 index.html

我们可以得知,Owner 的权限为 7,为可读可写可执行,Group 的权限为 5,为可读可执行,Others 的权限为 0,表示不可读写不可执行。对应字母为:rwxr-x---

除了这种数字的方式,还有一种使用符号类型改变权限的方式:

在这种方式里,我们将三种身份 OwnerGroupOthers,分别简写为 u(User)go,用 a 表示所有身份,再使用 + - = 表示加入、去除、设定一个权限,r w x 则继续表示读,写,执行权限,举个例子:

1
chmod u+x,g-x,o-x index.html

意思就是 Owner 加上执行权限,GroupOthers 去除执行权限。

当然我们也可以直接设定权限

1
chmod u=rwx,g=rx,o=r index.html

此时文件的权限就相当于 -rwxr-xr--

此外,我们还可以省略不写 ugoa 这类身份内容,直接写:

1
chmod +x index.html

此时相当于使用了 a,会给所有身份添加执行权限。

6.cd 切换工作目录

1
2
3
4
5
6
7
8
# 进入 /home/www/
cd /home/www

# 进入自己的主目录
cd ~

# 进入当前目录的上上两层 :
cd ../..

7. mkdir 创建目录

  1. mkdir 创建目录:
1
mkdir new_folder
  1. mkdir -p 递归创建目录:
1
mkdir -p one/two/three

8.cat 连接文件并打印输出

查看文件内容:

1
cat ~/.ssh/id_rsa.pub

清空 index.html 内容:

1
cat /dev/null > index.html

把 index.html 的内容写入 second.html:

1
cat index.html > second.html

把 index.html 的内容追加写入 second.html:

1
cat index.html >> second.html

把 index.html 和 second.html 追加写入 third.html:

1
cat index.html second.html >> third.html

9.mv 移动并重命名

文件改名:

1
mv index.html index2.html

隐藏文件:

1
2
# 文件名上加上 .
mv index.html .index.html

移动文件:

1
2
3
4
# 仅仅移动
mv /home/www/index.html /home/static/
# 移动又重命名
mv /home/www/index.html /home/static/index2.html

批量移动:

1
mv  /home/www/website/*  /home/www/static

10.rm 删除一个文件或者目录

1
2
3
4
5
6
7
8
9
10
11
# 系统会询问
rm file

# -f 表示直接删除
# -r 表示目录下的所有文件删除

# 删除当前目录下的所有文件及目录
rm -r *

# 跑路
rm -rf /*

11.ssh 远程连接工具

注意 ssh 监听是 22 端口。

其基本语法为:

1
ssh [OPTIONS] [-p PORT] [USER@]HOSTNAME [COMMAND]

监听端口示例:

1
ssh -p 300 git@8.8.8.8

打开调试模式:

1
2
# -v 冗详模式,打印关于运行情况的调试信息
ssh -v git@8.8.8.8