【Linux】指令及权限管理的学习总结

时间:2022-11-07 08:54:31


1️⃣ Linux的文件系统结构简介

????Linux文件系统为一个倒转的单根树状结构,文件系统的根是"/",文件路径使用“/”来分割。
【Linux】指令及权限管理的学习总结

作为入门,先了解一下根目录及几个根目录下的子目录:
参考博客:Linux根目录解析

  1. / ➡ 根目录:
    每一个文件和目录都从这里开始,只有root用户具有该目录下的写权限。此目录和/root目录不同,/root目录是root用户的主目录,是根目录下的一个子目录。

  2. /bin ➡ 用户二进制文件:
    包含二进制可执行文件。系统的所有用户使用的命令都设在这里,例如常用的有:ls,pwd,grep,cp等。

  3. /home ➡ 用户家目录:
    该机器的所有用户将他们的个人文件都存在/home下,每位用户有一个自己的家目录。例如:/home/zhangsan、/home/ikun。

  4. /tmp ➡ 临时文件
    包含系统和用户创建的临时文件,多用于不同用户间的交互。当系统重新启动时,这个目录下的文件都将被删除。


2️⃣ Linux下的基本指令

1. ls

语法: ls [选项] [目录名或文件名]
注意:[]方括号只是为了方便看,实际使用不需要,下文的指令语法示例都是如此
功能: 对于目录,该命令列出该目录下的所有子目录与文件;对于文件,将列出文件名以及其他信息。

常用选项:

  • -l 列出文件的详细信息。 (等价于ll,通常都是直接用ll) (常用)
  • -a 列出目录下的所有文件,包括以 . 开头的隐含文件。
  • -d 将目录象文件一样显示,而不是显示其下的文件。 如: ls –d 指定目录
  • -i 输出文件的 i 节点的索引信息。 如 ls –ai 指定文件
  • -k 以 k 字节的形式表示文件的大小。 ls –alk 指定文件
  • -n 用数字的 UID,GID 代替名称。 (介绍 UID, GID)
  • -F 在每个文件名后附上一个字符以说明该文件的类型, “*”表示可执行的普通文件; “/”表示目录; “@”表 示符号链接;“|”表示FIFOs; “=”表示套接字(sockets)。(目录类型识别)
  • -t 以时间排序。
  • -s 在l文件名后输出该文件的大小。(大小排序,如何找到目录下最大的文件)
  • -r 对目录反向排序。
  • -R 列出所有子目录下的文件。 (递归) (区分大小写r)
  • -1 一行只输出一个文件。

2. pwd

语法: pwd
功能: 显示用户当前所在的目录
常用选项:

3. cd

语法: cd [目录名]
功能: 改变当前工作目录到指定目录下。
举例:

cd … :返回上级目录
cd ~ :返回用户的家目录
cd - :返回最近访问目录
cd /home/name/test :绝对路径
cd …/test :相对路径

4. touch

语法: touch [选项] [文件名]
功能: ➀新建一个不存在的文件 ➁更改文档或目录的日期时间,包括存取时间和更改时间
常用选项:

  • -a 或–time=atime或–time=access或–time=use只更改存取时间。
  • -c 或–no-create 不建立任何文档。
  • -d 使用指定的日期时间,而非现在的时间。
  • -f 此参数将忽略不予处理,仅负责解决BSD版本touch指令的兼容性问题。
  • -m 或–time=mtime或–time=modify 只更改变动时间。
  • -r 把指定文档或目录的日期时间,统统设成和参考文档或目录的日期时间相同。
  • -t 使用指定的日期时间,而非现在的时间

5. mkdir

语法: mkdir [选项] dirname
功能: 在当前目录下创建一个名为 “dirname”的目录

常用选项:

-p, --parents 路径名称。此时若路径中的某些目录尚不存在,加上此选项后,系统将自动建立好那些尚不存在的目录,即一次可以建立多个目录(递归建立多个目录)

举例:
mkdir -p Test3/t1/t2/t3

【Linux】指令及权限管理的学习总结

6. rm

语法: rm [选项] [文件名或目录名]
适用对象: 根据权限判断
功能: 删除文件或目录

常用选项:

  • -f 即使文件属性为只读(即写保护),即直接删除,不会询问用户
  • -i 删除前逐一询问确认
  • -r 删除目录及其下所有文件

7. rmdir

rmdir是一个与mkdir相对应的命令。 mkdir是建立目录,而rmdir是删除命令。

语法: rmdir [-p] [目录名]
适用对象: 具有当前目录操作权限的所有使用者
功能: 删除目录

常用选项:

-p 当指定目录被删除后如果它的父目录也变成空目录的话,就连带父目录一起删除。

8. cp

类似于windows中的 ctrl c + ctrl v

语法: cp [选项] [源文件或目录] [目标文件或目录]
功能: 复制文件或目录
说明: cp指令用于复制文件或目录,如同时指定两个以上的文件或目录,且最后的目的地是一个已经存在的目录,则它会把前面指定的所有文件或目录复制到此目录中(若最后的目的地并非一个已存在的目录,则会出现错误信息)。

常用选项:

  • -r 递归复制处理,将指定目录下的文件与子目录一并处理。若源文件或目录的形态不属于目录或符号链接,则一律视为普通文件处理
  • -f 或 --force 强行复制文件或目录, 不论目的文件或目录是否已经存在
  • -i 或 --interactive 覆盖文件之前先询问用户
  • -R 或 --recursive递归处理,将指定目录下的文件及子目录一并处理

9. mv

类似于windows中的 ctrl x + ctrl v

语法: mv [选项] [源文件或目录] [目标文件或目录]
功能:

  1. 当第二个参数类型是文件时, mv命令完成文件重命名,此时,源文件只能有一个(也可以是源目录名),它将所给的源文件或目录重命名为给定的目标文件名。
  2. 当第二个参数是已存在的目录名称时,源文件或目录参数可以有多个, mv命令将各参数指定的源文件均移至目标目录中

常用选项:

  • -f 强制的意思,如果目标文件已经存在,不会询问而直接覆盖
  • -i 当目标目录中存在与源文件同名的文件时,会询问是否覆盖(不加该选项,默认也会询问)

10. cat

语法: cat [选项] [文件]
功能: 查看目标文件的全部内容

  • -b 对非空输出行编号
  • -n 对输出的所有行编号
  • -s 不输出多行空行

11. more

语法: more [选项] [文件]
功能: 从头查看目标文件的内容,可以按回车键往后翻页

常用选项:

  • -n 对输出的所有行编号
  • q 退出more

12. less

  • less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大。

  • less 的用法比起 more 更加的有弹性。在 more 的时候,我们并没有办法向前面翻, 只能往后面看,但若使用了 less 时,就可以使用 [pageup][pagedown] 等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容!

  • 除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜

语法: less [参数] 文件
功能: less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件。

常用选项:

  • -i 忽略搜索时的大小写
  • -N 显示每行的行号
  • /字符串:向下搜索“字符串”的功能
  • ?字符串:向上搜索“字符串”的功能
  • n:重复前一个搜索(与 / 或 ? 有关)
  • N:反向重复前一个搜索(与 / 或 ? 有关)
  • q:quit

13. head

head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块, head 用来显示文件的开头至标准输出中,而 tail 想当然就是看文件的结尾

语法: head [选项] [文件]
功能: head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。

选项:

  • -n 行数

14. tail

tail命令从指定点开始将文件写到标准输出。使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容

语法: tail [必要参数] [选择参数] [文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。

选项:

  • -f 循环读取
  • -n<行数> 显示行数

15. find

语法: find [选项] [文件名]
功能: 用于在文件树中查找文件,并作出相应的处理(可能访问磁盘)

常用选项:

  • -name 按照文件名查找文件

16. grep

语法: grep [选项] 搜寻字符串 文件
功能: 在文件中搜索字符串,将找到的行打印出来
常用选项:

  • -i 忽略大小写,所有大小写视为相同
  • -n 输出行号
  • -v 反向选择,即显示出没有 ‘搜寻字符串’ 内容的那些行

⭕其他一些关于搜索的指令

which 搜索指令
whereis 近似搜索

范围:whereis < which < find

17. zip

语法: zip [选项] [压缩文件.zip] [目录或文件]
功能: 将目录或文件压缩成zip格式到当前工作目录

常用选项:

  • -r 递归处理,将指定目录下的所有文件和子目录一并处理

18. unzip

语法: unzip [.zip文件]
功能: 将压缩包解压到当前工作目录

常用选项:

  • -d [目录] 解压文件到指定目录下

19. tar

有打包或解包功能,根据选项的不同而定。
语法: tar [选项] [文件与目录]
参数:

  • -c :建立一个压缩文件.tgz的参数指令 (create 的意思)
  • -x :解开一个压缩文件的参数指令
  • -z :是否同时具有 gzip 的属性。即是否需要用 gzip 压缩。(压缩时一般都要加)
  • -f :使用档名,在 f 之后要立即接档名。不要再加参数。(一般都要加)
  • -C : 解压到指定目录
  • -t :查看 tarfile 里面的文件!
  • -j :是否同时具有 bzip2 的属性。即是否需要用 bzip2 压缩。
  • -v :压缩的过程中显示文件。这个常用,但不建议用在背景执行过程。

20. uname

语法: uname [选项]
功能: uname用来获取电脑和操作系统的相关信息。
补充说明: uname可显示linux主机所用的操作系统的版本、硬件的名称等基本信息。

常用选项:

  • -a或–all 详细输出所有信息,依次为内核名称,主机名,内核版本号,内核版本,硬件名,处理器类 型,硬件平台类型,操作系统名称

3️⃣ Linux下的权限

权限,就是什么人能干什么事,在Linux下同样有权限,约束着用户使用和操作文件。

????Linux有两种用户:超级用户(root)和普通用户

  • 超级用户:可以在Linux系统下做任何事情,不受限制
  • 普通用户:在Linux下只能做有限的事情

超级用户root的命令提示符是“#”,普通用户的命令提示符是“$"

【Linux】指令及权限管理的学习总结

在切换不同用户的命令是 su [用户名] ,要从root用户切换到普通用户user,则直接使用su user
要从普通用户user切换到root用户则使用 su root(root可以省略,直接su),此时系统会提示输入root用户的密码。

权限管理

⭕Linux下的权限可以理解为用户对文件的权限,这里的两个主体是用户和文件,而权限的管理就是从这两个主体出发的。

1. 文件的访问者分类(用户)

这里的访问者分类只是分成不同角色,而不是具体的用户,只是具体用户的一种身份

  • 文件或目录的所有者:u —— user
  • 文件或目录的所有者所在组的其他用户(所属群): g —— group
  • 其他用户:o —— others

2. 文件类型和访问权限(文件)

⭕我们通常会在查看文件和目录信息时,看到它们前面带着这样的一串符号,其实这就是用于表示文件类型和访问权限的字符串。

【Linux】指令及权限管理的学习总结

????它们表示的意思如图所示
【Linux】指令及权限管理的学习总结

第2-10位中,每个访问者的权限顺序都是 rwx

1. 文件类型

d:文件夹
-:普通文件
l:软链接(类似Windows的快捷方式)
b:块设备文件(例如硬盘、光驱等)
p:管道文件
c:字符设备文件(例如屏幕等串口设备)
s:套接口文件

2. 基本权限

① 读 rRead对文件而言,具有读取文件内容的权限;对目录来说,具有ls浏览该目录信息的权限

② 写 wWrite对文件而言,具有修改文件内容的权限;对目录来说具有创建或删除目录内文件的权限

③ 执行 x : eXecute对文件而言,具有执行文件的权限;对目录来说,具有cd进入目录的权限

- :表示不具有该项权限


3. 文件权限值的表示方法

① 字符表示法,就是用’r’ ‘w’ ‘x’ ‘-’ 四个字符表示文件的权限,比较通俗易懂。

② 八进制表示法:

先将表示文件权限的9位字符转化位0或1(有权限为1,无权限为0),再将转化后的数字字符串视为三个二进制数,转化成八进制数,这样就可以用三个八进制数来表示文件权限了。

⭕例:

【Linux】指令及权限管理的学习总结


4. 文件访问权限的相关设置方法

了解了文件访问权限的概念,可以想象到权限肯定不是固定的,是可以修改和变化的,就像人通过地位的提升权限也会扩大。不仅是人的权限可以修改,权限为谁所有也可以修改。下面就来看看如何设置文件访问权限。

????chmod指令

注意:只有文件的拥有者和 root才可以改变文件的权限

功能: 设置文件的访问权限
格式: chmod [参数] [权限] [文件名]

常用选项:

  • R:递归修改目录文件的权限

chmod命令权限值的格式

① 用户表示符 +-= 权限表示字符 (r,w,x)

+:向权限范围增加权限字符所表示的权限
-:向权限范围取消权限字符所表示的权限
=:向权限范围赋予权限字符所表示的权限
用户符号: u—拥有者 g—拥有者同组用 o—其它用户 a—所有用户

实例:

chmod u-w 666.c

chmod g+wx 666.c

chmod o=r-- 666.c

chmod o=g 666.c (可以直接将一个访问者的权限赋予另一个)

② 三位8进制数字

实例:

chmod 664 666.c

chmod 640 666.c



????chown指令

功能: 修改文件的拥有者
格式: chown [参数] [用户名] [文件名]

常用选项:

-R 递归修改文件或目录的拥有者

实例:
chown user1 f1

chown -R user1 filegroup1



????chgrp指令

功能: 修改文件或目录的所属组
格式: chgrp [参数] [用户组名] [文件名]

常用选项:

-R 递归修改文件或目录的所属组



????umask指令

????新建文件默认权限=0666,新建目录默认权限=0777,但实际上你所创建的文件和目录,看到的权限往往不是上面这个值。原因就是创建文件或目录的时候还要受到umask掩码的影响。假设默认权限是mask,则实际创建的出来的文件权限是:mask & (~umask)

功能: 查看或修改文件掩码
格式: umask [权限值]

说明:超级用户默认掩码值为0022,普通用户默认为0002。

实例:

umask //查看

umask 020 //设置


⭕演示:root用户创建一个普通文件

【Linux】指令及权限管理的学习总结

⭕验证结果

【Linux】指令及权限管理的学习总结


5. 粘滞位的概念

Introduction

???? 在根目录下,存在一个目录tmp,作为公用的临时文件存储点,一般用于不同用户之间文件的交互。我们可以试着在根目录下模拟实现一个mytmp。

【Linux】指令及权限管理的学习总结
【Linux】指令及权限管理的学习总结

????经过一段时间的使用,各个用户都在mytmp中创建了属于自己的文件。

【Linux】指令及权限管理的学习总结

????有一天,用户ckf操作失误,误删了用户DongYu的文件dy,本来这一操作应该是不被允许的,每个用户只能删除自己拥有的文件,但是没想到却成功的删除了。

【Linux】指令及权限管理的学习总结

????这一现象是因为,用户有了目录的写权限,就可以任意删除该目录下的任意文件,无论该用户有没有这个文件的写权限。
这貌似不太合理,若root超级用户删除普通用户的文件倒还说得通,因为root的权限大于普通用户,但是两个权限平行的普通用户怎么可以互删文件呢?

Body

????为了解决这个不合理的问题, Linux引入了粘滞位的概念

粘滞位是目录权限的一种特殊情况,用 chmod +t [目录名] 设置。

当一个目录被设置为"粘滞位"时,该目录下的文件只能由

  1. 超级用户root删除
  2. 该目录的所有者删除
  3. 该文件的所有者删除

⭕实例

【Linux】指令及权限管理的学习总结


关于权限的小结

  • 目录的可执行权限是表示你可否在目录下执行命令。

  • 如果对目录没有x执行权限,则无法对目录执行任何命令,甚至无法cd进入目录,即使对目录仍然有r读权限(这个地方很容易犯错,认为有读权限就可以进入目录读取目录下的文件)
    【Linux】指令及权限管理的学习总结

  • 而如果目录具有x权限,但没有r权限,则用户可以执行命令,可以cd进入目录。但由于没有目录的读权限,即使可以执行ls命令,但仍然没有权限读出目录下的文档。