sudo免密权限配置不生效

1. 故障现象

用户oneslide已在/etc/sudoers写入免密规则oneslide ALL=(ALL:ALL) NOPASSWD: ALL,执行sudo命令仍要求输入密码。

2. 诊断过程

  1. 执行权限校验命令:sudo -l -U oneslide

  2. 输出存在两条匹配规则:

    sql 复制代码
    (ALL : ALL) ALL
    (ALL : ALL) NOPASSWD: ALL
  3. 根因:oneslide归属sudo用户组,配置中%sudo ALL=(ALL:ALL) ALL行位于用户免密行上方;sudo规则遵循从上至下匹配,最后一条生效,原顺序组规则覆盖免密配置。

3. 修复操作

  1. 执行visudo编辑sudoers,调整规则顺序,将用户免密行移至sudo组规则下方:

    sudoers 复制代码
    %sudo	ALL=(ALL:ALL) ALL
    oneslide ALL=(ALL:ALL) NOPASSWD: ALL
  2. 语法校验:visudo -c,无语法报错。

  3. 清空sudo认证缓存:sudo -k

4. 验证结果

  1. 权限查询输出顺序更新,免密规则为最后匹配项:

    sql 复制代码
    User oneslide may run the following commands on oneslide-VMware-Virtual-Platform:
        (ALL : ALL) ALL
        (ALL : ALL) NOPASSWD: ALL
  2. 切换oneslide用户执行sudo ls /root,无需输入密码,故障解决。

5. 关键原理

sudo多规则匹配逻辑:同一用户命中多条权限时,文件内靠后的规则优先级更高;用户专属权限配置需放置于用户组通用权限下方,确保免密规则覆盖组默认密码校验规则。

6. 附属排查要点

  1. 检查/etc/sudoers.d/目录,无冲突权限子配置;
  2. 配置文件权限保持440,无权限异常干扰;
  3. 无PAM/SELinux强制密码校验策略。
相关推荐
站大爷IP1 小时前
为什么Python不用var或let声明变量?
后端
赴星半途1 小时前
NestJS实战-创建AuthService
后端
北冥有鱼1 小时前
mqtt 测试
前端·后端
代码丰1 小时前
使用 TtlExecutors 解决线程池中的 ThreadLocal 上下文丢失问题
后端
阿祖zu2 小时前
别再优化 RAG 了,适配 Agent 的 LLM Wiki 知识库理念
前端·后端·aigc
昵称为空C2 小时前
手撸一个动态 SQL 执行引擎:不重启服务,在线增删改查任意数据库
spring boot·后端
用户8356290780513 小时前
用 Python 自动化 PowerPoint 演讲者备注添加
后端·python
神奇小汤圆3 小时前
科研神器再升级!Claude Code 全套 Skills,16 大科研场景全覆盖!
后端