0

0

LINUX怎么切换用户身份_Linux su和sudo命令的区别与配置【权限管理】

尼克

尼克

发布时间:2025-12-24 18:13:17

|

303人浏览过

|

来源于php中文网

原创

Linux中切换用户身份需用su或sudo:su依赖目标用户密码切换会话,sudo基于当前用户密码授权执行命令,支持细粒度权限控制、日志审计与最小权限原则。

linux怎么切换用户身份_linux su和sudo命令的区别与配置【权限管理】

如果您在Linux系统中需要临时以其他用户身份执行命令或登录,必须使用特定的命令来切换用户身份。以下是实现用户身份切换的具体方法及su与sudo命令的核心差异说明:

一、使用su命令切换用户

su(switch user)命令用于切换当前shell会话的用户身份,可切换至普通用户或root用户,需目标用户的密码验证。默认不带参数时切换为root用户,且环境变量保持原用户状态;使用“-”或“-l”选项可加载目标用户的完整环境。

1、切换至root用户并继承其环境变量:
输入 su -lsu -,然后输入root密码。

2、切换至指定普通用户(如testuser)并加载其环境:
输入 su -l testuser,然后输入testuser的密码。

3、仅临时执行一条命令而不启动新shell:
输入 su -c "command" username,例如 su -c "ls /root" root,需输入root密码。

二、使用sudo命令以其他用户权限执行命令

sudo(superuser do)允许授权用户在不共享root密码的前提下,以指定用户(默认为root)身份执行特定命令。其行为由/etc/sudoers文件配置控制,支持细粒度权限分配和操作日志记录。

1、以root身份执行单条命令:
输入 sudo command,例如 sudo apt update,需输入当前用户的密码(若已配置密码缓存则可能免输)。

2、以指定非root用户身份执行命令:
输入 sudo -u username command,例如 sudo -u www-data ls /var/www

3、启动一个具有root权限的交互式shell:
输入 sudo -isudo -s,前者加载root环境,后者复用当前环境变量。

三、配置sudo权限(通过visudo编辑)

直接修改/etc/sudoers文件存在语法风险,必须使用visudo命令进行安全编辑,该命令会在保存前校验语法正确性,避免因配置错误导致sudo功能失效。

1、以root身份运行 visudo 命令打开配置文件

Subtxt
Subtxt

生成有意义的文本并编写完整的故事。

下载

2、在文件末尾添加授权行,例如授予用户alice完全root权限:
alice ALL=(ALL:ALL) ALL

3、限制alice仅能以www-data身份运行systemctl命令:
alice ALL=(www-data) /bin/systemctl

4、允许组users中的所有成员无需密码执行apt命令:
%users ALL=(ALL) NOPASSWD: /usr/bin/apt

四、检查当前用户sudo权限范围

sudo -l命令用于列出当前用户被授权执行的命令列表,有助于确认配置是否生效及权限边界,避免越权操作或权限不足导致的执行失败。

1、查看当前用户所有可用sudo命令:
输入 sudo -l,系统将提示输入密码(若未启用NOPASSWD)并显示授权详情。

2、以特定用户身份检查其sudo权限:
输入 sudo -l -U username,例如 sudo -l -U bob,需当前用户具备对bob的sudo查看权限。

五、su与sudo的关键区别对比

su依赖目标用户密码,切换后完全获得该用户全部权限与环境;sudo基于原始用户身份认证,按策略授予最小必要权限,支持命令级控制、日志审计与超时密码缓存,更符合最小权限原则与安全合规要求。

1、认证方式不同:
su要求输入目标用户的密码;sudo要求输入当前用户的密码(除非配置NOPASSWD)。

2、权限粒度不同:
su提供全用户会话接管能力;sudo可精确到单个命令、参数范围甚至运行用户

3、日志与审计支持不同:
su默认仅记录登录事件;sudo默认将每次执行写入/var/log/auth.log,包含调用者、目标用户、命令及时间戳。

相关专题

更多
switch语句用法
switch语句用法

switch语句用法:1、Switch语句只能用于整数类型,枚举类型和String类型,不能用于浮点数类型和布尔类型;2、每个case语句后面必须跟着一个break语句,以防止执行其他case的代码块,没有break语句,将会继续执行下一个case的代码块;3、可以在一个case语句中匹配多个值,使用逗号分隔;4、Switch语句中的default代码块是可选的等等。

513

2023.09.21

Java switch的用法
Java switch的用法

Java中的switch语句用于根据不同的条件执行不同的代码块。想了解更多switch的相关内容,可以阅读本专题下面的文章。

401

2024.03.13

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

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

1343

2023.06.21

如何安装LINUX
如何安装LINUX

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

698

2023.06.29

linux find
linux find

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

293

2023.06.30

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

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

771

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

571

2023.07.06

linux删除文件夹的方法
linux删除文件夹的方法

linux删除文件夹的方法:1、使用rm -r命令;2、使用rm -rf命令;3、使用find命令结合rm命令;4、使用图形界面。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

969

2024.02.23

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

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

精品课程

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

共48课时 | 5.9万人学习

Git 教程
Git 教程

共21课时 | 2.2万人学习

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

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