Linux 的 chmod 命令

Linux 的 chmod 命令详解

基本概念

chmod (change mode) 是 Linux/Unix 系统中用于更改文件或目录权限的命令。权限控制是 Linux 系统安全性的重要组成部分,它决定了哪些用户可以读取、写入或执行特定文件。

权限表示方式

Linux 系统中的权限有三种表示方法:

  1. 符号表示法

    • r (read):读取权限
    • w (write):写入权限
    • x (execute):执行权限
    • - (无权限)
  2. 八进制表示法

    • 4:读权限
    • 2:写权限
    • 1:执行权限
    • 这些数字可以相加组合,如 7 (4+2+1) 表示读写执行权限
  3. 用户类别

    • u (user/owner):文件所有者
    • g (group):文件所属组
    • o (others):其他用户
    • a (all):所有用户

常用命令格式

bash 复制代码
chmod [选项] 模式 文件...

使用示例

  1. 符号模式示例

    bash 复制代码
    chmod u+x file.txt       # 给所有者添加执行权限
    chmod g-w file.txt       # 移除所属组的写权限
    chmod o=r file.txt       # 设置其他用户只有读权限
    chmod a+x script.sh      # 给所有用户添加执行权限
  2. 八进制模式示例

    bash 复制代码
    chmod 755 script.sh      # 所有者:rwx,组:r-x,其他:r-x
    chmod 644 file.txt       # 所有者:rw-,组:r--,其他:r--
    chmod 600 secret.txt     # 只有所有者有读写权限
  3. 递归修改目录权限

    bash 复制代码
    chmod -R 755 directory/  # 递归修改目录及其内容权限

常用选项

  • -R--recursive:递归更改目录及其内容的权限
  • -v--verbose:显示详细的权限更改信息
  • -c--changes:仅显示实际发生更改的信息
  • --reference=RFILE:使用参考文件的权限模式

应用场景

  1. 保护敏感文件

    bash 复制代码
    chmod 600 ~/.ssh/id_rsa  # 保护SSH私钥文件
  2. 共享目录设置

    bash 复制代码
    chmod 775 /shared        # 允许组成员读写执行共享目录
  3. 脚本可执行权限

    bash 复制代码
    chmod +x install.sh      # 使脚本可执行
  4. Web服务器文件权限

    bash 复制代码
    chmod 644 *.html         # 网页文件只读
    chmod 755 cgi-bin/       # CGI目录需要执行权限

注意事项

  1. 修改系统文件权限可能导致安全问题或功能异常
  2. 过度宽松的权限(如777)会带来安全隐患
  3. 修改目录权限时,通常需要同时设置执行权限(x)才能访问目录内容
  4. 使用umask命令可以设置默认的文件创建权限

理解并正确使用chmod命令是Linux系统管理的基础技能之一,合理设置文件权限有助于维护系统安全和功能正常运行。

相关推荐
Avan_菜菜12 小时前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
Sokach101521 小时前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
SelectDB2 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
AlfredZhao2 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
zzzzzz3103 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode3 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220704 天前
如何搭建本地yum源(上)
运维
A小辣椒5 天前
TShark:Wireshark CLI 功能
linux
A小辣椒5 天前
TShark:基础知识
linux
AlfredZhao5 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci