Linux基本权限(2)

Linux基本权限(2)

📟作者主页:慢热的陕西人

🌴专栏链接:Linux

📣欢迎各位大佬👍点赞🔥关注🚓收藏,🍉留言

本博客主要讲解了目录权限,和目录,文件的默认权限和他们是怎么生成的,还有粘滞位,umask(掩码)进行权限的收尾

1.目录的权限:

对于目录和文件是类似的也有权限的限制:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-h2K8XBj1-1671266825262)(C:\Users\jason\AppData\Roaming\Typora\typora-user-images\image-20221216203249546.png)]

  • x可执行权限: 如果目录没有可执行权限, 则无法 cd 到目录中

  • r可读权限: 如果目录没有可读权限, 则无法用ls等命令查看目录中的文件内容.

  • w可写权限: 如果目录没有可写权限, 则无法在目录中创建文件, 也无法在目录中删除文件

2.默认权限:

起始权限:系统设定的

默认(最终)权限:我们所看到的

首先我们创建一个文件和一个目录,并观察他们的权限属性:

[root@iZ2ze8prly56kg8in4hqa2Z dir]# ll
total 0
drwxrwxr-x 2 root root 6 Dec 17 12:49 new_dir
-rw-rw-r-- 1 root root 0 Dec 17 12:49 test.txt

为什么普通文件的默认的权限是从664开始的?

为什么目录的默认权限是775开始的?

不同的操作系统默认的权限可能是不同的;

在这里插入图片描述

普通文件的起始权限是从666开始的;

目录文件的起始权限是从777开始的;

2.1 umask掩码:

系统为了更好的控制文件权限,系统会有默认的权限掩码的概念!umask

前面提到每个操作系统的默认权限都是不同的这就是由umask决定的(因为我们的默认权限是由初始权限和umask进行如上图的位运算的得到的),那么我们如何查看我们的umask权限掩码是多少呢?

再Linux命令行中输入umask即可;

[root@iZ2ze8prly56kg8in4hqa2Z dir]# umask
0002

这里的0002是什么意思:

第一个0表示八进制位;

剩下的三个数字分别对应文件权限属性中的三个权限:

所属者权限,所属组权限还有other权限;

运算过程(以目录为例):

在这里插入图片描述

最终的结果转化成八进制就是 775,这也回答了上面的两个问题为什么文件默认是664, 目录是775;

2.2修改umask:

语法: umask 八进制数(例如 0002)

演示:

[root@iZ2ze8prly56kg8in4hqa2Z dir]# umask 0003
[root@iZ2ze8prly56kg8in4hqa2Z dir]# umask
0003
[root@iZ2ze8prly56kg8in4hqa2Z dir]# umask 0002
[root@iZ2ze8prly56kg8in4hqa2Z dir]# umask
0002

3.粘滞位:

背景: 在使用Linux的时候,未来可能会有一些共享目录,被所有的普通用户共享,用来保存普通用户产生的临时数据;

准备:共享的目录通常的都是root提供的,文件被所有的人共享的时候,受权限约束,但是拦不住别人删我的文件(即使是other没有rwx权限也可以删除)!!

为了让大家共享文件,并且不让其他人随便删除别人的文件,引入粘滞位

粘滞位只能给目录添加;

创建共享文件:

[root@iZ2ze8prly56kg8in4hqa2Z dir]# mkdir public
[root@iZ2ze8prly56kg8in4hqa2Z dir]# ll
total 0
drwxrwxr-x 2 root root 6 Dec 17 12:49 new_dir
drwxrwxr-x 2 root root 6 Dec 17 15:59 public
-rw-rw-r-- 1 root root 0 Dec 17 12:49 test.txt
[root@iZ2ze8prly56kg8in4hqa2Z dir]# chmod 777 public
[root@iZ2ze8prly56kg8in4hqa2Z public]# touch root1
[root@iZ2ze8prly56kg8in4hqa2Z public]# touch root2
[root@iZ2ze8prly56kg8in4hqa2Z public]# touch root3

尝试删除:

[root@iZ2ze8prly56kg8in4hqa2Z public]# ll
total 0
-rw-r--r-- 1 root root 0 Dec 17 16:21 root1
-rw-rw-r-- 1 root root 0 Dec 17 16:08 root2
-rw-rw-r-- 1 root root 0 Dec 17 16:09 root3
[root@iZ2ze8prly56kg8in4hqa2Z public]# rm root1
rm: remove regular empty file 'root1'? y
[root@iZ2ze8prly56kg8in4hqa2Z public]# ll
total 0
-rw-rw-r-- 1 root root 0 Dec 17 16:08 root2
-rw-rw-r-- 1 root root 0 Dec 17 16:09 root3

我们发现用普通用户是可以删除的;

3.1 如何添加粘滞位:

语法:chmod +t public

[root@iZ2ze8prly56kg8in4hqa2Z dir]# chmod +t public
[root@iZ2ze8prly56kg8in4hqa2Z dir]# ll
total 0
drwxrwxr-x 2 root root  6 Dec 17 12:49 new_dir
drwxrwxrwt 2 root root 45 Dec 17 16:09 public
-rw-rw-r-- 1 root root  0 Dec 17 12:49 test.txt

这时候我们使用普通用户尝试去删除public中的文件的时候是不能删除的:

[root@iZ2ze8prly56kg8in4hqa2Z public]# su mi
[mi@iZ2ze8prly56kg8in4hqa2Z public]$ rm root1
rm: remove write-protected regular empty file 'root1'? y
rm: cannot remove 'root1': Operation not permitted

3.2添加粘滞位之后的效果:

前面我们提到如果other没有没有w权限的话,那么我们就不能删除文件了,但是我们也不能在public目录中创建文件了。

所以我们给public添加粘滞位后的效果:

①每个普通用户都可以在public目录中任意的添加文件;

②那么谁能删除文件呢?

(1)root

(2)文件的所属者

(3)该目录的所属者


到这本篇博客的内容就到此结束了,至此Linux权限的部分也就学习结束了,接下来会进入Linux工具的学习,为后序的在Linux上进行开发做铺垫。
如果觉得本篇博客内容对你有所帮助的话,可以点赞,收藏,顺便关注一下!
如果文章内容有错误,欢迎在评论区指正

在这里插入图片描述

  • 7
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 8
    评论
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小米睡不醒.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值