【Linux】深入理解linux权限

🌟🌟作者主页:ephemerals__

🌟🌟所属专栏:Linux

目录

前言

一、权限是什么

二、用户和身份角色

三、文件属性

1. 文件属性表示

2. 文件类型

3. 文件的权限属性

四、修改文件的权限属性和角色

1. 修改权限属性

2. 修改文件角色

五、关于权限的三个问题

1. 目录的权限

2. 默认权限与实际权限

3. 删除权限与粘滞位

总结


前言

        在数字世界中,安全始终是最重要的基石,而Linux作为开源操作系统的璀璨明珠,其权限管理机制更是构筑安全防线的关键一环。本篇文章,我们将深入探讨Linux的权限体系,帮助你更好地掌控文件权限,构建更安全、可靠的工作环境。

一、权限是什么

        在Linux当中,权限指的是操作系统用于控制用户对文件或目录进行访问的机制,说白了,权限能决定用户能不能访问一个文件或目录,能以什么样的方式访问文件或目录。影响权限的因素:目标事物的属性和用户及其扮演的身份角色

二、用户和身份角色

        在Linux下,我们可以认为有两种用户:

1. root用户(超级用户) 几乎不受权限约束,可以任意访问文件或目录。

2. 普通用户Linux使用者,受权限约束。

创建用户:adduser [用户名]

设置密码:passwd [用户名]

切换用户: su [用户名]

切换到root用户:su

回退到之前用户:ctrl+Dexit

以root身份重新登录:su -

指令提权:sudo 指令

        注:指令提权本质是以root用户的身份执行命令

而“身份角色”是针对于具体事物,由用户所扮演的。身份角色有如下三种:

1. 文件拥有者(User,u)

2. 文件所属组(Group,g)

3. 其他人(Other,o)

 对于一个目录或文件而言,身份角色不同,它们所拥有的权限也不尽相同,其权限由文件属性和身份角色共同决定

三、文件属性

1. 文件属性表示

        使用 ls -l 指令显示文件信息,就可以看到文件属性

例如上图中的code文件,它的各项属性表示如下:

接下来,我们重点探讨一下文件类型以及权限属性。

2. 文件类型

文件类型

d:目录

-:普通文件

c:字符设备文件

b:块设备文件

p:管道文件

l:软链接文件

s:套接口文件

3. 文件的权限属性

         如上图所示,文件的权限属性针对三种角色可能有所不同,这就说明权限由文件属性和身份角色共同决定权限类型有三种:

r:可读--可以查看文件内容

w:可写--可以修改文件内容

x:可执行--可以运行

当权限属性的相应位置上有r/w/x时,表示该文件针对的角色具有读/写/执行该文件的权限,否则不具有相应权限。

以下两点需要注意:

对于root用户,无论其扮演的角色是否具有权限,其都可以进行相应操作。

一个文件可执行的两个必要条件:1. 文件具备可执行权限;2. 文件的类型是可执行程序。

        权限类型有字符表示方法八进制表示方法两种

当使用八进制表示方法表示权限属性时,一种角色的权限属性可以只用一位八进制数字表示,所以一个三位八进制数字就可以表示全部角色的权限属性(修改权限属性时方便使用)。 

注意:针对某个文件来讲,一个扮演多种角色的用户的权限按照角色优先级进行对应。

角色优先级:拥有者>所属组>其他人

举例:对于一个文件test.txt,拥有者的权限是r--,而所属组的权限是-x-,而一个用户既作为该角色的拥有者,也作为所属组时,其权限是r--(拥有者优先级较高,与拥有者权限相同)。

四、修改文件的权限属性和角色

1. 修改权限属性

        我们可以使用chmod指令修改一个目录或文件的权限属性。它的语法如下:

chmod 选项 权限 文件名

常用选项-R  递归地修改目录及子目录的权限

其中,若使用字符表示法表示权限,则其格式是:(角色)(+/-)(r/w/x)

角色

u:表示拥有者

g:表示所属组

o:表示其他人

a:表示所有角色

+/-

+:表示新增权限

-:表示去除权限 

使用示例:

chmod u+r test.txt  #对于该文件,给拥有者增加读权限

chmod g+rwx test.txt  #对于该文件,给所属组增加读、写、执行权限

chmod a-x test.txt  #对于该文件,去除所有人的执行权限
chmod -x test.txt  #与上条指令等价

chmod u+r,o-w test.txt  #对于该文件,给拥有者增加读权限,并去除其他人的写权限

当然我们也可以使用八进制表示方法设置文件权限。使用示例:

chmod 777 test.txt  #针对该文件,给所有人增加所有权限
chmod 456 test.txt  #针对该文件,设置拥有者的八进制权限编号为4,所属组为5,其他人为6

注意只有文件的拥有者或具有root权限才能修改和设置文件的权限属性

2. 修改文件角色

        除了文件的权限属性,文件角色也可以被修改。

chown指令修改文件拥有者

chown 用户名 文件名

使用示例:

chown user test.txt  #将test.txt的拥有者改为user
chown -R user mydir/...  #将目录mydir及其子目录的拥有者改为user

chgrp指令修改文件所属组

chgrp 用户名 文件名

 使用示例:

chgrp user test.txt  #将test.txt的所属组改为user
chgrp -R user mydir/...  #将目录mydir及其所有子目录的所属组改为user

 注意只有具有root权限才能修改文件拥有者;只有文件的拥有者或具有root权限才可以修改该文件所属组

五、关于权限的三个问题

1. 目录的权限

对于一个目录而言:

        如果没有权限,就无法查看该目录下的文件信息;

        如果没有权限,那么就无法创建、删除、修改该目录内部的文件;

        如果没有执行权限,那么无法进入该目录。

注意:即使一个目录有读权限,但若没有执行权限,那么仍然无法进入该目录,并且无法在该目录下执行命令和查看该目录下文件的详细信息。

2. 默认权限与实际权限

        在Linux下,一个普通文件,它的默认权限是rw- rw- rw-(666);而一个目录的默认权限是rwx rwx rwx(777)

        但当我们创建一个普通文件和目录后,可以看到其权限属性并非是默认值

相比默认权限,两者的实际权限貌似缺失了所属组和其他人的读权限。这是为什么呢?

        实际上,存在一种叫做umask权限掩码的机制,它控制的是新创建文件和目录时,哪些权限将被去除。注意:它并不会直接赋予权限,而是通过限制默认权限来间接设定权限。

可以使用umask指令查看umask码:

可以看到,当前系统的umask为022(最高位的0暂且省略),它其实是一个三位八进制数字,与八进制数字表示的权限属性相呼应。

掩码规则:文件的实际权限 = 默认权限(八进制)- umask

所以我们看到的文件和目录的实际权限是:

目录:777 - 022 = 755 (rwx r-x -r-x)

文件:666 - 022 = 644 (rw- r-- r--)

        当然,umask也可支持修改,使用示例如下:

umask 002  #将umask修改为002

修改umask,可以达到修改实际权限的效果。

3. 删除权限与粘滞位

        删除一个文件,看的不是该文件的读/写/执行权限,而是需要该文件所在目录的写权限执行权限,因为执行权限决定了是否可以进入目录;写权限决定了是否可以删除目录下文件。

        但这种设定似乎并不合理:假设有一个用户,其无权访问文件A,但可能有权删除文件A。

        所以Linux出现了一种机制:粘滞位,用于防止无关人员删除重要文件

当一个目录被设置为粘滞位后,其下的文件或目录只能由以下两者删除:

1. root用户

2. 当前文件或目录的所有者

也就是说,除了root用户之外,该目录下的文件或目录,只有自己的,才能被自己删除。

设置粘滞位的指令:

chmod +t 目录名

总结:如果想要共享一个目录,并且确保目录下的文件不被删除,那么就需要设置粘滞位。

有两点需要注意:

1. 根目录下的tmp目录自带粘滞位,可以用做共享目录。

2. 粘滞位只需给目录设置,不需要给普通文件设置。 

总结

        本篇文章,我们深入探讨了Linux系统中的权限管理,包括权限的概念、用户角色、文件属性及其权限设置的操作方法。了解并掌握这些内容对于管理Linux系统的安全性至关重要。通过合理配置文件权限和用户角色,可以有效控制文件访问、提高系统的安全性和灵活性。如果你觉得博主讲的还不错,就请留下一个小小的赞在走哦,感谢大家的支持❤❤❤

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

三次握手,四次挥手,服务器模型(多进程并发,线程),基于套接字的UDP通信

三次握手: 第一次握手:客户端向服务器发送SYN待确认数据x, 客户端进入SYN_SEND状态​ 第二次握手:服务器向客户端回传一条ACK应答数据x1, 同时发送一条SYN待确认数据y,服务器进入SYN_RECV状态​ 第三次握手:客户端向服…

PostgreSQL的学习心得和知识总结(一百六十七)|深入理解PostgreSQL数据库之静态语法检查工具PgSanity的使用和实现

目录结构 注:提前言明 本文借鉴了以下博主、书籍或网站的内容,其列表如下: 1、参考书籍:《PostgreSQL数据库内核分析》 2、参考书籍:《数据库事务处理的艺术:事务管理与并发控制》 3、PostgreSQL数据库仓库链接,点击前往 4、日本著名PostgreSQL数据库专家 铃木启修 网站…

【数据结构】双向链表(真正的零基础)

链表是一种物理存储单元上非连续、非顺序的存储结构。数据元素的逻辑顺序是通过指针的链接来实现的!在上篇我们学习了单向链表,而单向链表虽然空间利用率高,插入和删除也只需改变指针就可以达到!但是我们在每次查找、删除、访问..…

Docker 之mysql从头开始——Docker下mysql安装、启动、配置、进入容器执行(查询)sql

一、Docker 之mysql安装配置 步骤一:拉取镜像 1. 查看是否包含已安装的mysql。 docker images | grep mysql 2. 如上图所示,我们有mysql镜像,所以不必对mysql镜像进行拉取,如若没有上图中的惊喜,使用如下命令进行拉取…

网易日常实习一面面经

1. 自我介绍 2. 两道代码题: 第一道题:写一道链表排序题要求空间复杂度O(1) :已ac 插入排序算法 时间复杂度 O(N^2),空间复杂度O(1) class ListNode{int val;ListNode next;public ListNode(int x) {this.val x;} } public cl…

DeepSeek LLM 论文解读:相信长期主义开源理念可扩展大语言模型(DeepSeek 吹响通用人工智能的号角)

论文链接:DeepSeek LLM: Scaling Open-Source Language Models with Longtermism(相信长期主义开源理念可扩展大语言模型) 目录 摘要一、数据处理(一)数据清洗与丰富(二)分词器与词汇设置 二、模…

02DevOps基础环境准备

准备两台Linux的操作系统,最简单的方式就是在本机上使用虚拟机搭建两个操作系统(实际生产环境是两台服务器,虚拟机的方式用于学习使用) 我搭建的两台服务器的ip分别是192.168.1.10、192.168.1.11 192.168.1.10服务器用于安装doc…

基于 SpringBoot 和 Vue 的智能腰带健康监测数据可视化平台开发(文末联系,整套资料提供)

基于 SpringBoot 和 Vue 的智能腰带健康监测数据可视化平台开发 一、系统介绍 随着人们生活水平的提高和健康意识的增强,智能健康监测设备越来越受到关注。智能腰带作为一种新型的健康监测设备,能够实时采集用户的腰部健康数据,如姿势、运动…

表单与交互:HTML表单标签全面解析

目录 前言 一.HTML表单的基本结构 基本结构 示例 二.常用表单控件 文本输入框 选择控件 文件上传 按钮 综合案例 三.标签的作用 四.注意事项 前言 HTML&#xff08;超文本标记语言&#xff09;是构建网页的基础&#xff0c;其中表单&#xff08;<form>&…

vue3中使用print-js组件实现打印操作

第一步&#xff1a;安装依赖 yarn add print-js 第二步&#xff1a;创建打印组件&#xff1a;PrintHtmlComp.vue <template><div id"printArea_123456789"><!-- 默认插槽&#xff0c;传入打印内容 --><slot></slot></div>…

【计算机网络】TCP/IP 网络模型有哪几层?

目录 应用层 传输层 网络层 网络接口层 总结 为什么要有 TCP/IP 网络模型&#xff1f; 对于同一台设备上的进程间通信&#xff0c;有很多种方式&#xff0c;比如有管道、消息队列、共享内存、信号等方式&#xff0c;而对于不同设备上的进程间通信&#xff0c;就需要网络通…

网络工程师 (29)CSMA/CD协议

前言 CSMA/CD协议&#xff0c;即载波监听多路访问/碰撞检测&#xff08;Carrier Sense Multiple Access with Collision Detection&#xff09;协议&#xff0c;是一种在计算机网络中&#xff0c;特别是在以太网环境下&#xff0c;用于管理多个设备共享同一物理传输介质的重要…

基于Python的人工智能驱动基因组变异算法:设计与应用(下)

3.3.2 数据清洗与预处理 在基因组变异分析中,原始数据往往包含各种噪声和不完整信息,数据清洗与预处理是确保分析结果准确性和可靠性的关键步骤。通过 Python 的相关库和工具,可以有效地去除噪声、填补缺失值、标准化数据等,为后续的分析提供高质量的数据基础。 在基因组…

AI大语言模型

一、AIGC和生成式AI的概念 1-1、AIGC Al Generated Content&#xff1a;AI生成内容 1-2、生成式AI&#xff1a;generative ai AIGC是生成式 AI 技术在内容创作领域的具体应用成果。 目前有许多知名的生成式 AI&#xff1a; 文本生成领域 OpenAI GPT 系列百度文心一言阿里通…

在postman中设置环境变量和全局变量以及五大常用响应体断言

一、什么是环境变量和全局变量 环境变量&#xff08;Environment Variables&#xff09;和全局变量&#xff08;Global Variables&#xff09;是 Postman 中用于存储和管理数据的两种变量类型&#xff0c;它们可以提高 API 测试的灵活性和可维护性。 1、 环境变量&#xff08…

Redis数据库(二):Redis 常用的五种数据结构

Redis 能够做到高性能的原因主要有两个&#xff0c;一是它本身是内存型数据库&#xff0c;二是采用了多种适用于不同场景的底层数据结构。 Redis 常用的数据结构支持字符串、列表、哈希表、集合和有序集合。实现这些数据结构的底层数据结构有 6 种&#xff0c;分别是简单动态字…

C++STL(六)——list模拟

目录 本次所需实现的三个类一、结点类的模拟实现构造函数 二、迭代器类的模拟实现为什么有迭代器类迭代器类的模板参数说明构造函数运算符的重载- -运算符的重载和!运算符的重载*运算符的重载->运算符的重载引入模板第二个和第三个参数 三、list的模拟实现3.1 默认成员函数构…

国产编辑器EverEdit - 替换功能详解

1 替换 1.1 应用场景 替换文本是在文档编辑过程中不可回避的操作&#xff0c;是将指定的关键词替换为新的文本&#xff0c;比如&#xff1a;写代码时修改变量名等。 1.2 使用方法 1.2.1 基本替换 使用主菜单查找 -> 替换&#xff0c;或使用快捷键Ctrl H&#xff0c;会打…

LIMO:上海交大的工作 “少即是多” LLM 推理

25年2月来自上海交大、SII 和 GAIR 的论文“LIMO: Less is More for Reasoning”。 一个挑战是在大语言模型&#xff08;LLM&#xff09;中的复杂推理。虽然传统观点认为复杂的推理任务需要大量的训练数据&#xff08;通常超过 100,000 个示例&#xff09;&#xff0c;但本文展…

防御保护作业二

拓扑图 需求 需求一&#xff1a; 需求二&#xff1a; 需求三&#xff1a; 需求四&#xff1a; 需求五&#xff1a; 需求六&#xff1a; 需求七&#xff1a; 需求分析 1.按照要求进行设备IP地址的配置 2.在FW上开启DHCP功能&#xff0c;并配置不同的全局地址池&#xff0c;为…