Linux权限分配不当会引发哪些安全风险?

Linux权限基础

  1. 权限组成

    • 用户(User):文件/目录的所有者(创建者)
    • 组(Group):共享权限的用户集合
    • 其他(Others):除所有者和组外的用户
    • 权限类型
      • r(读):查看文件内容/目录列表
      • w(写):修改文件/增删目录内容
      • x(执行):运行程序/进入目录
  2. 查看权限
    命令 ls -l 输出示例:

    -rw-r--r-- 1 user1 dev_team 1024 Jan 1 10:00 report.txt
    • 首段 -rw-r--r--
      • 第1位:表示文件,d表示目录
      • 后9位:三组rwx(分别对应用户/组/其他)

修改权限的三种方法

chmod:修改文件/目录权限

  • 符号模式(直观)
    语法:chmod [角色][操作][权限] 文件名

    • 角色:u(用户), g(组), o(其他), a(所有)
    • 操作:(添加), (移除), (设定)
    • 权限:r, w, x
      示例

      chmod u+x script.sh    # 给所有者添加执行权限
      chmod go-w file.txt    # 移除组和其他用户的写权限
      chmod a=rw config.cfg  # 所有用户设为读写权限
  • 数字模式(高效)
    权限值:r=4, w=2, x=1,按位相加
    示例

    chmod 755 backup.sh    # 用户:rwx(7),组和其他:rx(5)
    chmod 640 secret.txt   # 用户:rw(6),组:r(4),其他:无权限(0)

chown:修改所有者/组

  • 语法:chown [新所有者]:[新组] 文件名
    示例

    chown user2 report.log     # 更改文件所有者为user2
    chown user3:admins /data   # 同时更改所有者和组
    sudo chown -R www:www /var/www  # -R递归修改目录下所有文件

    ⚠️ 需sudo权限执行

chgrp:修改所属组

  • 语法:chgrp [新组名] 文件名
    示例

    chgrp developers app.py

高级权限管理

  1. 特殊权限

    • SUID4):用户以文件所有者身份执行
      chmod 4755 /usr/bin/custom_tool
    • SGID2):目录中新文件继承组权限
      chmod 2775 /shared_dir
    • Sticky Bit1):仅文件所有者可删除(如/tmp
      chmod 1777 /public_upload
  2. ACL(访问控制列表)
    为特定用户/组定制权限(需安装acl包):

    setfacl -m u:guest:rwx project/  # 给guest用户rwx权限
    setfacl -m g:contractors:r-x project/
    getfacl project/                 # 查看ACL权限

安全最佳实践

  1. 最小权限原则

    • 避免使用chmod 777(所有用户可读写执行)
    • 目录权限推荐755,敏感文件设为600(仅所有者读写)
  2. 关键操作规范

    • 使用sudo临时提权而非长期使用root账户
    • 通过用户组管理权限(如创建dev_team组分配项目权限)
    • 定期审计权限:find / -perm -4000 检查SUID文件
  3. 权限继承示例
    创建共享目录步骤:

    sudo mkdir /team_data
    sudo chown admin:team_group /team_data
    sudo chmod 2770 /team_data     # SGID确保新文件继承组权限
    sudo usermod -aG team_group user1  # 将用户加入组

Linux权限管理依赖三大命令:

  • chmod 控制读写执行
  • chown 调整所有者
  • chgrp 修改所属组

始终遵循最小权限原则,结合ACL满足复杂场景需求,错误的权限配置可能导致数据泄露或系统瘫痪,操作前务必验证命令准确性。

引用说明基于Linux官方文档(kernel.org/docs)、Filesystem Hierarchy Standard(FHS 3.0)及《Linux Administration Handbook》权威指南的技术标准,权限管理实践符合CIS Linux安全基准要求。

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

(0)
酷番叔酷番叔
上一篇 1天前
下一篇 1天前

相关推荐

  • Linux删文件后悔了?如何避免误删

    基础删除命令:rmrm(remove)是最常用的删除命令,直接永久删除文件(不进入回收站),基本语法:rm [选项] 文件名常用选项:选项作用示例-i交互式删除(推荐)rm -i file.txt → 删除前确认-f强制删除(忽略错误)rm -f file.txt → 无需确认直接删-v显示删除详情rm -v……

    6天前
    800
  • 电脑存储空间怎么查看

    在 Linux 系统中,查看设备信息是系统管理、故障排查和硬件维护的基础操作,以下详细介绍多种专业方法,涵盖存储设备、PCI/USB 硬件、CPU 等关键组件,所有命令均经过严格测试,适用于主流 Linux 发行版(如 Ubuntu、CentOS、Fedora),lsblk 命令功能:直观显示块设备(硬盘、分区……

    4天前
    700
  • Linux编辑文件必学哪几种方法?

    命令行编辑器(终端操作)Vi/Vim 编辑器Vi/Vim 是Linux预装的高效文本编辑器,适合远程服务器操作,基本步骤:vim 文件名 # 打开文件(若不存在则创建)进入编辑模式:按 i(插入)或 a(追加)开始编辑,保存与退出:按 Esc 返回命令模式 → 输入 :wq 保存并退出,其他命令::q! 不保存……

    2025年7月6日
    1300
  • 如何安全移除MySQL核心包及依赖?

    在Linux上彻底卸载MySQL的完整指南卸载MySQL前,请务必备份所有数据库数据,避免不可逆的数据丢失,以下步骤覆盖主流Linux发行版(Ubuntu/Debian 和 CentOS/RHEL),包含服务停止、软件移除、残留清理及验证方法,卸载前的关键准备备份数据库(防止误删): mysqldump -u……

    1天前
    300
  • 如何在Ubuntu快速创建用户?

    核心命令:useradd 与 adduseruseradd:基础命令,需手动配置参数(推荐有经验的用户)adduser:交互式工具,自动创建家目录和提示设置密码(新手首选)使用 useradd 创建用户(通用)sudo useradd -m -s /bin/bash username # -m:创建家目录 -s……

    2025年6月22日
    1300

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信