Linux用户权限管理命令大全

Linux用户权限管理核心在于控制“谁能动什么”,通过chmod、chown、useradd等命令实现文件权限与用户组管理,结合SUID、SGID、Sticky Bit及sudo机制,确保系统安全与多用户协作高效进行。

linux用户权限管理命令大全

Linux用户权限管理,说白了,就是操作系统层面上的“谁能动什么,怎么动”的规矩。这不仅仅是技术细节,更是系统安全和稳定性的基石,尤其在多用户、多任务的环境下,理解和掌握这些命令,几乎是每个Linux使用者,无论是运维、开发还是普通用户,都绕不开的一道坎。它决定了你的文件是私密还是共享,你的程序是安全运行还是处处受限。

解决方案

谈到Linux用户权限管理,核心命令其实就那么几个,但它们组合起来能玩出很多花样。我个人觉得,理解这些命令的“意图”比死记硬背参数更重要。

首先是文件和目录的权限管理,这块是基础中的基础:

chmod

(change mode):这个命令用来改变文件或目录的权限。权限分为读(r)、写(w)、执行(x),分别对应数字4、2、1。我们通常用八进制数字来表示用户(u)、组(g)和其他人(o)的权限。示例:

chmod 755 script.sh

。这表示文件所有者(u)有读写执行权限(4+2+1=7),文件所属组(g)和其他人(o)只有读和执行权限(4+1=5)。个人看法: 我更喜欢用符号模式,比如

chmod u+x,g-w file.txt

,感觉更直观,尤其在只修改某一部分权限时。但对于全新设置,数字模式效率更高。

chown

(change owner):改变文件或目录的所有者。示例:

chown user1:group1 file.txt

。这会将

file.txt

的所有者改为

user1

,所属组改为

group1

小贴士: 经常会遇到

chown -R

递归修改整个目录树的情况,但要小心,别把系统关键文件的所有者改错了。

chgrp

(change group):专门改变文件或目录的所属组。虽然

chown

也能做,但

chgrp

在某些脚本里可能更明确。示例:

chgrp newgroup file.txt

接着是用户和用户组的管理,这是构建多用户环境的关键:

useradd

:创建新用户。示例:

useradd -m -s /bin/bash newuser

-m

会自动创建家目录,

-s

指定默认shell。经验之谈: 别忘了创建密码,否则用户是登录不了的。

passwd newuser

紧随其后是常态。

userdel

:删除用户。示例:

userdel -r olduser

-r

选项会一并删除用户的家目录和邮件池。注意: 删除用户前,最好确认该用户没有重要文件或正在运行的服务。

usermod

:修改用户属性。示例:

usermod -g newgroup -G anothergroup -s /bin/sh existinguser

。修改主组、附加组和shell。个人心得:

usermod -aG

是我最常用的,用来把用户添加到某个附加组,而不会覆盖掉其他附加组。

groupadd

:创建新用户组。示例:

groupadd devteam

groupdel

:删除用户组。示例:

groupdel oldgroup

groupmod

:修改用户组属性。示例:

groupmod -n newname oldname

。修改组名。

然后是权限提升和身份切换:

sudo

(superuser do):以其他用户(通常是root)的身份执行命令。这是日常管理中最常用,也最安全的权限提升方式。示例:

sudo apt update

安全提示:

sudo

的配置 (

/etc/sudoers

) 至关重要,它决定了谁能用

sudo

,能执行哪些命令。错误的配置可能导致严重的安全漏洞。

su

(switch user):切换用户身份。示例:

su - root

。切换到root用户,并加载root的环境变量。区别

su

切换后需要目标用户的密码,而

sudo

只需要当前用户的密码(如果配置允许)。在服务器上,我更倾向于

sudo

,因为它有更好的审计日志。

最后是一些辅助查看命令:

id

:显示用户的UID、GID以及所属的所有组。示例:

id username

whoami

:显示当前有效的用户名。

ls -l

:查看文件或目录的详细信息,包括权限、所有者和所属组。

这些命令构成了Linux权限管理的核心骨架。理解它们,基本上就能应对绝大多数的权限问题了。

如何理解Linux文件与目录权限的rwx含义?

说起Linux的权限,

rwx

这三个字母简直是基石,它们分别代表着读(read)、写(write)、执行(execute)。但光知道这三个字面意思还不够,关键在于它们在文件和目录上,有着截然不同的“行为模式”。这对我来说,是初学时最容易混淆的地方,直到真正踩过坑,才算彻底搞明白。

对于文件:

r (读):很简单,就是允许你查看文件的内容。比如

cat

more

less

命令,或者用文本编辑器打开它。没有读权限,文件内容对你来说就是个黑箱。w (写):允许你修改或删除文件的内容。你可以用编辑器保存对文件的修改,或者直接删除这个文件(前提是你对文件所在的目录有写权限,这一点很重要,下面会说)。x (执行):这表示文件可以被当作一个程序来运行。对于脚本文件(如

.sh

),没有

x

权限,即使内容写得再好,你也无法直接

./script.sh

来运行它。它只会是个普通的文本文件。

对于目录:

这里就有点意思了,目录的

rwx

和文件的含义大相径庭:

r (读):允许你列出目录下的文件和子目录名称。比如

ls

命令,没有这个权限,你甚至不知道目录里有什么。但你不能进入目录。w (写):这是最“危险”的权限。它允许你在目录中创建、删除、重命名文件和子目录,甚至移动目录中的文件。注意,即使你对某个文件没有写权限,但如果你对它所在的目录有写权限,你仍然可以删除这个文件!这就是为什么有时候你无法修改一个文件,但却能把它删掉的原因。x (执行):这个权限对于目录来说,通常被称为“搜索”或“进入”权限。没有它,你无法

cd

进入这个目录,也无法访问目录下的任何文件或子目录,即使你知道文件的完整路径。这有点像一个锁住的门,你知道门后面有东西,但你进不去。

八进制表示法:

为了方便,我们把

rwx

映射成数字:

r=4

,

w=2

,

x=1

。这样,一个权限组合就可以用一个数字来表示:

rwx

= 4+2+1 = 7

rw-

= 4+2+0 = 6

r-x

= 4+0+1 = 5

r--

= 4+0+0 = 4

---

= 0+0+0 = 0

当我们看到

chmod 755 file.sh

,它意味着:

第一个

7

(4+2+1):文件所有者拥有读、写、执行权限。第二个

5

(4+0+1):文件所属组拥有读、执行权限,但不能修改。第三个

5

(4+0+1):其他用户拥有读、执行权限,也不能修改。

理解这些细微的差别,对于排查“为什么我不能访问这个文件?”或者“为什么我不能运行这个脚本?”这类问题,至关重要。我曾经因为一个目录没有

x

权限,导致Web服务器无法读取其中的静态文件,排查了半天,才发现是这个小细节。

除了基本权限,Linux还有哪些高级权限设置?

当基本的用户、组和文件权限(rwx)无法满足复杂场景的需求时,Linux系统还提供了一些“高级”权限机制。这些机制虽然不如

chmod

那么常用,但在特定场景下,它们能提供更精细的控制和更高的安全性。我主要想聊聊三个比较重要的:SUID、SGID和Sticky Bit,以及一个更复杂的ACL。

1. SUID (Set User ID)

这个权限只对可执行文件有效,并且它是个非常强大的功能。当一个设置了SUID位的文件被执行时,无论执行它的用户是谁,程序都将以文件所有者的权限来运行,而不是执行者的权限。

标识:

ls -l

输出中,文件所有者权限的

x

位会变成

s

(如果所有者有执行权限) 或

s

(如果所有者没有执行权限)。作用: 最经典的例子就是

passwd

命令。

passwd

文件通常属于

root

用户,并设置了SUID位。这样,普通用户执行

passwd

命令时,程序会以

root

用户的身份运行,从而能够修改

/etc/shadow

文件(存储用户密码的加密文件),而这个文件普通用户是没有权限直接修改的。潜在风险: 如果一个恶意程序被设置了SUID,并且其所有者是

root

,那么任何用户执行它都将获得

root

权限,这无疑是一个巨大的安全漏洞。因此,系统管理员需要非常谨慎地管理带有SUID位的文件。

2. SGID (Set Group ID)

乾坤圈新媒体矩阵管家 乾坤圈新媒体矩阵管家

新媒体账号、门店矩阵智能管理系统

乾坤圈新媒体矩阵管家 17 查看详情 乾坤圈新媒体矩阵管家

SGID有两种应用场景,分别针对文件和目录:

对于可执行文件: 类似SUID,当一个设置了SGID位的可执行文件被执行时,程序会以文件所属组的权限来运行,而不是执行者所在的主组。标识:

ls -l

输出中,文件所属组权限的

x

位会变成

s

(如果所属组有执行权限) 或

s

(如果所属组没有执行权限)。对于目录: 这是SGID更常见的应用。当一个目录设置了SGID位后,任何在该目录中创建的新文件或子目录,其所属组都会自动继承父目录的所属组,而不是创建者用户的默认组。标识:

ls -l

输出中,目录所属组权限的

x

位会变成

s

作用: 在多用户协作环境中非常有用。比如一个项目组

devteam

,所有成员都在

/project

目录下工作。如果

/project

目录设置了SGID,那么无论哪个成员创建文件,新文件的所属组都会是

devteam

,方便组内成员共享和协作。

3. Sticky Bit (粘滞位)

Sticky Bit主要用于目录,它的目的是为了防止非所有者用户删除或重命名目录中的文件,即使这些用户对目录有写权限。

标识:

ls -l

输出中,其他用户权限的

x

位会变成

t

(如果其他用户有执行权限) 或

t

(如果其他用户没有执行权限)。作用: 最典型的例子就是

/tmp

目录。

/tmp

目录是所有用户都可以读写执行的,任何用户都可以在其中创建文件。但由于

/tmp

目录设置了Sticky Bit,用户只能删除或重命名自己创建的文件,而不能删除或重命名其他用户创建的文件。这有效防止了用户之间互相干扰,确保了临时文件的隔离性。

如何设置这些特殊权限:

使用

chmod

命令,通过数字模式或符号模式。

数字模式: 在三位八进制权限数字前加一位,代表特殊权限。

4

表示 SUID

2

表示 SGID

1

表示 Sticky Bit示例:

chmod 4755 file

(设置SUID),

chmod 2775 dir

(设置SGID),

chmod 1777 /tmp

(设置Sticky Bit)。符号模式:

chmod u+s file

(设置SUID)

chmod g+s dir

(设置SGID)

chmod +t /tmp

(设置Sticky Bit)

这些高级权限,虽然在日常操作中不常用,但在构建安全的、多用户协作的系统时,它们是不可或缺的工具。理解它们的原理和用途,能让你在面对复杂的权限需求时,有更多的选择和更精准的控制力。

在多用户协作环境中,如何高效管理用户和用户组?

在多用户协作的场景下,尤其是在服务器或开发环境中,用户和用户组的管理就不仅仅是“创建几个用户”那么简单了。它涉及到权限的隔离、资源的共享以及操作的审计。我个人觉得,高效管理的关键在于“合理规划”和“灵活运用”那些基础命令。

1. 规划先行:明确职责与权限边界

在动手之前,花点时间思考:

谁需要访问什么? 哪些用户需要访问哪些目录、哪些文件、哪些服务?权限级别是什么? 是只读、读写、还是完全控制?有哪些协作小组? 比如开发组、测试组、运维组,他们之间需要共享哪些资源?

有了这个蓝图,你就能更好地设计用户和组的结构,避免后期频繁调整。

2. 巧用用户组:实现权限共享与隔离

用户组是实现权限共享和隔离的利器。与其给每个用户单独设置文件权限,不如将相关用户加入到一个组中,然后对组设置权限。

创建用户组 (

groupadd

):示例:

groupadd developers

groupadd testers

实践: 尽可能根据项目或团队职能来划分组。创建用户并指定主组 (

useradd

):示例:

useradd -m -g developers -s /bin/bash dev_user1

。这里

-g

指定了用户的主组。每个用户都有一个主组,新创建的文件通常会继承主组的权限。将用户添加到附加组 (

usermod -aG

):示例:

usermod -aG testers dev_user1

dev_user1

既属于

developers

组(主组),又属于

testers

组(附加组)。这样,

dev_user1

就能访问

developers

组和

testers

组共享的资源。关键点:

-aG

是个非常重要的组合,它表示“追加到附加组”,而不是覆盖已有的附加组。如果只用

-g

,会覆盖掉用户所有的附加组,这在生产环境里可能是个灾难。修改文件/目录的所属组 (

chgrp

chown

):示例:

chgrp developers /var/www/project_repo

。将项目代码仓库的所属组设为

developers

配合 SGID: 如果

/var/www/project_repo

目录设置了SGID (

chmod 2775 /var/www/project_repo

),那么

developers

组的成员在这个目录下创建的任何新文件,其所属组都会自动是

developers

,极大地方便了组内协作。

3. 权限委派:使用

sudo

替代

root

直登

在协作环境中,直接共享

root

密码是绝对不可取的。

sudo

是更安全的权限委派方式。

配置

/etc/sudoers

通过

visudo

命令编辑

sudoers

文件,可以精细地控制哪些用户或组可以执行哪些命令,以及是否需要密码。示例:

dev_user1 ALL=(ALL) /usr/bin/systemctl restart nginx

。这允许

dev_user1

root

权限重启

nginx

服务,但仅限于这个命令。思考: 我通常会创建一个

sudoers

组,然后把需要执行特权命令的用户加入这个组,再在

sudoers

文件中给这个组配置权限,这样管理起来更集中。

4. 审计与监控:了解谁做了什么

虽然不是直接的权限管理命令,但审计日志对于多用户环境至关重要。

/var/log/auth.log

(或类似文件): 记录用户登录、

sudo

命令执行等安全相关事件。定期查看这些日志,有助于发现异常行为。

高效的用户和用户组管理,本质上是一种平衡艺术:在确保系统安全的前提下,最大限度地提升团队协作的便利性。它不是一劳永逸的配置,而是需要根据团队发展和项目需求持续调整和优化的过程。

以上就是Linux用户权限管理命令大全的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/433196.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
Linux系统性能监控工具_Linuxsar、iotop和perf使用详解
上一篇 2025年11月7日 15:02:37
鬼谷八荒新手开局玩法介绍-鬼谷八荒各种系统简介
下一篇 2025年11月7日 15:02:48

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    900
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    000
  • Debian syslog性能优化技巧有哪些

    提升Debian系统syslog (通常基于rsyslog)性能,关键在于精简配置和高效处理日志。以下策略能有效优化日志管理,提升系统整体性能: 精简配置,高效加载: 在rsyslog配置文件中,仅加载必要的输入、输出和解析模块。 使用全局指令设置日志级别和格式,避免不必要的处理。 自定义模板: 创…

    2026年5月10日
    000
  • 怎么在PHP代码中实现图片上传功能_PHP图片上传功能实现与安全处理教程

    首先创建含enctype的HTML表单,再用PHP接收文件,检查目录、移动临时文件,验证类型与大小,生成唯一文件名,并调整php.ini限制以确保上传成功。 如果您尝试在PHP项目中添加图片上传功能,但服务器无法正确接收或保存文件,则可能是由于表单配置、文件处理逻辑或安全限制的问题。以下是实现该功能…

    2026年5月10日
    100
  • 比特币新手教程 比特币交易平台有哪些

    比特币是一种去中心化的数字货币,基于区块链技术实现点对点交易,具有匿名性、有限发行和不可篡改等特点;新手可通过交易所购买,P2P交易获得比特币,常用平台包括Binance、OKX和Huobi;交易流程包括注册账户、实名认证、绑定支付方式、充值法币并下单购买,可选择市价单或限价单;比特币存储方式有交易…

    2026年5月10日
    000
  • c++中的SFINAE技术是什么_c++模板编程中的SFINAE原理与应用

    SFINAE 是“替换失败不是错误”的原则,指模板实例化时若参数替换导致错误,只要存在其他合法候选,编译器不报错而是继续重载决议。它用于条件启用模板、类型检测等场景,如通过 decltype 或 enable_if 控制函数重载,实现类型特征判断。尽管 C++20 引入 Concepts 简化了部分…

    2026年5月10日
    000
  • 修复点击时按钮抖动:CSS垂直对齐实践

    本文探讨了在Web开发中,交互式按钮(如播放/暂停按钮)在点击时发生意外垂直位移的问题。通过分析CSS样式变化对元素布局的影响,我们发现这是由于按钮不同状态下的边框样式和内边距改变,以及默认的垂直对齐行为共同作用所致。核心解决方案是利用CSS的vertical-align属性,将其设置为middle…

    2026年5月10日
    000
  • 理解编程指令:当结果正确,但实现方式不符要求时

    本文探讨了在编程实践中,即使程序输出了正确的结果,但若其实现方式未能严格遵循既定指令,仍可能被视为“不正确”的问题。我们将通过具体示例,对比直接求和与累加求和两种实现策略,强调理解和遵守编程规范的重要性,以确保代码的健壮性、可维护性及符合项目要求。 在软件开发过程中,我们经常会遇到这样的情况:编写的…

    2026年5月10日
    000
  • Golang goroutine与channel调试技巧

    使用go run -race检测数据竞争,结合runtime.NumGoroutine监控协程数量,通过pprof分析阻塞调用栈,利用select超时避免永久阻塞,有效排查goroutine泄漏、死锁和数据竞争问题。 Go语言的goroutine和channel是并发编程的核心,但它们也带来了调试上…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • php常量怎么用_PHP常量(define/const)定义与使用方法

    PHP中可通过define函数和const关键字定义常量,用于存储不可变值。define适用于全局作用域,支持动态名称和条件定义,如define(‘SITE_NAME’, ‘MyWebsite’);const在编译时生效,语法简洁但限制多,只能在类或全…

    2026年5月10日
    000
  • 网站标题关键词更新后,搜索引擎为何仍显示旧标题?

    网站标题更新后,搜索引擎为何显示旧标题? 网站SEO优化中,站长常修改网站标题关键词,期望搜索结果显示自定义标题。然而,即使更新标签、meta keywords、meta description和结构化数据中的name属性后,搜索结果仍显示旧标题,这令人费解。本文将对此进行解释。 问题:站长修改了网…

    2026年5月10日
    100
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • 如何插入查询结果数据_SQL插入Select查询结果方法

    如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法如何插入查询结果数据_SQL插入Select查询结果方法

    使用INSERT INTO…SELECT语句可高效插入数据,通过NOT EXISTS、LEFT JOIN、MERGE语句或唯一约束避免重复;表结构不一致时可通过别名、类型转换、默认值或计算字段处理;结合存储过程可提升可维护性,支持参数化与动态SQL。 将查询结果数据插入到另一个表中,可以…

    2026年5月10日 用户投稿
    000
  • Discord.py 交互按钮超时与持久化解决方案

    本教程旨在解决Discord.py中交互按钮在一段时间后出现“This Interaction Failed”错误的问题。我们将深入探讨视图(View)的超时机制,并提供通过正确设置timeout参数以及利用bot.add_view()方法实现按钮持久化的具体方案,确保您的机器人交互功能稳定可靠,即…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • c++如何实现UDP通信_c++基于UDP的网络通信示例

    UDP通信基于套接字实现,适用于实时性要求高的场景。1. 流程包括创建套接字、绑定地址(接收方)、发送(sendto)与接收(recvfrom)数据、关闭套接字;2. 服务端监听指定端口,接收客户端消息并回传;3. 客户端发送消息至服务端并接收响应;4. 跨平台需处理Winsock初始化与库链接,编…

    2026年5月10日
    000
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • JavaScript函数中插入加载动画(Spinner)的正确方法

    本文旨在解决在JavaScript函数中插入加载动画(Spinner)时遇到的异步问题。通过引入async/await和Promise.all,确保在数据处理完成前后正确显示和隐藏加载动画,提升用户体验。我们将提供两种实现方案,并详细解释其原理和优势。 在Web开发中,当执行耗时操作时,显示加载动画…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信