如何理解文件权限rw-r-r-1?

权限基础概念

Linux为每个文件/目录定义三类用户:

  1. 所有者(Owner):文件创建者或指定用户
  2. 所属组(Group):共享权限的用户组
  3. 其他用户(Others):系统所有其他账户

权限类型分为三种:

  • 读(r):查看文件内容/目录列表
  • 写(w):修改文件/在目录增删文件
  • 执行(x):运行程序/进入目录

查看当前权限

使用 ls -l 命令查看:

ls -l file.txt```
- **首段符号解析**:  
  `-rw-r--r--` →  
  `-`(文件类型)`rw-`(所有者权限)`r--`(组权限)`r--`(其他用户权限)
---
### **三、修改权限(chmod命令)**
#### **1. 数字模式(推荐)**
权限用数字表示:`r=4`, `w=2`, `x=1`,组合相加:  
```bash
chmod 755 file.txt  # 所有者:rwx(7),组:r-x(5),其他:r-x(5)
chmod 644 dir/      # 所有者:rw(6),组:r(4),其他:r(4)
  • 常用场景
    • 755:可执行程序/目录
    • 644:普通文件(禁止其他用户修改)

符号模式

通过 u/g/o/a(用户/组/其他/所有)和 操作:

chmod u+x script.sh    # 给所有者添加执行权限  
chmod g-w file.txt     # 移除组的写入权限  
chmod o=r-- dir/       # 设置其他用户为只读  

修改所有者与组

  • 更改所有者(需sudo):
    sudo chown user1 file.txt  # 设置所有者
    sudo chown user1:group1 dir/  # 同时设置所有者和组
  • 更改所属组
    sudo chgrp developers project/  # 将目录所属组设为developers

设置默认权限(umask)

umask 决定新建文件/目录的初始权限:

umask 022    # 默认值:文件权限=644,目录权限=755
umask 007    # 组和其他用户无权限(文件=660,目录=770)
  • 计算规则:目录权限 = 777 - umask文件权限 = 666 - umask

特殊权限

  1. SUID4xxx):用户以所有者身份运行程序
    chmod 4755 /usr/bin/program  # 设置SUID
  2. SGID2xxx):目录中新文件继承组权限
    chmod 2775 shared_dir/  # 设置SGID
  3. 粘滞位1xxx):仅所有者可删除目录内文件(如/tmp
    chmod 1777 public_upload/

安全实践与注意事项

  1. 避免过度授权
    • 禁止随意使用 chmod 777,否则所有用户可任意修改文件。
    • 目录需+x权限才能访问内部文件。
  2. 最小权限原则
    • 普通用户文件建议设为 644,敏感数据用 600
  3. 特殊权限风险

    SUID/SGID程序需审计,避免提权漏洞。

  4. 递归修改
    • 批量修改目录权限时用 -R 参数:
      chmod -R 750 /data/  # 递归设置/data下所有内容

引用说明: 基于Linux核心工具集(GNU coreutils)官方文档及Linux man手册(man chmod, man chown, man umask),权限设计遵循POSIX标准,适用于所有主流Linux发行版(Ubuntu/CentOS等)。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/7032.html

(0)
酷番叔酷番叔
上一篇 2025年7月12日 06:16
下一篇 2025年7月12日 06:32

相关推荐

  • 底层驱动交互核心方法哪三种?

    在Linux系统中,Qt应用程序操作底层驱动函数的核心原理是通过用户空间与内核空间的交互实现的,由于Qt本身是用户空间框架,无法直接访问内核驱动,因此需借助Linux提供的标准化接口,以下是具体实现方法和关键技术:设备文件操作(/dev目录)Linux将硬件设备抽象为文件(如 /dev/ttyS0、/dev/i……

    2025年7月6日
    17700
  • Linux如何不保存退出?操作方法有哪些?

    在Linux系统中,不保存退出文件通常发生在使用文本编辑器编辑文件后,用户希望放弃所有修改并直接退出编辑器,这一操作在Linux日常运维和开发中较为常见,尤其是在编辑错误或临时查看文件时,不同文本编辑器的操作方式存在差异,下面将针对Linux中最常用的几种编辑器(如vi/vim、nano等)详细说明不保存退出的……

    2025年9月25日
    14400
  • 最新源码官网如何获取?

    在 Linux 系统中安装名称以 “g” 开头的软件(如 gcc、git、grep 等)需根据具体软件名和发行版选择合适方法,以下是详细指南,符合安全性和最佳实践:通用安装方法(推荐优先使用)通过包管理器安装(最安全可靠)Linux 发行版均提供官方软件仓库,通过包管理器安装可自动解决依赖问题并确保安全性,De……

    2025年7月30日
    13800
  • 程序员如何避免996加班?

    在Linux系统中监控硬件温度对于维护系统稳定性、预防过热损坏及优化性能至关重要,以下详细介绍多种命令行与图形化工具的操作方法,涵盖CPU、硬盘、GPU等核心硬件:核心工具安装与配置lm-sensors(CPU/主板传感器)安装:sudo apt install lm-sensors # Debian/Ubun……

    2025年8月8日
    13800
  • 如何打包当前目录所有文件?

    在Linux系统中,表示当前目录是文件操作和命令行导航的基础概念,当前目录(Current Working Directory)指用户或程序正在操作的位置,类似于Windows中的“打开文件夹”,正确理解其表示方法能避免路径错误,提升命令执行效率,以下是两种核心表示方式及使用场景:点号 :最简表示法点号是Lin……

    2025年7月6日
    16200

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信