文章目录
1️⃣ Linux的文件系统结构简介
🌲Linux文件系统为一个倒转的单根树状结构,文件系统的根是"/",文件路径使用“/”来分割。
作为入门,先了解一下根目录及几个根目录下的子目录:
参考博客:Linux根目录解析
-
/ ➡ 根目录:
每一个文件和目录都从这里开始,只有root用户具有该目录下的写权限。此目录和/root目录不同,/root目录是root用户的主目录,是根目录下的一个子目录。 -
/bin ➡ 用户二进制文件:
包含二进制可执行文件。系统的所有用户使用的命令都设在这里,例如常用的有:ls,pwd,grep,cp等。 -
/home ➡ 用户家目录:
该机器的所有用户将他们的个人文件都存在/home下,每位用户有一个自己的家目录。例如:/home/zhangsan、/home/ikun。 -
/tmp ➡ 临时文件
包含系统和用户创建的临时文件,多用于不同用户间的交互。当系统重新启动时,这个目录下的文件都将被删除。
2️⃣ Linux下的基本指令
1. ls
语法: ls [选项] [目录名或文件名]
注意:[]方括号只是为了方便看,实际使用不需要,下文的指令语法示例都是如此
功能: 对于目录,该命令列出该目录下的所有子目录与文件;对于文件,将列出文件名以及其他信息。
常用选项:
2. pwd
语法: pwd
功能: 显示用户当前所在的目录
常用选项: 无
3. cd
语法: cd [目录名]
功能: 改变当前工作目录到指定目录下。
举例:
4. touch
语法: touch [选项] [文件名]
功能: ➀新建一个不存在的文件 ➁更改文档或目录的日期时间,包括存取时间和更改时间
常用选项:
5. mkdir
语法: mkdir [选项] dirname
功能: 在当前目录下创建一个名为 “dirname”的目录
常用选项:
举例:
mkdir -p Test3/t1/t2/t3
6. rm
语法: rm [选项] [文件名或目录名]
适用对象: 根据权限判断
功能: 删除文件或目录
常用选项:
7. rmdir
rmdir是一个与mkdir相对应的命令。 mkdir是建立目录,而rmdir是删除命令。
语法: rmdir [-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 [选项] [源文件或目录] [目标文件或目录]
功能:
- 当第二个参数类型是文件时, mv命令完成文件重命名,此时,源文件只能有一个(也可以是源目录名),它将所给的源文件或目录重命名为给定的目标文件名。
- 当第二个参数是已存在的目录名称时,源文件或目录参数可以有多个, mv命令将各参数指定的源文件均移至目标目录中。
常用选项:
10. cat
语法: cat [选项] [文件]
功能: 查看目标文件的全部内容
11. more
语法: more [选项] [文件]
功能: 从头查看目标文件的内容,可以按回车键往后翻页
常用选项:
12. less
-
less 工具也是对文件或其它输出进行分页显示的工具,应该说是linux正统查看文件内容的工具,功能极其强大。
-
less 的用法比起 more 更加的有弹性。在 more 的时候,我们并没有办法向前面翻, 只能往后面看,但若使用了 less 时,就可以使用 [pageup][pagedown] 等按键的功能来往前往后翻看文件,更容易用来查看一个文件的内容!
-
除此之外,在 less 里头可以拥有更多的搜索功能,不止可以向下搜,也可以向上搜
语法: less [参数] 文件
功能: less与more类似,但使用less可以随意浏览文件,而more仅能向前移动,却不能向后移动,而且less在查看之前不会加载整个文件。
常用选项:
13. head
head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块, head 用来显示文件的开头至标准输出中,而 tail 想当然就是看文件的结尾
语法: head [选项] [文件]
功能: head 用来显示档案的开头至标准输出中,默认head命令打印其相应文件的开头10行。
选项:
14. tail
tail命令从指定点开始将文件写到标准输出。使用tail命令的-f选项可以方便的查阅正在改变的日志文件,tail -f filename会把filename里最尾部的内容显示在屏幕上,并且不但刷新,使你看到最新的文件内容
语法: tail [必要参数] [选择参数] [文件]
功能: 用于显示指定文件末尾内容,不指定文件时,作为输入信息进行处理。常用查看日志文件。
选项:
15. find
语法: find [选项] [文件名]
功能: 用于在文件树中查找文件,并作出相应的处理(可能访问磁盘)
常用选项:
16. grep
语法: grep [选项] 搜寻字符串 文件
功能: 在文件中搜索字符串,将找到的行打印出来
常用选项:
⭕其他一些关于搜索的指令
which 搜索指令
whereis 近似搜索
范围:whereis < which < find
17. zip
语法: zip [选项] [压缩文件.zip] [目录或文件]
功能: 将目录或文件压缩成zip格式到当前工作目录
常用选项:
18. unzip
语法: unzip [.zip文件]
功能: 将压缩包解压到当前工作目录
常用选项:
19. tar
有打包或解包功能,根据选项的不同而定。
语法: tar [选项] [文件与目录]
参数:
20. uname
语法: uname [选项]
功能: uname用来获取电脑和操作系统的相关信息。
补充说明: uname可显示linux主机所用的操作系统的版本、硬件的名称等基本信息。
常用选项:
3️⃣ Linux下的权限
权限,就是什么人能干什么事,在Linux下同样有权限,约束着用户使用和操作文件。
💭Linux有两种用户:超级用户(root)和普通用户
- 超级用户:可以在Linux系统下做任何事情,不受限制
- 普通用户:在Linux下只能做有限的事情
超级用户root的命令提示符是“#”,普通用户的命令提示符是“$"
权限管理
⭕Linux下的权限可以理解为用户对文件的权限,这里的两个主体是用户和文件,而权限的管理就是从这两个主体出发的。
1. 文件的访问者分类(用户)
这里的访问者分类只是分成不同角色,而不是具体的用户,只是具体用户的一种身份
- 文件或目录的所有者:u —— user
- 文件或目录的所有者所在组的其他用户(所属群): g —— group
- 其他用户:o —— others
2. 文件类型和访问权限(文件)
⭕我们通常会在查看文件和目录信息时,看到它们前面带着这样的一串符号,其实这就是用于表示文件类型和访问权限的字符串。
🔎它们表示的意思如图所示
第2-10位中,每个访问者的权限顺序都是 rwx
1. 文件类型
2. 基本权限
① 读 r
: Read对文件而言,具有读取文件内容的权限;对目录来说,具有ls浏览该目录信息的权限
② 写 w
: Write对文件而言,具有修改文件内容的权限;对目录来说具有创建或删除目录内文件的权限
③ 执行 x
: eXecute对文件而言,具有执行文件的权限;对目录来说,具有cd进入目录的权限
④ -
:表示不具有该项权限
3. 文件权限值的表示方法
① 字符表示法,就是用’r’ ‘w’ ‘x’ ‘-’ 四个字符表示文件的权限,比较通俗易懂。
② 八进制表示法:
⭕例:
4. 文件访问权限的相关设置方法
了解了文件访问权限的概念,可以想象到权限肯定不是固定的,是可以修改和变化的,就像人通过地位的提升权限也会扩大。不仅是人的权限可以修改,权限为谁所有也可以修改。下面就来看看如何设置文件访问权限。
🔎chmod指令
⭕注意:只有文件的拥有者和 root才可以改变文件的权限
功能: 设置文件的访问权限
格式: chmod [参数] [权限] [文件名]
常用选项:
chmod命令权限值的格式
① 用户表示符 +-=
权限表示字符 (r,w,x)
实例:
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 [参数] [用户名] [文件名]
常用选项:
实例:
chown user1 f1
chown -R user1 filegroup1
🔎chgrp指令
功能: 修改文件或目录的所属组
格式: chgrp [参数] [用户组名] [文件名]
常用选项:
🔎umask指令
功能: 查看或修改文件掩码
格式: umask [权限值]
说明:超级用户默认掩码值为0022,普通用户默认为0002。
实例:
umask //查看
umask 020 //设置
⭕演示:root用户创建一个普通文件
⭕验证结果
5. 粘滞位的概念
Introduction
Body
💡为了解决这个不合理的问题, Linux引入了粘滞位的概念
粘滞位是目录权限的一种特殊情况,用 chmod +t [目录名]
设置。
当一个目录被设置为"粘滞位"时,该目录下的文件只能由
- 超级用户root删除
- 该目录的所有者删除
- 该文件的所有者删除
⭕实例
关于权限的小结
-
目录的可执行权限是表示你可否在目录下执行命令。
-
如果对目录没有x执行权限,则无法对目录执行任何命令,甚至无法cd进入目录,即使对目录仍然有r读权限(这个地方很容易犯错,认为有读权限就可以进入目录读取目录下的文件)
-
而如果目录具有x权限,但没有r权限,则用户可以执行命令,可以cd进入目录。但由于没有目录的读权限,即使可以执行ls命令,但仍然没有权限读出目录下的文档。