【Linux】权限管理(文件的访问者、类型和访问权限,chmod、chown、chgrp、umask,粘滞位)

本文主要是介绍【Linux】权限管理(文件的访问者、类型和访问权限,chmod、chown、chgrp、umask,粘滞位),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

00.前言

01.文件访问者的分类

02.文件类型和访问权限

文件类型:

文件基本权限:

03.文件权限值的表示方法

04.访问权限的设置

(1)chmod

(2)chown

(3)chgrp

(4)umask

05.目录的权限

粘滞位

总结


00.前言

        在生活中,所有的个人财产都有它们各自的所有权人,非所有权人想要使用其个人财产需要征得所有权人的同意,就好比小时候我们借同桌的一块橡皮,需要征得他的同意才行,不然可能就会产生矛盾[doge]。

        linux下面的一切文件也是如此,所有文件都有各自的权限,其权限由访问者和访问权限构成。

root 就是文件的访问者,访问者有不同类型,所以这里显示了两类访问者。

-rw-r--r-- 就是文件的访问权限,下面会解释。

01.文件访问者的分类

  1. 文件和文件目录的所有者:

    • 符号表示为 u,代表User(用户),也就是文件或目录的创建者或所有者。
    • 在中国的法律问题中,通常会涉及到文件或目录的所有者,即文件的创建者或拥有者。所有者拥有对文件或目录的完全控制权限,可以对其进行读取、写入和执行等操作。
  2. 文件和文件目录的所有者所在的组的用户:

    • 符号表示为 g,代表Group(用户组),即文件或目录的所有者所属的用户组。
    • 在中国的法律问题中,这一概念通常用于讨论文件或目录的共享和访问权限。文件的所有者可以选择与哪些用户共享文件,通过设置适当的用户组权限来控制访问。
  3. 其它用户:

    • 符号表示为 o,代表Others(其他用户),即除了文件的所有者和所属用户组之外的所有用户。
    • 在中国的法律问题中,这一概念通常用于讨论文件或目录的公共访问权限。通过设置适当的其他用户权限,可以控制其他用户对文件或目录的访问权限,以保护文件的安全性和隐私。

02.文件类型和访问权限

如图:

下面我们来一一解释:

  1. 文件类型

    • 在 Linux 中,每个文件都有一个文件类型,文件类型通常由文件的第一个字符表示。
    • 常见的文件类型包括:
      • -:普通文件。
      • d:目录。
      • l:符号链接(软链接)。
      • c:字符设备文件。
      • b:块设备文件。
      • p:命名管道(FIFO)。
      • s:套接字(Socket)。
  2. 文件基本权限

    • 文件基本权限是指文件或目录的基本访问权限,通常由 9 个字符组成,分为 3 组,每组 3 个字符,分别表示文件的所有者、用户组和其他用户的权限。
    • 每个权限字符的含义如下:
      • r:读权限,表示允许读取文件内容。
      • w:写权限,表示允许修改或删除文件内容。
      • x:执行权限,对于普通文件表示允许执行文件,对于目录表示允许进入目录。
      • -:表示缺少对应的权限。

    例如,文件权限为 -rw-r--r-- 表示文件的所有者具有读写权限,用户组和其他用户只有读权限。

下面举个例子让我们更好理解:我有一块橡皮,我现在拿它擦字,它的访问者就是所有者我,它的访问权限是可以随意使用,我可以拿它擦铅笔字,也可以对它进行破坏。我同桌向我借走了这块橡皮去用,此时访问者变成了其他人,我告诉他只能用来擦铅笔字,其访问权限就仅限于擦字。

03.文件权限值的表示方法

下面用一张图来表示:

所以前一张图中

表示文件所有者可读可写可执行,文件所属用户组可读可执行但不可写,其他用户也是可读可执行但不可写。

04.访问权限的设置

(1)chmod

chmod 命令说明:

  • 功能: 设置文件的访问权限
  • 格式: chmod [参数] 权限 文件名
  • 常用选项:
    • -R:递归修改目录文件的权限

符号模式说明:

  • 用户符号:

    • u:文件拥有者(User)
    • g:文件拥有者所在的用户组(Group)
    • o:其他用户(Others)
    • a:所有用户(All)
  • 权限操作符:

    • +:增加权限
    • -:取消权限
    • =:设置权限
  • 权限字符:

    • r:读权限(Read)
    • w:写权限(Write)
    • x:执行权限(Execute)

实例:

  • +:向权限范围增加权限代号所表示的权限
  • -:向权限范围取消权限代号所表示的权限
  • =:向权限范围赋予权限代号所表示的权限

示例用法:

  • chmod u+r file.txt:给文件的拥有者添加读权限
  • chmod g-w file.txt:取消文件所属用户组的写权限
  • chmod o=x file.txt:设置其他用户的执行权限
  • chmod a=rwx file.txt:给所有用户设置读、写、执行权限
  • chmod 664 file.txt:给文件的拥有者以及所属用户组添加读、写权限;给其他用户添加读权限
  • chmod 640 file.txt:给文件的拥有者添加读、写权限;给文件所属用户组添加读权限;其他用户不添加任何权限

(2)chown

chown 命令说明:

  • 功能: 更改文件或目录的所有者和/或用户组
  • 格式: chown [参数] 用户名[:用户组] 文件名
  • 常用选项:
    • -R:递归更改目录及其子目录中所有文件的所有者和/或用户组

示例用法:

  • chown user1 file.txt:将文件 file.txt 的所有者更改为 user1
  • chown user2:group1 file.txt:将文件 file.txt 的所有者更改为 user2,用户组更改为 group1
  • chown -R user3 directory/:递归地将目录 directory/ 及其子目录中所有文件的所有者更改为 user3

注意事项:

  • 只有文件的所有者和 root 用户可以更改文件的所有者和用户组。
  • 如果省略了用户组,则文件的用户组不会更改。
  • -R 选项用于递归地更改目录及其子目录中所有文件的所有者和/或用户组。

(3)chgrp

chgrp 命令说明:

  • 功能: 更改文件或目录的用户组
  • 格式: chgrp [参数] 用户组 文件名
  • 常用选项:
    • -R:递归更改目录及其子目录中所有文件的用户组

示例用法:

  • chgrp group1 file.txt:将文件 file.txt 的用户组更改为 group1
  • chgrp -R group2 directory/:递归地将目录 directory/ 及其子目录中所有文件的用户组更改为 group2

注意事项:

  • 只有文件的所有者和 root 用户可以更改文件的用户组。
  • -R 选项用于递归地更改目录及其子目录中所有文件的用户组。

(4)umask

umask 命令说明:

  • 功能: 设置新建文件的默认权限掩码
  • 格式: umask [参数] [权限掩码]

示例用法:

  • umask:显示当前的权限掩码
  • umask 022:设置新建文件的默认权限掩码为 022
  • umask -S:以符号模式显示当前的权限掩码
  • umask -p:以八进制数模式显示当前的权限掩码

说明:

  • umask 命令用于设置新建文件的默认权限掩码,它决定了新文件创建时的默认权限。
  • 权限掩码是一个八进制数字,表示了要屏蔽的权限位。例如,权限掩码 022 表示屏蔽了组和其他用户的写权限。
  • 可以使用 -S 选项以符号模式显示权限掩码,或使用 -p 选项以八进制数模式显示权限掩码。

05.目录的权限

  1. 目录权限基本概念

    • 目录权限与文件权限类似,也是由读、写、执行三种基本权限组成,用来控制用户对目录的访问和操作权限。
    • 读权限:允许用户列出目录中的文件名。
    • 写权限:允许用户在目录中创建、删除和重命名文件。
    • 执行权限:允许用户进入目录,访问其内容。
  2. 目录的基本权限设置

    • 使用 chmod 命令可以设置目录的权限,与设置文件权限类似。
    • 例如,chmod 755 directory 可以将目录 directory 的权限设置为 rwxr-xr-x,允许所有者读、写、执行,允许用户组和其他用户读、执行。

        下面举个例子,如果有一个共享目录,A用户在里面写了一个文件,并设置除所有者外的用户只能读不能写不能执行,其目的是不想让其他用户修改甚至删除自己写的文件,可是如此一来,B用户具有这个目录的写权限,那么他是不是就可以删除这个目录中的文件,而不用管是否具有这个文件的写权限了吗,这合理吗,显然不合理,为此Linux引入了粘滞位的概念。

粘滞位

        粘滞位是一种特殊的文件权限,它通常用于目录上,对于目录上设置了粘滞位的情况,只有文件的所有者、目录的所有者或者管理员才能够删除该目录中的文件。

  1. 粘滞位的作用

    • 粘滞位通常用于目录中,它确保只有文件的所有者、目录的所有者或者管理员才能够删除目录中的文件。
    • 在具有粘滞位的目录中,即使其他用户有删除文件的权限,但他们也不能删除不属于自己的文件。
  2. 粘滞位的设置

    • 在 Linux 中,使用 chmod 命令可以设置粘滞位。
    • 对于目录,粘滞位通常是通过在权限模式的末尾添加一个 t 来设置的。例如,chmod +t directory 可以为目录 directory 设置粘滞位。
    • 使用数字模式时,粘滞位的权限位表示为数字中的最后一位。例如,chmod 1755 directory 中的 1 表示粘滞位。
  3. 粘滞位的显示

    • 在文件列表中,具有粘滞位的目录将在权限列表中显示一个小写字母 t
    • 如果目录没有设置粘滞位,则显示一个大写字母 T

总结

  • 目录的可执行权限 (x) 决定了用户是否可以在该目录下执行命令或者进入该目录。
  • 如果目录没有可执行权限 (-x),即使具有读权限 (r),用户也无法在目录下执行任何命令,甚至无法通过 cd 命令进入该目录。
  • 如果目录具有可执行权限 (x),但没有读权限 (r),用户仍然可以通过 cd 命令进入目录,但是由于没有读权限,无法查看目录中的文件列表。
  • 即使用户可以执行 ls 命令,但由于没有读权限,仍然无法读取目录中的文件。
  • 有时候容易混淆可执行权限和读权限的作用,但只有具有可执行权限的目录才允许用户进入该目录,而读权限仅允许用户查看目录中的文件列表。

这篇关于【Linux】权限管理(文件的访问者、类型和访问权限,chmod、chown、chgrp、umask,粘滞位)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/786392

相关文章

Linux虚拟机不显示IP地址的解决方法(亲测有效)

《Linux虚拟机不显示IP地址的解决方法(亲测有效)》本文主要介绍了通过VMware新装的Linux系统没有IP地址的解决方法,主要步骤包括:关闭虚拟机、打开VM虚拟网络编辑器、还原VMnet8或修... 目录前言步骤0.问题情况1.关闭虚拟机2.China编程打开VM虚拟网络编辑器3.1 方法一:点击还原VM

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

SpringBoot接收JSON类型的参数方式

《SpringBoot接收JSON类型的参数方式》:本文主要介绍SpringBoot接收JSON类型的参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、jsON二、代码准备三、Apifox操作总结一、JSON在学习前端技术时,我们有讲到过JSON,而在

Spring Security注解方式权限控制过程

《SpringSecurity注解方式权限控制过程》:本文主要介绍SpringSecurity注解方式权限控制过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、摘要二、实现步骤2.1 在配置类中添加权限注解的支持2.2 创建Controller类2.3 Us

Javascript访问Promise对象返回值的操作方法

《Javascript访问Promise对象返回值的操作方法》这篇文章介绍了如何在JavaScript中使用Promise对象来处理异步操作,通过使用fetch()方法和Promise对象,我们可以从... 目录在Javascript中,什么是Promise1- then() 链式操作2- 在之后的代码中使

Redis实现RBAC权限管理

《Redis实现RBAC权限管理》本文主要介绍了Redis实现RBAC权限管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1. 什么是 RBAC?2. 为什么使用 Redis 实现 RBAC?3. 设计 RBAC 数据结构

Linux系统之authconfig命令的使用解读

《Linux系统之authconfig命令的使用解读》authconfig是一个用于配置Linux系统身份验证和账户管理设置的命令行工具,主要用于RedHat系列的Linux发行版,它提供了一系列选项... 目录linux authconfig命令的使用基本语法常用选项示例总结Linux authconfi

jdk21下载、安装详细教程(Windows、Linux、macOS)

《jdk21下载、安装详细教程(Windows、Linux、macOS)》本文介绍了OpenJDK21的下载地址和安装步骤,包括Windows、Linux和macOS平台,下载后解压并设置环境变量,最... 目录1、官网2、下载openjdk3、安装4、验证1、官网官网地址:OpenJDK下载地址:Ar

linux本机进程间通信之UDS详解

《linux本机进程间通信之UDS详解》文章介绍了Unix域套接字(UDS)的使用方法,这是一种在同一台主机上不同进程间通信的方式,UDS支持三种套接字类型:SOCK_STREAM、SOCK_DGRA... 目录基础概念本机进程间通信socket实现AF_INET数据收发示意图AF_Unix数据收发流程图A