详解Linux下系统权限
ahcoder 2025-01-02 14:02 8 浏览
一、权限概述
1. 什么是权限
权限:在计算机系统中,权限是指某个计算机用户具有使用软件资源的权利。
软件资源:Linux系统中,一切皆文件!SO,这里的软件资源就是文件资源。
所以,我们今天所讲的权限,指的就是:文件资源所拥有的相关权限,即文件权限。
2. 权限设置目的
文件权限的设置目的:是想让某个用户有权利操作文件.
3. 文件权限的分类
㈠ 普通权限
用户正常情况去操作文件所具有的权限
㈡ 高级权限
用户对某个文件操作有特殊需求,而普通权限不能满足,需要给文件设置高级权限
㈢ 默认权限
用户在系统中创建一个文件,该文件默认都会有一个权限,该权限是默认有的
时刻谨记:
权限是设置在文件上的,目的是让某个用户拥有操作文件的权利。
二、普通权限
1. 理解普通权限rwx含义
㈠ 读权限—r(read)
- 针对目录
一个目录拥有r权限,说明可以查看该目录里的内容,如(ls命令列出)
- 针对普通文件
一个普通文件拥有r权限,说明可以查看该文件的内容,如(cat/head/tail/less/more等命令查看)
- 读权限r(read)用数字表示是4
㈡ 写权限—w(write)
- 针对目录
一个目录拥有w权限,说明可以在该目录里创建、删除、重命名等操作(mkdir/touch/mv/rm等)
- 针对普通文件
一个普通文件拥有w权限,说明可以修改该文件的内容(vi/vim编辑器编辑文件)
- 写权限w(write)用数字表示是2
㈢ 执行权限—x(execute)
- 针对目录
一个目录拥有x权限,说明可以进入或切换到该目录里(cd命令)
- 针对普通文件
一个普通文件拥有x权限,说明可以执行该文件(一般程序文件、脚本文件、命令都需要执行权限)
- 执行权限x(execute)用数字表示是1
㈣ 没有权限—横杠-
没有任何权限用横杠-表示,数字表示是0
2. 理解UGO的含义
㈠ UGO指的是什么
UGO,指的是用户身份,每个字母代表不同的用户身份。
- U(the user who owns it)
文件的拥有者(owner)或者创建者
- G(other users in the file’s group)
在文件的所属组(默认是创建文件的用户的主组)里的用户
- O(other users not in the file’s group)
既不是文件的创建者,也不在文件属组里的用户,称为其他人
注意:
除了上面ugo以外,还有一个字母a(all users),表示所有用户。
㈡ 如何判断不同身份的用户对文件的权限
3. 修改文件的普通权限
㈠ 通过字母形式更改权限
㈡ 通过数字形式更改权限
4. 总结
- 用户是否可以删除目录里的文件,看的是目录的权限!!!
- 对于正常能够操作的目录来说,应该默认具备r-x。
三、高级权限
1. 高级权限有哪些
㈠ 冒险位(SETUID)
- 冒险位,指文件操作者(用户)临时拥有文件拥有者的权限
- 冒险位,一般针对的是命令或者脚本文件
- 冒险位,用字母表示是s或S;数字表示是4
- 冒险位的设置:chmod u+s 文件名或者chmod 4xxx 文件名
㈡ 强制位(SETGID)
- 强制位,一般针对的是目录
如果一个目录拥有强制位,那么任何用户在该目录里所创建的任何文件的属组都会继承该目录的属组。
- 强制位,用字母表示是s或S;数字表示是2
- 强制位的设置:chmod g+s 文件名或者chmod 2xxx 文件名
㈢ 粘滞位(STICKY)
- 粘滞位,一般针对的是公共目录
如果一个公共目录拥有粘滞位,那么该目录下的文件,只有root和文件的创建者可以删除,其他人只能自己管理自己。(A用户不能删除B用户创建的文件)
- 粘滞位,用字母表示是t或T;数字表示是1
- 粘滞位的设置:chmod o+t 文件名或者chmod 1xxx 文件名
2. 高级权限设置
㈠ 冒险位举例
需求:
给一个vim命令设置冒险位,目的是任何人拿vim去修改文件可以临时获得文件拥有者的权限
㈡ 强制位举例
需求:
给dir2设置一个强制位,测试是否任何人在该目录里创建的文件属组都是该目录的属组。
㈢ 粘滞位举例
需求:
在创建一个公共目录/tmp/dir3,要求所有人都可以在该公共目录里创建、删除文件;但是只能自己管理自己,不能删除别人的文件
四、默认权限
1. 什么是默认权限
所谓文件的默认权限(遮罩权限),是指用户创建文件后,文件天生就有的权限,不需要设置。
2. 文件默认权限由谁来控制
文件默认权限由一个叫做umask的东西来控制。
3. umask如何控制文件默认权限
㈠ 临时控制
- 临时控制,指的是用命令umask临时设置,只在当前终端当前进程中生效。
- 如何通过umask计算文件的默认权限?
Linux系统中,默认创建目录的最大权限是0777;文件的最大权限是0666
umask=文件的最大权限-文件的默认权限
- 临时设置用户的umask
[root@localhost ~]# umask 0007
- 计算用户的默认权限
㈡ 永久控制
永久设置,指的是通过修改配置文件设置,对用户的所有终端所有进程生效。
① 针对所有用户生效
② 针对某个用户生效
五、总结
对于运维工程师来说,掌握Linux系统权限是必备的技能,除了以上介绍的普通权限、高级权限、默认权限外,如果需要更加细致的控制用户对文件的权限,还可以通过ACL策略来控制。
相关推荐
- ARM64内核内存布局图(ARM64内核内存布局图解)
-
ARM64架构处理器采用48位物理寻址机制,最大可以寻找到256TB的物理地址空间。对于目前的应用来说已经足够了,不需要扩展到64位的物理地址寻址。虚拟地址也同样最大支持48位支持,所以在处理器的架构...
- ARM64 linux 调试串口通信(ARM64 linux 调试串口通信实验报告)
-
ARM64linux调试串口通信随着国产机普及很多工作也转移到了新平台上,以前调试设备用的笔记本电脑也换成新国产ARM64架构的了。本文以绿联CM204USB-A转RJ45Console调试线...
- Gentoo Linux 终止对 Itanium IA-64 体系的支持
-
GentooLinux是最后几个继续维护Itanium(IA-64)架构构建的Linux发行版之一,但现在这些已停产的英特尔处理器正在逐步淘汰。由于Linux6.7内核放弃了对Itan...
- 如何检查 Linux 系统是 32 位还是 64 位?这9个命令查的又快又准!
-
在Linux系统中,位数(bit)通常指的是CPU架构的位宽,即CPU一次能够处理的数据量。32位系统和64位系统在内存寻址能力、计算性能和软件支持上存在显著差异:「32位系统」:...
- 调出好画面!带你玩转飞凌嵌入式AM62x开发板的显示接口
-
来源:飞凌嵌入式官网“显示”是嵌入式开发板最为重要的功能之一,能够支持更多种类、更高规格的显示接口,意味着它能够应对的使用场景也更加广泛。每一款嵌入式开发板在出厂前都会做屏幕调试,但在客户的实际项目开...
- 带你玩转AM62x开发板的显示接口——LVDS的显示和修改方式
-
此前小编已为大家介绍过OK6254-C开发板的RGB显示和修改方式,今天将继续为大家介绍OK6254-C开发板的LVDS显示和修改方式。话不多说,我们进入正题。1、LVDS接口规格飞凌嵌入式OK62...
- AM335x继任者?AM6254性能解析(am2361p)
-
飞凌嵌入式FET6254-C核心板基于TISitaraTMAM62x系列工业级处理器设计开发,采用ARMCortex-A53架构,主频最高可达1.4GHz;并集成了丰富的接口,可广泛应用于的工...
- 如何在 Linux 发行版中安装微信和 QQ?
-
很多人因为工作沟通的原因需要用到微信和QQ,那么如何在Linux发行版中安装微信和QQ呢?以下是一些尝试的解决方法。QQ上一个版本的QQLinux版还是在2009年,而在现在,基于N...
- MySQL:物理备份工具XBK(mysql 备份方案)
-
XBK的优缺点:XBK(PerconaXtraBackup)优点:1.免费2.热备:备份期间不阻塞innodb和XtraDB表,但会阻塞Myisam表3.物理备份:备份恢复快XBK缺点:1.不支持远...
- AMD锐龙9 9950X CPU AIDA64跑分曝光:比7950X最高快45%
-
IT之家6月26日消息,Anandtech论坛网友igor_kavinski本周一发布帖子,分享了AMD旗舰锐龙99950X处理器的AIDA64基准测试跑分,与当前基于Z...
- qemu linux内核(5.10.209)开发环境搭建
-
版本信息宿主机:ubuntu20.04.6LTS(FocalFossa)虚拟机:ubuntu20.04.6LTS(FocalFossa)安装宿主机的步骤省略,和一般的在vmware中安...
- iPhone 7成刷机神器,成功运行乌班图、Linux、安卓
-
在智能机刚开始流行的时候,很多手机发烧友都喜欢刷机,当时民间大神们制作了特别多优化的ROM。后来随着手机硬件的逐步提升,以及厂商们对系统的大力优化,让大家对于刷机的兴趣也越来越少。不知道大家还记得这部...
- 12 款最佳免费开源 Linux 渲染器 | 火狐浏览器 130.0 版本更新
-
12款最佳免费开源Linux渲染器Linux的一大优势在于其拥有丰富的开源软件,可以满足艺术家、摄影师、动画师和设计师的需求。凭借价格低廉的硬件、免费的软件以及少量的才能和灵感,任何人都可以创...
- Linux中xargs 命令详解与实用场景
-
xargs是Linux系统中常用的命令行工具之一,它能够从标准输入构造参数列表并传递给其他命令使用,是处理批量数据操作时的重要利器。一、xargs的基本语法xargs[OPTION]...[C...
- Linux 磁盘扩容(非LVM)方式(linux扩容lvm磁盘容量)
-
今天接到一个客户的需求,CentOS的/分区容量太小了,OA系统所有的数据都在这下面,由于当时前同事给客户安装系统时采用了标准分区,而不是LVM逻辑卷,所以不支持在线扩容。df-hT查看磁盘使...
- 一周热门
- 最近发表
-
- ARM64内核内存布局图(ARM64内核内存布局图解)
- ARM64 linux 调试串口通信(ARM64 linux 调试串口通信实验报告)
- Gentoo Linux 终止对 Itanium IA-64 体系的支持
- 如何检查 Linux 系统是 32 位还是 64 位?这9个命令查的又快又准!
- 调出好画面!带你玩转飞凌嵌入式AM62x开发板的显示接口
- 带你玩转AM62x开发板的显示接口——LVDS的显示和修改方式
- AM335x继任者?AM6254性能解析(am2361p)
- 如何在 Linux 发行版中安装微信和 QQ?
- MySQL:物理备份工具XBK(mysql 备份方案)
- AMD锐龙9 9950X CPU AIDA64跑分曝光:比7950X最高快45%
- 标签列表
-
- linux 远程 (37)
- u盘 linux (32)
- linux 登录 (34)
- linux 路径 (33)
- linux 文件命令 (35)
- linux 是什么 (35)
- linux 界面 (34)
- 查看文件 linux (35)
- linux 语言 (33)
- linux代码 (32)
- linux 查看命令 (33)
- 关闭linux (34)
- root linux (33)
- 删除文件 linux (35)
- linux 主机 (34)
- linux与 (33)
- linux 函数 (35)
- linux .ssh (35)
- cpu linux (35)
- 查看linux 系统 (32)
- linux 防火墙 (33)
- linux 手机 (32)
- linux 镜像 (34)
- linux mac (32)
- linux ip地址 (34)