当前位置: 首页 > news >正文

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

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

目录

【一】Shell命令及运行原理

【二】Linux权限的概念

【三】Linux权限管理

(1)文件类型

(2)权限分布与解释

(3)文件权限的设置

(1)chmod指令

(2)chown指令

(3)chgrp指令

(4)umask指令

【四】粘滞位

(1)粘滞位解释

(2)粘滞位使用


【一】Shell命令及运行原理

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

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

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

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

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

【二】Linux权限的概念

Linux的权限一般分为两种:

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

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

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

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

【三】Linux权限管理

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

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

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

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

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

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

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

(1)文件类型

- 开头的属于文件

d 开头的属于目录

(2)权限分布与解释

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

怎么理解三个权限对象?

所有者:文件的创造对象

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

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用户,是不受权限的约束:

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

对文件权限简称的解释:

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

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

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

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

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

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

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

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

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

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

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

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

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

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

⽤⼾符号:

u:拥有者

g:拥有者同组⽤

o:其它⽤⼾

a:所有⽤⼾

例如:

(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 执行权限的,因此需要手动添加

【四】粘滞位

(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

http://www.dtcms.com/a/394675.html

相关文章:

  • 树链剖分(模板 + 思路)
  • 医疗数据互操作性与联邦学习的python编程方向研究(上)
  • Windows最新摆烂更新,让用户没法看视频了
  • 可配置化App启动弹窗系统:实现后台动态管理与热更新引导-蜻蜓Q系统laravel+vue3-优雅草卓伊凡
  • Permute 媒体文件格式转换【音视频图像文件转换】(Mac电脑)
  • Netty:实现RPC服务(实战)
  • 408复习笔记—MIPS指令系统
  • 阿里万相2.1:蓝耘MaaS平台部署 vs 官网在线使用:万字实测对比与深度技术解析
  • 11月长春EI会议:ISRAI 2025 诚邀学者参与投稿
  • 【AI时代速通QT】第七节:Visual Studio+Qt 开发指南
  • 医疗问诊陪诊小程序:全方位守护就医体验的功能宝库
  • iOS 开发环境搭建完整指南 Xcode 安装配置、iOS 开发工具选择、ipa 打包与 App Store 上架实战经验
  • 【Node.js】Express 和 Koa 中间件的区别
  • 学习路之PHP--TP8+swoole
  • 【从零开始的大模型原理与实践教程】--第五章:动手搭建大模型LLaMA2
  • Vue.js 从入门到实践1:环境搭建、数据绑定与条件渲染
  • “潮涌之江,文兴浙里”文化推动高质量发展主题活动在西湖区调研
  • 【MongoDB】mongoDB数据迁移
  • 《C++多态入门:轻松理解虚函数与多态编程》
  • 虚拟化范式跃迁中的生命周期隐喻与命令哲学——解构Docker容器从抽象实体到可控资源的数字化生存法则
  • OpenLayers地图交互 -- 章节八:平移交互详解
  • AES+RSA 实现混合加密
  • 命名实体识别技术NER
  • 网络验证 一键加密 一键接入验证 加壳加密数盾加盾
  • JDBC组件
  • StandardScaler,MinMaxScaler等四个内置归一化函数学习
  • pandawiki 无法获取模型列表
  • openEuler2403安装宝塔面板
  • Altium Designer(AD) PCB铺铜
  • 解决Django长时间操作中的MySQL连接超时问题