Linux权限及其理解

文章介绍了Linux系统的权限管理机制,包括用户分类如超级用户和普通用户,如何切换用户,提升命令权限。详细讲解了文件的访问者分类、文件类型和权限表示,如读、写、执行权限,并展示了如何使用chmod命令设置文件权限。此外,还提到了umask在设定默认权限中的作用,以及目录权限中的粘滞位概念,用于防止非所有者删除目录中的文件。
摘要由CSDN通过智能技术生成

Linux权限的概念

与其它系统相比,Linux 系统的优点中最主要的一个便是 Linux 系统的安全漏洞和被攻击的隐患更少。Linux 无疑为用户提供了更灵活和精细化的文件系统安全权限控制。在 Linux 服务器中有严格的权限等级,若权限过高导致误操作会增加服务器的风险。所以了解 Linux 系统中的各种权限,以及如何给用户、服务等分配合理的权限是非常重要的!

在 Linux 系统下有两种用户:超级用户(root),普通用户。 超级用户(上帝视角)可以在 Linux 下执行任何操作,不会受到权限的限制。普通用户一般只能在自己的工作目录下操作,能在 Linux 系统中执行的操作是有限的。超级用户的命令提示符是"#“,普通用户的命令提示符是”$"。

在这里插入图片描述

❓如何实现用户账号之间的切换?

命令: su [用户名]
功能: 切换用户。root 用户切换到普通用户 user,使用 su user。从普通用户 user 切换到 root 用户,使用 su root(root可省略),此时系统提示输入 root 用户的密码。

在这里插入图片描述
该指令也可以从一个普通的用户切换为另外一个普通用户,输入待切换的用户账号密码即可。
切换用户后,可以通过 exit 或者 logout 进行退出当前用户,也可以用 Ctrl+D 切回上一次的用户。

❓如何提升当前指令的权限

在一些情况下,想要提升普通用户的指令的权限并不需要都切换到 root 下。

例如:在当前云服务器下,以一名普通用户的身份去修改另外一个普通用户的密码。但是当你输入密码后系统提示你没有被添加到信任列表,因此无法执行该命令。
在这里插入图片描述

❓怎样将普通用户添加到信任列表

首先切换到超级用户 root ,因为 root 才有权限将普通用户添加到信任列表。然后在 root 下执行以下操作:
在这里插入图片描述

执行完上述操作之后,再用该用户执行 sudo 命令,该用户就拥有了执行该指令的权限了。
在这里插入图片描述

Linux权限管理

文件访问者的分类(人)

  • 文件和文件目录的所有者:u(user),文件的拥有者。
  • 文件和文件目录的所有者和所在的组的用户,g(group),文件的所属组。
  • 其它用户:o(other),其他人。

输入 ll 指令可以查看文件的属性,可以看到文件的拥有者和所属组,除两者之外的都是 other。

在这里插入图片描述

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

文件由读、写、执行三个权限约束。超级用户 root 不受其中的权限约束,权限约束都是对于普通用户而言的。

如下图所示,文件的前10个字符代表着文件的类型和权限。

在这里插入图片描述

上图中的10个字符分别代表什么含义呢?我们用 myfile.txt 来分析一下:

在这里插入图片描述

不同的字符代表着不同的文件类型:

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

注意:在 Linux 中,文件类型与文件后缀无关。第一个字符代表文件的类型,剩下的9个字符分为3组,分别代表文件相对于其拥有者、所属者、other 的权限。

其它内容所代表的含义如下所示:
在这里插入图片描述
基本权限:
r : read 对文件而言,具有读取文件内容的权限;而对目录来说,具有浏览该目录信息的权限。
w : wirte 对文件而言,具有修改文件内容的权限;而对目录而言,具有删除以及移动目录内文件的权限。
x : execute 对文件而言,具有执行文件的权限;而对目录而言,就有进入目录的权限。
- :表示不具有该权限。


❓如何去描述一个文件的类型以及权限呢?以下面为例:
在这里插入图片描述
myfile.txt 文件是一个普通文件,该文件对拥有者和所属者都是可读可写的,而对该文件的 other 用户只有可读的权限。


文件权限值的表示方法

文件的权限值表示法有字符表示法8进制数值表示法

Linux字符表示法二进制值八进制值说明
- - -0000无权限
r - -1004仅可读
- w -0102仅可写
- - x0011仅可执行
r w -1106可读可写
r - x1015可读可执行
- w x0113可写可执行
r w x1117可读可写可执行

在这里插入图片描述

文件访问权限的设置方法

更改文件权限的命令:chmod

语法格式:chmod 选项 权限 文件名
功能:设置文件的访问权限
常用选项:R -> 递归式的修改目录文件的权限
说明:只有文件的拥有者和 root 才能改变文件的权限

chmod 命令权限值得格式:

1️⃣用户表示符 +/-/= 权限字符
1.+ :向权限范围增加权限代号所表示的权限
2. - :向权限范围取消权限代号所表示的权限
3. =:向权限范围赋予权限代号所表示的所有权限

用户符号:

  • u — 拥有者
  • g — 所属者
  • o — 其他用户(other)
  • a — 所有用户

例如:将可执行程序 a.out 的拥有者的可执行权限减去,那么拥有者将没有可执行此程序的权限。

在这里插入图片描述

需要设置多个用户的权限时,可同时设置不同用户的权限,中间需要用逗号分开。

在这里插入图片描述

2️⃣三位8进制数

使用三位8进制数来表示文件的权限,将8进制数写成对应的二进制数,按照1对应有权限,0对应没有权限来对文件的权限进行相应的设置。
在这里插入图片描述

❓如何修改文件的拥有者和所属者?

chown
功能:修改文件的拥有者
语法:chowm 选项 用户名 文件名
常用选项: -R 递归修改目录文件的拥有者

修改文件的拥有者和所属者需要使用 root 来进行操作,普通用户修改需要提升权限,可以用 sudo 来进行提升权限。
在这里插入图片描述

chgrp
功能:修改文件或者目录的所属组
语法:chgrp 选项 所属组名 文件名
常用选项:-R 递归修改文件或者目录的所属者

在这里插入图片描述

权限掩码

当我们创建一个文件或者目录时,系统会根据其属性给出默认的权限。
在这里插入图片描述
为什么我们创建的目录或者文件权限会是这样的?实际上,新建文件的默认权限是 0666,新建目录的默认权限是 0777。第一位0代表特殊权限,后三位是权限的八进制数值表示方法。

但是我们会发现,我们新建的文件默认权限是664,新建的目录默认权限是775。是因为创建文件和目录时的默认权限还受 umask 的影响。假设默认权限是 mask,则实际创建出来得文件权限是:mask & ~umask。

umask
功能:查看或修改文件掩码。
语法:umask 权限值
说明:将现有的存取权限减去权限掩码之后,即可以产生建立文件时的预设权限。超级用户默认掩码值为0022,普通用户默认掩码值为0002。

可以通过输入 umask 命令来查看文件的默认掩码:
在这里插入图片描述
但是我们创建出的文件或目录的实际权限需要进行再次运算才能够得出来,先将权限掩码的后三位八进制写成对应的二进制数,并且按位取反,将新建文件的默认权限值和新建目录的默认权限值分别与其进行按位与操作,最终得到的二进制数所对应的权限就是我们创建出的文件或目录的权限。

假设默认权限是 mask,则实际创建出来得文件权限是:mask & ~umask。
在这里插入图片描述
上述也可以理解为在 umask 中出现的权限为,不能在最终的实际权限中出现。一些场景下,我们可以修改 umask 来设置文件或目录创建时的权限。
在这里插入图片描述

目录的权限

可读权限:若目录没有可读权限,则无法用 ls 等指令查看目录中的内容。
可写权限:若目录没有可写权限,则无法在目录中创建文件,也无法删除文件。
可执行权限:若目录没有可执行权限,则无法进入到目录中。

但是,问题出现了。即用户只要具有目录的写权限,用户就可以删除目录中的文件,而不论此用户是否具有这个文件的写权限,这显然是不科学的!

在 Linux 下存在一些目录,拥有者和所属组都是 root,允许其他人以 other 的身份在该目录下进行文件的创建、读取、删除、修改等操作。在一个共享目录下,不让别人读写你的文件,但是防不住别人删除你的文件。

为了解决这个问题,Linux 引入了粘滞位的概念。

粘滞位

粘滞位(Stickybit),或黏着位,是 Linux 文件系统权限的一个旗标。 最常见的用法是在目录上设置粘滞位,如此以来,只有目录内文件的所有者或者 root 才可以删除或移动该文件。若不为目录设置粘滞位,任何具有目录写和执行权限的用户都可以删除和移动其中的文件。在实际应用中,粘滞位通常用于 /tmp 目录,以防止普通用户删除或移动其它用户的文件。

功能: 给目录加上粘滞位。
语法: chmod +t 目录名

加上粘滞位之后,目录权限的最后一个字符变为 ‘t’ ,目录颜色也发生了改变。

在这里插入图片描述
当一个目录被设置为"粘滞位"(用 chmod +t),则该目录下的文件只能由:

  1. 超级管理员 root 删除
  2. 该目录的所有者删除
  3. 该文件的所有者删除

注意:增加粘滞位用 chmod +t 文件名,去掉粘滞位用 chmod -t 文件名

总结

  • 目录的可执行权限是表示你是否可以在目录下执行命令。
  • 若目录没有 -x 权限,则无法对目录执行任何命令,甚至无法 cd 进入目录,即使目录有 -r 权限。
  • 如果目录具有 -x 权限,但是没有 -r 权限,则用户可以执行命令,可以 cd 进入目录。但是没有目录的读权限,所以在目录下,即使可以执行 ls 指令,但是仍热没有权限读取目录下的文档。
评论 32
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

风&57

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值