0

0

Linux怎么限制用户权限_Linux编辑sudoers文件规则【进阶】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-15 14:54:35

|

776人浏览过

|

来源于php中文网

原创

必须用 visudo 编辑 sudoers 文件,因其保存前会语法校验;直接 vim 修改易致 sudo 失效且无法修复。

linux怎么限制用户权限_linux编辑sudoers文件规则【进阶】

sudoers 文件里写错一行,用户就彻底没 sudo 权了

/etc/sudoers 不是改普通配置文件,语法错误或权限逻辑冲突会导致 sudo 拒绝所有用户(包括 root)执行命令,连修复都进不去。必须用 visudo 编辑,它会在保存前做语法校验;直接 vim /etc/sudoers 是高危操作。

  • 每次修改后,用 sudo -l -U username 验证目标用户的实际可用命令,别只看配置写了什么
  • 不要在规则末尾加 ! 以外的注释——# 后内容会被解析器吞掉,可能造成意外交叉授权
  • 如果误锁自己,需重启进 recovery mode 或用 Live CD 挂载根分区手动修复 /etc/sudoers

限制用户只能运行特定脚本,但脚本里调用了其他命令怎么办

sudoers 的命令匹配是**字面精确匹配**,不展开 shell、不解析 shebang、不递归检查脚本内部调用。比如允许 /usr/local/bin/backup.sh,但该脚本里写了 rm -rf /tmp/*,那 rm 就不会被 sudo 授权,运行时会失败或静默丢弃权限。

  • 要么把脚本里所有依赖命令也逐条加进 sudoers(不推荐,维护成本高)
  • 要么用 sudo -E 保持环境变量 + 脚本内用绝对路径调用,并确保这些路径也在 sudoers 白名单中
  • 更稳妥的做法:用 sudoersCmnd_Alias 定义一组可信命令,再让脚本只调用这个集合里的东西

为什么加了 NOPASSWD 还要输密码

常见原因是规则顺序问题。sudoers 从上到下匹配,**第一条完全匹配的规则生效,后续忽略**。如果你在默认的 %sudo ALL=(ALL:ALL) ALL 之后加了一条 alice ALL=(ALL) NOPASSWD: /bin/ls,那 alice 执行 ls 时其实走的是前面那条需要密码的规则。

FlowMuse AI
FlowMuse AI

节点式AI视觉创作引擎

下载
  • 把更具体的规则(如用户级、命令级)放在通用规则(如 %sudo)之前
  • sudo -l -U alice 查看实际生效的规则列表,注意输出里哪条标了 (NOPASSWD)
  • Defaults targetpwDefaults rootpw 这类全局设置会覆盖单条规则的 NOPASSWD,需一并检查

sudo -u 指定用户执行时,环境变量和工作目录怎么控制

默认情况下,sudo -u www-data /path/to/script.sh 会继承当前 shell 的环境变量(比如 $HOME 还是你的家目录),但 www-data 用户的 $HOME 实际是 /var/www,这可能导致脚本读不到预期配置或写错日志路径。

  • -i 参数模拟登录: sudo -i -u www-data /path/to/script.sh,这时 $HOME$PATH$SHELL 全按目标用户重置
  • -H 强制设置 $HOME,但其他变量不变,适合轻量切换
  • 避免在 sudoers 中用 env_reset 以外的方式硬编码环境变量——不同发行版对 env_keep 的默认行为不一致,CentOS 和 Ubuntu 表现可能不同

真正麻烦的不是写规则,而是规则之间隐含的优先级、环境继承和命令路径解析逻辑。一个看似简单的 sudoers 条目,背后牵扯 shell 解析、PAM 策略、甚至 systemd user session 的环境隔离。改完别急着退出,先用 sudo -l -U 和实际命令跑一遍。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
session失效的原因
session失效的原因

session失效的原因有会话超时、会话数量限制、会话完整性检查、服务器重启、浏览器或设备问题等等。详细介绍:1、会话超时:服务器为Session设置了一个默认的超时时间,当用户在一段时间内没有与服务器交互时,Session将自动失效;2、会话数量限制:服务器为每个用户的Session数量设置了一个限制,当用户创建的Session数量超过这个限制时,最新的会覆盖最早的等等。

325

2023.10.17

session失效解决方法
session失效解决方法

session失效通常是由于 session 的生存时间过期或者服务器关闭导致的。其解决办法:1、延长session的生存时间;2、使用持久化存储;3、使用cookie;4、异步更新session;5、使用会话管理中间件。

772

2023.10.18

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

96

2025.08.19

vim保存退出命令
vim保存退出命令

vim是一个非常强大的文本编辑器,常用于Unix和Linux系统。它是从vi发展而来的,相比vi有许多改进和扩展。在vim中,保存并退出的命令是:wq"wq"这个命令是由两个部分组成的。其中,"w"表示写入文件,将所做的更改保存到磁盘;而"q"表示退出vim编辑器。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

268

2023.08.01

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1500

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

714

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

299

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

791

2023.07.05

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

145

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.1万人学习

Git 教程
Git 教程

共21课时 | 3.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号