Linux权限机制深度解读:系统安全的第一道防线

在这里插入图片描述

文章目录

  • 前言
    • ‼️一、Linux权限的概念
    • ‼️二、Linux权限管理
      • ❕2.1 文件访问者的分类(人)
      • ❕2.2 文件类型和访问权限(事物属性)
        • ✔️1. 文件类型
        • ✔️2. 基本权限
        • ✔️3. 权限值的表示方法
      • ❕2.3 文件访问权限的相关设置方法
        • ✔️1. `chmod` 命令
        • ✔️2. `chown` 命令
        • ✔️3. `chgrp` 命令
    • ‼️三、其他权限问题
      • ❕3.1 问题一:为什么普通文件是664,目录文件是775?
        • ✔️1. umask 的作用与工作原理
        • ✔️2. umask 的计算规则
        • ✔️3. 查看和设置 umask
      • ❕3.2 问题二:目录的权限代表什么?
        • ✔️1. 读取权限(`r` - Read)
        • ✔️2. 写入权限(`w` - Write)
        • ✔️3. 执行权限(`x` - Execute)
      • ❕3.3 问题三:想要建立共享文件,但不想让其他人删除怎么办?
        • ✔️1. 粘滞位的作用
        • ✔️2. 粘滞位的表示
        • ✔️3. 设置和移除粘滞位
  • 结语


前言

在现代操作系统中,权限管理是保障安全与系统稳定运行的关键环节。Linux作为一个广泛应用的开源操作系统,其权限体系以灵活性、可扩展性和严谨性著称。无论是个人用户还是企业环境,理解并掌握Linux权限管理,既是保障信息安全的基础,也能大幅提升系统管理效率。本文将带你深入探索Linux权限体系的核心概念、常见操作以及最佳实践。


‼️一、Linux权限的概念

Linux下有两种用户:超级用户(root)、普通用户

  • 超级用户:可以再linux系统下做任何事情,不受限制
  • 普通用户:在linux下做有限的事情。
  • 超级用户的命令提示符是“#”,普通用户的命令提示符是“$”。

命令:su [用户名]

功能:切换用户。

例如,要从root用户切换到普通用户user,则使用 su user。 要从普通用户user切换到root用户则使用 su root(root可以省略),此时系统会提示输入root用户的口令。退出用户使用 exit 或者 ctrl + d。

‼️二、Linux权限管理

❕2.1 文件访问者的分类(人)

  • 文件和文件目录的所有者:u—User(中国平民 法律问题)

  • 文件和文件目录的所有者所在的组的用户:g—Group(不多说)

  • 其它用户:o—Others (外国人)

❕2.2 文件类型和访问权限(事物属性)

在这里插入图片描述

✔️1. 文件类型

Linux 文件类型由文件的第一个字符标识,当使用命令 ls -l 查看文件列表时,可以看到类似如下的输出:

-rwxr-xr--
drwxr-xr-x
lrwxrwxrwx

第一个字符表示文件的类型,可能的取值如下:

字符文件类型
-普通文件 (Regular File)
d目录 (Directory)
l符号链接 (Symbolic Link)
b块设备文件 (Block Device)
c字符设备文件 (Character Device)
p管道 (Pipe)
s套接字 (Socket)

✔️2. 基本权限

Linux 文件权限分为三组:

  • 所有者 (Owner):文件的创建者。
  • 所属组 (Group):同组用户。
  • 其他人 (Others):非所有者或非所属组的用户。

权限有三种:

权限描述
r读 (Read)4
w写 (Write)2
x执行 (Execute)1

✔️3. 权限值的表示方法

a. 符号表示法

用字母表示文件权限,例如:-rw-r--r--

字符含义
r读权限
w写权限
x执行权限
-没有该权限

例子

  • -rw-r--r-- 表示普通文件,所有者有读写权限,组用户和其他用户只有读权限。

b. 数值表示法

每种权限的值相加表示最终权限。例如:

权限数值二进制
---0000
--x1001
-w-2010
-wx3011
r--4100
r-x5101
rw-6110
rwx7111

权限分为三组(Owner, Group, Others),组合成三位数字。例如:

  • -rwxr-xr-- 的数值表示为 754

❕2.3 文件访问权限的相关设置方法

✔️1. chmod 命令

chmod (Change Mode) 是用于修改 Linux 文件或目录权限的命令。权限可以用符号或八进制数表示。

基本语法

chmod [选项] 模式 文件名
  • 模式:可以是符号表示法 (u+r, g-w) 或数字表示法 (755)。
  • 文件名:要更改权限的目标文件或目录。

a. 符号表示法

符号表示法适合逐步修改权限:

chmod [ugoa][+-=][rwx] 文件名
符号作用
u文件所有者 (user)
g文件所属组 (group)
o其他人 (others)
a所有用户 (all)
+添加权限
-移除权限
=直接设定权限

示例

  1. 给文件所有者添加写权限:

    chmod u+w filename
    
  2. 删除其他人的执行权限:

    chmod o-x filename
    
  3. 所有用户设定只读权限:

    chmod a=r filename
    

b. 数字表示法

数字表示法直接设定文件权限值(例如 644755)。

权限数值二进制
---0000
--x1001
-w-2010
-wx3011
r--4100
r-x5101
rw-6110
rwx7111
  1. 设置文件权限为 rwxr-xr--

    chmod 754 filename
    
  2. 设置目录权限为 rwx------

    chmod 700 directory_name
    

常用选项

选项描述
-R递归修改权限,适用于目录及其所有子目录和文件。
-v显示每个文件权限修改的详细信息。
-c仅显示被更改的文件信息。
--reference=ref_fileref_file 的权限应用到目标文件。

示例

  1. 递归修改目录及其内容的权限:

    chmod -R 755 /path/to/directory
    
  2. 使用参考文件权限:

    chmod --reference=ref_file target_file
    
✔️2. chown 命令

chown(Change Ownership)用于更改文件或目录的所有者和/或所属组。

语法

chown [选项] [所有者][:组] 文件名
  • 所有者:文件的新所有者用户。
  • :文件的新所属组。如果不指定所有者,只修改组时,可以用 : 开头。
  • 文件名:要修改的目标文件或目录。

常用选项

选项描述
-R递归更改目录及其内容的所有者和组。
-v显示更改的详细信息。
--reference=ref_file使用参考文件的所有者和组进行设置。

示例

  1. 更改文件所有者

    chown user1 filename
    

    filename 的所有者改为 user1

  2. 更改所有者和组

    chown user1:group1 filename
    

    filename 的所有者改为 user1,所属组改为 group1

  3. 仅更改组

    chown :group1 filename
    
  4. 递归更改目录和文件的所有者

    chown -R user1:group1 /path/to/directory
    
  5. 参考其他文件的所有者和组

    chown --reference=ref_file target_file
    

✔️3. chgrp 命令

chgrp(Change Group)用于更改文件或目录的所属组。

语法

chgrp [选项] [] 文件名
  • :文件的新所属组。
  • 文件名:要修改的目标文件或目录。

常用选项

选项描述
-R递归更改目录及其内容的所属组。
-v显示更改的详细信息。
--reference=ref_file使用参考文件的组进行设置。

示例

  1. 更改文件的所属组

    chgrp group1 filename
    

    filename 的所属组改为 group1

  2. 递归更改目录和文件的所属组

    chgrp -R group1 /path/to/directory
    
  3. 参考其他文件的组

    chgrp --reference=ref_file target_file
    

‼️三、其他权限问题

在这里插入图片描述

❕3.1 问题一:为什么普通文件是664,目录文件是775?

实际上:

  • 创建文件时的默认权限是 666(没有执行权限)。

  • 创建目录时的默认权限是 777(包括执行权限)。

但是:实际权限 = 默认权限 - umask

这里我们引入一个叫做umask的东西。

✔️1. umask 的作用与工作原理

umask(User File Creation Mask)是一个在 Linux 操作系统中用于控制文件和目录默认权限的命令。它定义了文件和目录创建时的权限掩码,从而决定新创建的文件或目录的最终权限。

✔️2. umask 的计算规则

实际权限 = 默认权限 - umask

注意:这里的 - 并不是简单的减,而是,默认权限 & (~umask)

例如:

  • 如果 umask = 022
    • 文件默认权限 = 666 - 022 = 644(rw-r–r–)
    • 目录默认权限 = 777 - 022 = 755(rwxr-xr-x)
  • 如果 umask = 027
    • 文件默认权限 = 666 - 027 = 640(rw-r-----)
    • 目录默认权限 = 777 - 027 = 750(rwxr-x–)

示例:

更改 umask: 修改为 077

umask 077
touch test3.txt
mkdir dir3

在这里插入图片描述

✔️3. 查看和设置 umask
  1. 查看当前 umask 值

运行命令:

umask

这将返回一个四位的八进制数字(前三位是有效的)。

例如:

$ umask
0022
  1. 临时设置 umask

在当前会话中临时更改:

umask 0027

此更改仅适用于当前 shell 会话。

注意事项

  • umask 不会增加权限umask 只能限制权限,而不能授予额外权限。例如,设置 umask0000 允许最大权限,但不能为文件自动添加执行权限。

❕3.2 问题二:目录的权限代表什么?

✔️1. 读取权限(r - Read)
  • 作用:
    • 允许查看目录中的文件名列表。
    • 如果没有读取权限,用户即使知道目录的路径,也无法列出其中的内容(如使用 ls 命令)。
  • 效果:
    • 如果对目录有读取权限,你可以看到该目录内的文件和子目录的名称,但不能访问其内容(如果缺少执行权限)。
✔️2. 写入权限(w - Write)
  • 作用:
    • 允许在目录中创建、删除或重命名文件。
    • 如果没有写入权限,你无法在该目录中添加新文件、删除文件或修改目录结构。
  • 注意:
    • 写入权限还受执行权限的限制(即需要同时有执行权限才能实际修改目录内容)。
✔️3. 执行权限(x - Execute)
  • 作用:
    • 允许进入该目录,也就是说,用户可以切换到该目录(使用 cd 命令)。
    • 允许访问目录中的具体文件(前提是对文件本身有合适的权限)。
  • 效果:
    • 如果对目录没有执行权限,即使有读取权限,你也无法查看目录的内容。
    • 执行权限对目录至关重要,因为它决定了目录是否可用作工作路径。

❕3.3 问题三:想要建立共享文件,但不想让其他人删除怎么办?

解决方案:设置粘滞位

粘滞位(Sticky Bit)是一种特殊的权限位,用于保护目录下的文件和子目录,使得只有文件的所有者或者目录的所有者才能删除或修改该文件,即使其他用户对目录有写权限。

✔️1. 粘滞位的作用
  • 功能:当粘滞位设置在目录上时,只有以下用户可以删除或重命名该目录中的文件或子目录:
    1. 文件所有者
    2. 目录所有者
    3. 超级用户(root)
  • 应用场景:最常见的例子是 /tmp 目录。该目录通常对所有用户开放写入权限,但由于设置了粘滞位,用户只能删除或修改自己的文件,而不能影响其他用户的文件。

✔️2. 粘滞位的表示
  1. 符号模式:在文件或目录权限的符号表示中,粘滞位通常显示为目录权限的最后一位 tT

    • 如果目录同时有执行权限,粘滞位显示为 t
    • 如果目录没有执行权限,粘滞位显示为 T。 例如:
    drwxrwxrwt  10 root root  4096 Nov 19  /tmp
    

    /tmp 目录的权限显示 t,表示粘滞位已启用,且目录具有执行权限。

  2. 八进制模式:粘滞位对应的八进制值是 1,可以通过在权限数字前加上 1 设置粘滞位。例如:

    • 1755:设置了粘滞位,并且目录权限为 rwxr-xr-x
    • 1777:设置了粘滞位,并且目录权限为 rwxrwxrwx(例如 /tmp 目录)。

✔️3. 设置和移除粘滞位

设置粘滞位

使用 chmod 命令为目录添加粘滞位:

chmod +t directory_name  # 使用符号模式添加粘滞位。
chmod 1777 directory_name  # 使用八进制模式设置权限并添加粘滞位。

移除粘滞位

chmod -t directory_name  # 使用符号模式移除粘滞位。
chmod 0777 directory_name  # 使用八进制模式移除粘滞位。

结语

Linux权限体系是一个兼具严谨与灵活的设计,其核心在于平衡安全性与实用性。通过深入理解权限管理的原理和操作,你不仅能够应对常见的安全威胁,还能更高效地管理系统资源。希望本文能为你的学习和实践提供实用参考,让你在Linux系统的使用中更加自信、游刃有余。
在这里插入图片描述

今天的分享到这里就结束啦!如果觉得文章还不错的话,可以三连支持一下,17的主页还有很多有趣的文章,欢迎小伙伴们前去点评,您的支持就是17前进的动力!

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/62975.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C# 动态类型 Dynamic

文章目录 前言1. 什么是 Dynamic?2. 声明 Dynamic 变量3. Dynamic 的运行时类型检查4. 动态类型与反射的对比5. 使用 Dynamic 进行动态方法调用6. Dynamic 与 原生类型的兼容性7. 动态与 LINQ 的结合8. 结合 DLR 特性9. 动态类型的性能考虑10. 何时使用 Dynamic&…

Python毕业设计选题:基于大数据的淘宝电子产品数据分析的设计与实现-django+spark+spider

开发语言:Python框架:djangoPython版本:python3.7.7数据库:mysql 5.7数据库工具:Navicat11开发软件:PyCharm 系统展示 管理员登录 管理员功能界面 电子产品管理 系统管理 数据可视化分析看板展示 摘要 本…

用 NotePad++ 运行 Java 程序

安装包 网盘链接 下载得到的安装包: 安装步骤 双击安装包开始安装. 安装完成: 配置编码 用 NotePad 写 Java 程序时, 需要设置编码. 在 设置, 首选项, 新建 中进行设置, 可以对每一个新建的文件起作用. 之前写的文件不起作用. 在文件名处右键, 可以快速打开 CMD 窗口, 且路…

vxe-table 树形表格序号的使用

vxe-table 树形结构支持多种方式的序号&#xff0c;可以及时带层级的序号&#xff0c;也可以是自增的序号。 官网&#xff1a;https://vxetable.cn 带层级序号 <template><div><vxe-grid v-bind"gridOptions"></vxe-grid></div> <…

SQL SERVER 2016 AlwaysOn 无域集群+负载均衡搭建与简测

之前和很多群友聊天发现对2016的无域和负载均衡满心期待&#xff0c;毕竟可以简单搭建而且可以不适用第三方负载均衡器&#xff0c;SQL自己可以负载了。windows2016已经可以下载使用了&#xff0c;那么这回终于可以揭开令人憧憬向往的AlwaysOn2016 负载均衡集群的神秘面纱了。 …

Groom Blender to UE5

Groom Blender to UE5 - Character & Animation - Epic Developer Community Forums Hello, 你好&#xff0c; While exporting my “groom” from blender to UE5, I notice that the curves have a minimal resolution in Unreal. However I would like to get the same …

TCP/IP协议图--TCP/IP基础

1. TCP/IP 的具体含义 从字面意义上讲&#xff0c;有人可能会认为 TCP/IP 是指 TCP 和 IP 两种协议。实际生活当中有时也确实就是指这两种协议。然而在很多情况下&#xff0c;它只是利用 IP 进行通信时所必须用到的协议群的统称。具体来说&#xff0c;IP 或 ICMP、TCP 或 UDP、…

R语言机器学习论文(二):数据准备

禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据一、数据描述二、数据预处理(一)修改元素名称(二)剔除无关变量(三)缺失值检查(四)重复值检查(五)异常值检查三、描述性统计(一)连续变量数据情…

【算法】【优选算法】位运算(下)

目录 一、&#xff1a;⾯试题 01.01.判定字符是否唯⼀1.1 位图1.2 hash思路1.3 暴力枚举 二、268.丢失的数字2.1 位运算&#xff0c;异或2.2 数学求和 三、371.两整数之和四、137.只出现⼀次的数字 II五、⾯试题 17.19.消失的两个数字 一、&#xff1a;⾯试题 01.01.判定字符是…

【Docker】针对开发环境、测试环境、生产环境如何编排?

目录 一、引言 二、Docker Compose 文件基础 三、针对不同环境的 Docker 编排 开发环境 测试环境 生产环境 四、配置文件全局变量的编写 五、总结 一、引言 在软件开发和部署的过程中&#xff0c;不同的环境有着不同的需求和配置。Docker 作为一种强大的容器化技术&…

Flink:入门介绍

目录 一、Flink简介 2.1 Flink 架构 2.2 Flink 应用程序 运行模式 二、Flink 集群 部署 2.1 本地集群模式 2.1.1 安装JDK​编辑 2.1.2 下载、解压 Flink 2.1.3 启动集群 2.1.4 停止集群 2.2 Standalone 模式 2.2.0 集群规划 2.2.1 安装JDK 2.2.2 设置免密登录 2…

【RDMA】RDMA read和write编程实例(verbs API)

WRITE|READ编程&#xff08;RDMA read and write with IB verbs&#xff09; &#xff08;本文讲解的示例代码在&#xff1a;RDMA read and write with IB verbs | The Geek in the Corner&#xff09; 将 RDMA 与verbs一起使用非常简单&#xff1a;首先注册内存块&#xff0c…

洛谷P2670扫雷游戏(Java)

三.P2670 [NOIP2015 普及组] 扫雷游戏 题目背景 NOIP2015 普及组 T2 题目描述 扫雷游戏是一款十分经典的单机小游戏。在 n 行 m列的雷区中有一些格子含有地雷&#xff08;称之为地雷格&#xff09;&#xff0c;其他格子不含地雷&#xff08;称之为非地雷格&#xff09;。玩…

泷羽sec专题课笔记-- Linux作业--开机自启动方法以及破解

本笔记为 泷羽sec 《红队全栈课程》学习笔记&#xff0c;课程请可自行前往B站学习&#xff0c;课程/笔记主要涉及网络安全相关知识、系统以及工具的介绍等&#xff0c;请使用该课程、本笔记以及课程和笔记中提及工具的读者&#xff0c;遵守网络安全相关法律法规&#xff0c;切勿…

Linux内核早期打印机制与RS485通信技术

往期内容 本专栏往期内容&#xff1a;Uart子系统 UART串口硬件介绍深入理解TTY体系&#xff1a;设备节点与驱动程序框架详解Linux串口应用编程&#xff1a;从UART到GPS模块及字符设备驱动 解UART 子系统&#xff1a;Linux Kernel 4.9.88 中的核心结构体与设计详解IMX 平台UART驱…

汽车网络安全 -- IDPS如何帮助OEM保证车辆全生命周期的信息安全

目录 1.强标的另一层解读 2.什么是IDPS 2.1 IDPS技术要点 2.2 车辆IDPS系统示例 3.车辆纵深防御架构 4.小结 1.强标的另一层解读 在最近发布的国家汽车安全强标《GB 44495》,在7.2节明确提出了12条关于通信安全的要求,分别涉及到车辆与车辆制造商云平台通信、车辆与车辆…

如何利用内链策略提升网站的整体权重?

内链是谷歌SEO中常常被低估的部分&#xff0c;实际上&#xff0c;合理的内链策略不仅能帮助提升页面间的关联性&#xff0c;还可以增强网站的整体权重。通过正确的内链布局&#xff0c;用户可以更流畅地浏览你的网站&#xff0c;谷歌爬虫也能更快地抓取到更多页面&#xff0c;有…

工业—使用Flink处理Kafka中的数据_ChangeRecord2

使用 Flink 消费 Kafka 中 ChangeRecord 主题的数据&#xff0c;每隔 1 分钟输出最近 3 分钟的预警次数最多的 设备&#xff0c;将结果存入Redis 中&#xff0c; key 值为 “warning_last3min_everymin_out” &#xff0c; value 值为 “ 窗口结束时间&#xff0c;设备id” &am…

汇编语言学习-二

好吧&#xff0c;已经隔了两天&#xff0c;下完班看了两天&#xff0c;在电脑上装了虚拟机版的MS_DOS,主要是怕折腾坏我的电脑系统&#xff1b; 这个第二天应该是称为第二章更为合适&#xff0c;目前第二章已经看完&#xff0c;基本的命令也是敲了敲&#xff1b; 下面就进行一…

等差数列末项计算

等差数列末项计算 C语言代码C 代码Java代码Python代码 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; 给出一个等差数列的前两项a1&#xff0c;a2&#xff0c;求第n项是多少。 输入 一行&#xff0c;包含三个整数a1&#xff0c;a2&#x…