【Linux】Linux权限管理 —— shell运行原理 | 权限 | 目录权限 | 粘滞位 | 权限掩码umask

简介: Linux权限管理

在这里插入图片描述
正文开始@小边小边不秃头

1. shell命令以及运行原理

Linux严格意义上说的是一个操作系统,我们称之为“核心(kernel)“ ,但我们普通用户,无法直接使用kernel。而是通过kernel的“外壳”程序,也就是所谓的shell,来与kernel沟通。如何理解?为什么不能直接使用kernel?这是因为内核使用成本高,且有权限约束问题。

从技术角度,Shell的最简单定义 —— :yellow_heart: 命令行解释器(command Interpreter)主要包含:

  • [ ] 将使用者的命令翻译给核心(kernel)处理。
  • [ ] 同时,将核心的处理结果翻译给使用者。

下面我们通过一个故事感性认识一下shell

part one 苦情男初表心意

如果说你是一个闷骚且害羞的程序员,那shell就像媒婆,操作系统内核就是你们村头漂亮的心动女嘉宾小花。

你看上了小花,但是又不好意思直接表白,就让你家人(你爸是村长)找媒婆帮你提亲,所有的事情你都直接跟媒婆沟通,由媒婆转达你的意思给小花。:yellow_heart: shell 可以传递请求命令,让OS执行命令

<img src=" title="">

可是小花根本就不喜欢你,给你发了张好人卡,说啊,这小伙子人挺好,就是不是我的type,而且我已经有男嘉宾了。

这就相当于 ——

<img src=" title="">

part two 梅开二度

可是呢,你还是很喜欢小花,觉得啊,那男生哪有我有魅力?!于是你又去找媒婆。但是对于非法请求,媒婆是有权利拒绝的,这时媒婆让您滚。

<img src=" title="">

这其实就是保护了小花,让她免受打扰。:yellow_heart: shell可以保护内核。

part three 死缠烂打

可是呢,你真是太喜欢小花了,你虽然是理工男,但这幻想中的乐观,是你内向的浪漫(我去!我边通书写小说去得了),你说,我欲与君相知,长命无绝衰。山无棱,江水为竭,冬雷震震,夏雨雪,天地合,乃敢与君绝!(小边借博文默默提升你们表白水准呢啊!)媒婆碍于你爸是村长的态势,勉强答应,把事情交给实习生做,反正做不好也不关我媒婆的事儿。

<img src=" title="">

男生不要死缠烂打哦,真的特丢人,你以为只有你们两个人知道的事很可能她的闺蜜室友同学辅导员全都知道了哈哈(我可没夸张呢,工大女生八卦属性不变呢)。

而我们找到媒婆姓王,所以我们叫它王婆,它对应我们常使用的bash。

<img src=" title="">

:yellow_heart: 显示系统内所有进程

ps axj | grep bash

2. Linux权限管理

2.1 权限相关概念

2.1.1 用户分类

:green_heart: 1. 超级用户(root) —— 具有非常高的权限

:green_heart: 2. 普通用户 —— 权限受约束

注:这两套密码绝对要不一样,否则会产生权限界限不清的状况

2.1.2 如何用户切换

:yellow_heart: 1. 普通用户切换为root

su - 

<img src=" title="">

或者

su

它们的区别在于切回来su -会变成家路径再往下切会比较麻烦,而su还是当前路径。

<img src=" title="">

:yellow_heart: 2. root切换为普通用户

su - bts   以bts为例

<img src=" title="">

说明root可以变成任何人,且不需要输密码root权限真的很大,一定要保管好它的密码,并且尽量设的复杂。

:yellow_heart: 注意,关于回退。此时我们想从bts再切回root直接exit或者[ctrl + d]。

<img src=" title="">

不建议su - ,因为这样会重新创建bash ——

<img src=" title="">

2.2 权限的两要素

什么是权限?即一件事情,是否允许被特定的人做。比如校长办公室是可以进的,但是一般情况下你不能进,但是呢如果你到夏季小学期到行政楼门口光膀子打地铺你就会被请进去喝茶水;面包能吃,但是毛概书不能吃,所以你可以吃面包,不能吃毛概书。这里都包含了两个要素。

:yellow_heart:那放到这里,权限约束的是,文件本身具有天然的权限属性(读r写w执行x)。即,权限 = 人 + 事物。

下面的有关权限的操作将围绕着两个基本点展开。

:purple_heart:我们基本操作指令中,llls -l可以显示文件更多属性,这些属性是什么呢?

<img src=" title="">

来吧!

2.2.1 人

:yellow_heart: Linux下的用户类别

  1. 拥有者owner
  2. 所属组group
  3. 其他人other

上文所提到的用户分类于此并不矛盾,超级用户和普通用户是具体的人,而拥有者所需组其他人,是他们扮演的角色。

<img src=" title="">

我们不需要单独的other列表,因为有了拥有者和所属组,其他人自然就被排除在外了。

:这里所属组的存在是有它的意义的,比如一个部门有两个项目组在竞争性完成一个项目,我写的绝妙代码,我想让自己能看见,同组人能看见,别人看不见。

<img src=" title="">

2.2.2 事物属性

<img src=" title="">

:yellow_heart: 1. 属性第一列 —— 标识文件类型

在Linux系统中,不以文件后缀区分文件类型,也就是说文件类型与后缀没有直接关系。

Linux下一切皆文件,文件类型 ——

d    目录文件
-    普通文件(各种动静态库,可执行程序,源程序)
—————————————————下面只做了解————————————————————————
l    软链接link(类似Windows的快捷方式)
b    块设备文件bar(例如硬盘、光驱等)
p    管道文件pile
c    字符设备文件(例如键盘显示器等串口设备)[后序会站在系统角度重新理解]
s    套接口文件

:yellow_heart: 2. 接下来的9个字符

三三为一组,分别对应拥有者、所属组、其他人;三个字母分别对应文件属性,读r、写w、执行x。每个字母都具有两态概念,即是否其具有读权限、是否具有写权限、是否具有可执行权限。

描述下面这个文件权限,即是对于owner可读可写可执行,对于所属组可读可写可执行,对于其他人可读不可写可执行。

-rwxrwxr-x 1 bts bts 8360 Jan 24 17:25 a.out

3. 权限相关指令

3.1 文件的权限

:purple_heart:在此之前我们先来说明su - sudo的区别

:yellow_heart: 1. 身份直接变为root

su - 或  su     

:yellow_heart: 2. 临时权限提升,执行后续命令,以root身份执行

sudo touch root.txt

sudo是Linux系统管理指令,是允许系统管理员让普通用户执行一些或者全部的root命令的一个工具,如halt,reboot,su等等。这样不仅减少了root用户的登录和管理时间,同样也提高了安全性。

:因为我还没配置,所以暂时不能用sudo,在下一篇文章vim中,我会更新这里。在此暂时直接切回root身份演示,配置好之后快速上手sudo即可。

<img src=" title="">

3.1.1 修改读写执行属性

3.1.1.1 chmod指令

:yellow_heart: 修改文件读写执行权限

chmod u+w file.c

chmod 用户表示符+/-权限字符 文件名

用户表示符

u     拥有者 
g    所属组,拥有着同组人
o    其他人
a      所有用户

我们可以更改一个人的一个权限、

<img src=" title="">

一个人的多个权限、

<img src=" title="">

多个人的一个权限、多个人的多个权限,也可以批量化更改多个文件。

<img src=" title="">

:修改不是自己的文件需要sudo临时权限提升或者直接切成root身份。

sodu chmod 用户表示符+/-权限字符 文件名

接下来我们探索两个小问题 ——

:blue_heart: 1. 普通文件被约束权限的状况

<img src=" title="">

:blue_heart: 2. root受到权限约束吗?

  • [ ] root 竟然不经过我bts的允许,直接把读写权限都干掉了,修改了我的权限属性。

在这里插入图片描述

  • [ ] 此时root作为这个文件的other,即便不具有读写属性,却竟然还能读和写。

<img src=" title="">
但对于执行照样受约束,这是因为一些可执行程序的权限需要被强约束起来

<img src=" title="">

:yellow_heart:结论:root这个人几乎不受权限约束,权限是用来约束普通人的。

3.1.2 修改所有者所属组

3.1.2.1 chown指令

:yellow_heart: 更改文件拥有者

chown [参数] newUser filename

更改是需要得到别人的允许的,一般直接更改不行的。

<img src=" title="">
这是符合常理的,现实中你给别人东西也是要经过别人同意的。比如说你表白一姑娘送给她一只熊:bear:,她完全可以不收啊,虽然你白买了很伤心,但是教你一招,可以假装要系鞋带,跟她说你帮我拿一下,然后你转头就跑,真聪明,哎。哈哈扯远了回来~

:purple_heart: 这时我们可以sodu进行临时的权限提升或者直接切成root身份

sudo chown root file.txt  或  su

目前我直接切回root身份
<img src=" title="">
可以看到切到root身份/临时提升为root,也不需要什么别人的允许,就可以kind of为所欲为了

<img src=" title="">

3.1.2.2 chgrp指令

:yellow_heart: 更改文件或目录所属组

sudo chgrp newGrp filename 

或直接切换为root身份 ——
<img src=" title="">
也可以带选项递归修改目录所属组

sudo -R chgrp newGrp filename

我自己都验了哈,结果不贴了。

:yellow_heart: 可以带选项同时更改拥有者所属组

sudo chown -R newUser:newGrp filename

或者直接切换为root身份 ——

<img src=" title="">

3.2 目录的权限

3.2.1 目录权限(重要)

  • [ ] 可权限:如果目录没有可读权限,无法用ls相关命令查看目录
  • [ ] 可权限:如果目录没有可写权限,无法在目录中创建文件/删除文件(这是因为在目录下创建新目录/文件,本质都是在路径树中,新增路径/节点)

<img src=" title="">
这都是显而易见的,那么进入目录需要什么权限?【面试题】

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

<img src=" title="">

比较有趣的是当这个目录可读可写不可进入时,此时查看目录,你确实能看到但最多也就是看看文件名,其它属性都是乱码。这是可以理解的,你要查看详细属性,要先进入目录。

<img src=" title="">

3.2.2 粘滞位(重要)

3.2.2.1 引入

我们建立了一个目录test把权限设置为完全公开。
<img src=" title="">
在其中touch了几个拥有者为root的文件,把权限设置为对other不可写不可读。
<img src=" title="">
现在我以普通用户bts的身份,对于上述文件我属于other其他人。这些文件呢,你能看到,你不想让我看,我呢,确实也看不到。那好嘞,您也别看了,我给你干掉!
在这里插入图片描述
我竟然就真的干掉了!!

这是因为你目录本身就是对我bts就是可写的,我可以删自己的也可以删别人的。如果我们去掉目录的写[w]权限,那就确实删不掉了 ——

<img src=" title="">

:yellow_heart:以上我们可以看到,如果目录本身other[w]权限,other可以删掉任何目录下的文件;反之,如果目录本身对other没有[w]权限,other不能删掉任何文件。这并不科学

3.2.2.2 粘滞位

:purple_heart: 现在我有这样的需求,其他人other可以在特定的目录下创建文件(有写权限),并写入(文件本身属性);但是不想让任何人删除我的文件(没有写权限),这本身是矛盾的。这就需要引入了粘滞位。【面试题】

chmod o+t dir   

<img src=" title="">
这就保证了别人可以在这个目录下创建文件;可以删,但是只能删自己的,不能删别人的。

<img src=" title="">

:yellow_heart: 1. 粘滞位只能对目录设置(一般是对other)

:yellow_heart: 2. 对于设置了粘滞位的目录,只有文件的拥有者或root可以删除,其他人不能删除。

:green_heart: 这样的场景是存在的,Linux下就有这样一个目录用于存储临时文件
<img src=" title="">
有时,有多个人或者系统会有很多的临时数据,所有的临时文件都放在系统的/tmp目录下。所有的权限需要放开,但是只想让文件的拥有者删除自己的文件,这需要设置粘滞位。

3.3 默认权限

3.3.1 文件权限值八进制方案

上文提到,每一个权限位都是确定的且是两态概念。因此我们可以采用八进制方案表述权限

<img src=" title="">

我们就可以这样修改文件读写执行相关属性了 ——

<img src=" title="">

3.3.2 权限掩码

思考:为什么系统中的文件,创建出来的默认权限是这样?

默认权限 = 起始权限 + 权限掩码

:yellow_heart: 1. 起始权限

  • [ ] 普通文件666
  • [ ] 目录文件777

这样的起始值,是有一定道理的。

:yellow_heart: 2. 权限掩码

但是你创建的文件和目录,看到的权限往往不是上面的这个值,这是因为还受到权限掩码的影响。

所谓掩码umask掩码中为1的位,都应该在起始权限中去掉。

超级用户默认掩码值为0022(第一个0表示八进制),即000 010 010;普通用户默认掩码值为0002,即000 000 010.

于是 ——

rw-rw-rw-  666
110110110  initial 起始权限
000000010   umask  权限掩码
————————————————————————————
110110100  default 默认权限
rw-rw-r--  664

可以总结出这样的运算公式

default = default & (~umask)

在八进制中直接对应位做减法可快速计算。

也可以自定义权限掩码 ——

umask 0333     对所有人只保留写权限

<img src=" title="">

订制的权限只在本次登陆有效。要想全局有效,要改配置文件,但是您不要改。

持续更新@边通书

相关文章
|
2月前
|
Linux 数据安全/隐私保护
linux特殊权限!!
本文介绍了Linux系统中的特殊权限,包括suid、sgid和sbit。suid使普通用户在执行特定命令时获得root权限;sgid使用户在创建文件时继承目录的用户组权限;sbit确保用户只能删除自己在共享目录中创建的文件。此外,文章还讲解了chattr和lsattr命令,用于更改和查看文件的扩展属性,以及umask的概念和计算方法,帮助理解文件和目录的默认权限。
74 1
linux特殊权限!!
|
3月前
|
Linux 应用服务中间件 nginx
Linux下权限设置之suid、sgid、sticky
Linux下权限设置之suid、sgid、sticky
|
3月前
|
Linux 数据安全/隐私保护 Windows
Linux_权限理解(详细PLUS
Linux_权限理解(详细PLUS
|
3月前
|
网络协议 Linux 网络安全
【Linux】用户和权限及实用操作------迅速了解用户和权限及其实用操作
【Linux】用户和权限及实用操作------迅速了解用户和权限及其实用操作
|
2月前
|
Linux 网络安全 数据安全/隐私保护
Linux 超级强大的十六进制 dump 工具:XXD 命令,我教你应该如何使用!
在 Linux 系统中,xxd 命令是一个强大的十六进制 dump 工具,可以将文件或数据以十六进制和 ASCII 字符形式显示,帮助用户深入了解和分析数据。本文详细介绍了 xxd 命令的基本用法、高级功能及实际应用案例,包括查看文件内容、指定输出格式、写入文件、数据比较、数据提取、数据转换和数据加密解密等。通过掌握这些技巧,用户可以更高效地处理各种数据问题。
238 8
|
2月前
|
监控 Linux
如何检查 Linux 内存使用量是否耗尽?这 5 个命令堪称绝了!
本文介绍了在Linux系统中检查内存使用情况的5个常用命令:`free`、`top`、`vmstat`、`pidstat` 和 `/proc/meminfo` 文件,帮助用户准确监控内存状态,确保系统稳定运行。
938 6
|
2月前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
148 3
|
2月前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
124 2
|
1月前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
84 14
Linux 10 个“who”命令示例
|
1月前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
157 20