目录

初阶-Linux-工具学习Shell运行原理以及Linux权限讲解

《初阶 Linux 工具学习:Shell运行原理以及Linux权限讲解》

https://i-blog.csdnimg.cn/direct/8f2fba8a28994ed6b3046c3d042bfc35.gif

https://i-blog.csdnimg.cn/direct/c850cdc97ff14abbbc10db687dfa9b21.gif

**前引:**本文并非简单罗列工具命令,而是以 “技术原理 + 实战场景” 为核心:一方面拆解工具的底层实现逻辑(如 htop 如何通过读取 /proc 文件系统获取进程信息),另一方面结合企业级需求(如高并发服务的性能瓶颈排查、大规模日志的高效分析),讲解工具的组合使用技巧与进阶参数配置。无论你是 Linux 运维工程师、后端开发人员,还是需要深入掌握系统工具的技术学习者,都能通过本文建立 “工具原理 - 场景需求 - 优化方案” 的完整技术认知,真正实现从 “会用” 到 “精通” 的跨越!


【一】Shell命令及运行原理

Linux严格意义上来说是属于操作系统,我们称之为“核⼼(kernel)

我们一般用户是无法直接使用“kemel”的,而是通过“kernel”的外壳,也就是“Shell”,完成交互!

为什么不能直接入手“kernel”?

例如windows的GUI:我们操作windows不是直接操作windows内核,⽽是通过图形点击,从⽽完成我们的操作(⽐如进⼊D盘的操作,我们通常是双击D盘盘符.或者运⾏起来⼀个应⽤程序)

但其实这只是将Linux指令图形化界面了,通过操作图形化界面让Linux执行对应指令,那这中间就有一个命令转换:Shell的最简单定义–命令⾏解释器(command Interpreter),例如:

https://i-blog.csdnimg.cn/direct/79674ac26005495eaec3511712805e3b.png

【二】Linux权限的概念

Linux的权限一般分为两种:

超级用户(root):可以在 Linux 系统下做任何事情,不受限制,超级⽤⼾的命令提⽰符是“#”

https://i-blog.csdnimg.cn/direct/8da0315a7f5d46a9a2fc41d27f9ede07.png

**普通⽤⼾:**在 Linux 下做有限的事情,普通用户的命令提示符是“¥”

https://i-blog.csdnimg.cn/direct/5b26d7f6b57b4400bb89a93b09619442.png

权限用户的切换:su 或者 su - ,后面接用户名:root 或者 普通用户名

                           (root->普通用户不需要密码,普通用户->root需要密码)

https://i-blog.csdnimg.cn/direct/edc534eca109466db2e97cf884165473.png

【三】Linux权限管理

我们知道,Linux之下一切皆文件!

Linux操作的是文件,那么上面说的Linux权限分类可以这么理解:对操作文件权限的分类

操作文件的身份在Linux里面我们可以分为一下三类:

所有者:⽂件和⽂件⽬录的所有者(u),可理解为创造者

所属组:⽂件和⽂件⽬录的所有者所在的组的⽤⼾(g),可理解为使用者

other:其它用户(o),可理解为除了上面两类之外的

例如:在Linux操作的文件是有显示文件的各种信息的,下面我们来重点讨论几个信息!

https://i-blog.csdnimg.cn/direct/82a9d00a65494ed7a7b947ab8d01c22f.png

(1)文件类型

- 开头的属于文件

d 开头的属于目录

(2)权限分布与解释

除了开头的文件类型,后面九个每三个为一组分别代表:所有者、所属组、other权限,例如:

https://i-blog.csdnimg.cn/direct/6162bdd169474c2aba08983d822b4e95.png

怎么理解三个权限对象?

所有者:文件的创造对象

所属组:可以理解为多个人集中管理一个文件,那这多个人就在一个组里面

other:除了上面两种之外的统一解释为other

如何成为所属组成员?

所属组权限对象由 文件所有者 和 root 操控

(1)查看文件所在的所有组

ls -l 目标文件

(2)分配给所属组

  • -a:表示 “追加”(避免覆盖你原有的所属组)
  • -G:指定要加入的组(这里是文件的所属组dev_group
# 格式:sudo usermod -aG 目标组名 你的用户名
sudo usermod -aG dev_group your_username

(3)检查

# 查看自己所属的所有组
groups your_username

如果自己是文件的创造者或者root,那么没有了rwx权限,还可以操作吗?

如果是root用户,是不受权限的约束:

https://i-blog.csdnimg.cn/direct/00e3d0034bc043d2a97c5151d7a14724.png

如果修改所有者,所有者会受到影响:但是可以自己操作文件权限改回来

https://i-blog.csdnimg.cn/direct/00cc78a88cdb4dafa77b594b9310fb55.png

对文件权限简称的解释:

读(r/4):Read对⽂件⽽⾔,具有读取⽂件内容的权限

                   对⽬录来说,具有浏览该⽬录信息的权限

写(w/2):Write对⽂件⽽⾔,具有修改⽂件内容的权限

                    对⽬录来说具有删除移动⽬录内⽂件的权限

执⾏(x/1):execute对⽂件⽽⾔,具有执⾏⽂件的权限

                       对⽬录来说,具有进⼊⽬录的权限

 “—”表⽰不具有该项权限

(3)文件权限的设置
(1)chmod指令

作用:设置文件的访问权限

选项:-R 递归修改文件的权限

格式:⽤⼾表⽰符+/-=权限字符

+:向权限范围增加权限代号所表⽰的权限

-:向权限范围取消权限代号所表⽰的权限

=:向权限范围赋予权限代号所表⽰的权限

⽤⼾符号:

u:拥有者

g:拥有者同组⽤

o:其它⽤⼾

a:所有⽤⼾

例如:

https://i-blog.csdnimg.cn/direct/1175112ca153408685dfad58da5e3133.png

(2)chown指令

功能:修改⽂件的拥有者

选项:-R 递归修改文件的权限

格式:chown  [参数]  ⽤⼾名  ⽂件名

例如:

chown   user1   f1

chown  -R   user1   filegroup1

(3)chgrp指令

功能:修改⽂件或⽬录的所属组

格式:chgrp  [参数]   ⽤⼾组名  ⽂件名

常⽤选项:-R   递归修改⽂件或⽬录的所属组

实例: chgrp users   /abc/f2

(4)umask指令

作用:修改/查看文件掩码

何为文件掩码?

文件的权限掩码(umask) 即当文件/目录出生时,根据掩码屏蔽掉该文件/目录的部分权限,即完成一个文件/目录的出厂设置!

如何根据掩码计算文件出厂权限?(了解)

权限掩码的计算不是简单的 “数值减法”,而是基于二进制的按位操作。具体步骤如下:

(1)明确 “基础权限”(系统固定值)

新文件 / 目录的默认权限计算,首先依赖系统预设的 “基础权限”(不可修改):

  • 普通文件:基础权限为 666(对应权限字符串 -rw-rw-rw-默认无执行权限,避免安全风险);
  • 目录:基础权限为 777(对应权限字符串 drwxrwxrwx,目录必须有执行权限才能进入,因此基础权限包含 x)。

(2)理解权限的 “数字 - 二进制 - 字符” 对应关系

权限由 “读(r)、写(w)、执行(x)” 三种基础权限组成,每组角色(所有者、组、other)的权限可转换为数字或二进制:

  • r(读)=4(二进制 100
  • w(写)=2(二进制 010
  • x(执行)=1(二进制 001
  • 无权限(-)=0(二进制 000

例如:

  • rwx = 4+2+1 = 7(二进制 111
  • rw- = 4+2 = 6(二进制 110
  • r-- = 4(二进制 100

(3)计算步骤:按位取反 → 按位与

权限掩码的计算需通过两步二进制操作:目标权限 = 基础权限 & (~umask),推导 umask

(1)将权限掩码(umask 值)转换为二进制后按位取反~(0 变 1,1 变 0)

(2)将 “基础权限” 的二进制与 “取反后的掩码” 进行按位与(&)(同1为1,否则为0) 操             作,结果即为新文件的默认权限

格式:

umask   //查看

umask 044  //设置

例如:

现在我查看普通用户的掩码,然后修改为 rwx(000),在创建一个新文件看看默认权限

注意:文件的基础权限是规定不包含 x 执行权限的,因此需要手动添加

https://i-blog.csdnimg.cn/direct/234a9931ab0845098b829ab8b8d0f8d9.pnghttps://i-blog.csdnimg.cn/direct/984078c5901c426cacf7e0f80989d74a.png

【四】粘滞位

(1)粘滞位解释

粘滞位仅对目录有效(对文件的作用已在现代 Linux 中废弃),典型应用场景是系统级公共临时目录 /tmp 和 /var/tmp

(1)这些目录的默认权限是 rwxrwxrwx(所有用户都能读写执行),任何人都能在其中创建           文件

(2)若没有粘滞位,普通用户 A 可以删除普通用户 B 在 /tmp 中创建的文件,存在数据安             全风险

(3)加上粘滞位后,用户只能删除自己创建的文件(root也行)避免了误删他人文件的问题

例如:A在创建了一个目录PS,现在ABCD都在这个目录PS下面工作,现在A创建了一个文件text,按理来说这个文件只能由A或者root删除,但是实际是BCD都可以,所以避免这种情况,需要使用粘滞位来让text文件只能由A或者root删除!

启用粘滞位的目录,无论其他用户是否有写权限,都遵循以下删除 / 重命名规则:

操作(删除 / 重命名目录下的文件)是否允许?
文件的所有者执行操作✅ 允许
目录的所有者执行操作✅ 允许
root 用户执行操作✅ 允许(root 拥有最高权限,不受粘滞位限制)
其他普通用户执行操作❌ 拒绝(即使对目录有写权限,也不能删除他人文件)
(2)粘滞位使用

仅对目录生效,用 t 标识:

只有目录的所有者(owner)或 root 用户,才能为该目录设置或移除粘滞位。

格式:chmod  +t  目录位置

# 为公共目录 /data/public 添加粘滞位
chmod +t /data/public

效果:目录权限的最后一位(其他用户的执行位 x)替换为 t

https://i-blog.csdnimg.cn/direct/eea78a393943447cafea323a408afe36.gif