百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

从零入门Linux(四)用户与权限管理

ahcoder 2025-03-25 10:19 20 浏览

在 Linux 系统中,用户和权限管理是系统安全的重要组成部分。通过合理配置用户和权限,可以确保系统的安全性和资源的合理分配。以下是一些与用户和权限管理相关的常用命令和概念。

1. 用户管理

1.1 添加用户

使用 useradd 命令可以添加新用户:

sudo useradd username

1.2 设置用户密码

使用 passwd 命令可以为用户设置密码:

sudo passwd username

1.3 修改用户属性

使用 usermod 命令可以修改用户的属性:

sudo usermod -l new_username old_username  # 修改用户名
sudo usermod -d /new/home/directory username  # 修改用户的家目录
sudo usermod -aG groupname username  # 将用户添加到附加组

1.4 删除用户

使用 userdel 命令可以删除用户:

sudo userdel username  # 删除用户,保留家目录
sudo userdel -r username  # 删除用户及其家目录

2. 组管理

2.1 添加组

使用 groupadd 命令可以添加新组:

sudo groupadd groupname

2.2 修改组属性

使用 groupmod 命令可以修改组的属性:

sudo groupmod -n new_groupname old_groupname  # 修改组名

2.3 删除组

使用 groupdel 命令可以删除组:

sudo groupdel groupname

3. 权限管理

3.1 查看权限

使用 ls -l 命令可以查看文件或目录的权限:

ls -l file.txt

3.2 修改权限

使用 chmod 命令可以修改文件或目录的权限:

chmod 755 file.txt  # 设置权限为 rwxr-xr-x
chmod u+x file.txt  # 给所有者添加执行权限

3.3 修改所有者和组

使用 chown 和 chgrp 命令可以修改文件或目录的所有者和组:

chown user:group file.txt  # 修改所有者和组
chgrp groupname file.txt  # 修改组

4. 特殊权限

4.1 SUID(Set User ID)

当文件被执行时,进程的所有者变为文件的所有者:

chmod u+s file

4.2 SGID(Set Group ID)

当文件被执行时,进程的组变为文件的组;当应用于目录时,新创建的文件将继承目录的组:

chmod g+s file

4.3 Sticky Bit

只有文件的所有者或 root 用户才能删除或重命名文件:

chmod +t directory

5. 默认权限

新创建的文件和目录的默认权限由 umask 值决定。umask 是一个掩码,用于屏蔽权限位。

查看当前 umask 值:

umask

设置 umask 值:

umask 022  # 新文件的权限为 644,新目录的权限为 755

6. ACL(访问控制列表)

ACL 提供了更细粒度的权限控制,允许为特定用户或组设置权限。

6.1 查看 ACL

getfacl file.txt

6.2 设置 ACL

setfacl -m u:username:rwx file.txt  # 为用户设置权限
setfacl -m g:groupname:rwx file.txt  # 为组设置权限
setfacl -x u:username file.txt  # 移除用户的 ACL 条目

7. 用户切换

7.1 切换用户

使用 su 命令可以切换用户:

su username  # 切换到指定用户
su - username  # 切换到指定用户并加载其环境变量

7.2 以其他用户身份执行命令

使用 sudo 命令可以以其他用户(通常是 root)身份执行命令:

sudo command  # 以 root 身份执行命令
sudo -u username command  # 以指定用户身份执行命令

8. 用户和组配置文件

8.1/etc/passwd

存储用户信息:

username:x:UID:GID:comment:home_directory:shell

8.2/etc/shadow

存储用户密码信息:

username:encrypted_password:last_change:min_age:max_age:warn:inactive:expire:reserved

8.3/etc/group

存储组信息:

groupname:x:GID:user_list

相关推荐

KaOS 2025.05版本发布:全面拥抱Qt6,彻底告别Qt5

KaOSLinux2025.05版本重磅发布:全面拥抱Qt6,开启KDE生态新篇章继2025.03版本发布两个月后,专注于KDE桌面环境、采用XFS文件系统的滚动发行版Li...

基于FIMC接口的CMOS摄像头驱动分析与设计

摘要:目前的嵌入式系统中,USB摄像头使用比较普遍,但其应用会受到传输速度的限制。本文采用一款高速CMOS摄像头,其驱动利用S3C6410内置的FIMC接口技术,采用DMA和ping-pong缓冲...

没错是微软 推出基于Linux的交换机系统

2015-09-2205:59:59作者:郑伟你没看错,为了提升自身Azure云数据中心内网络设备的兼容性及开放性,微软也开始推出基于Linux的网络交换机系统了。这个被称为AzureCloud...

Linus Torvalds 宣布首个 Linux 内核 6.16 候选版本

Linux内核负责人兼创始人LinusTorvalds宣布关闭合并窗口,该窗口用于将主要新功能添加到内核中,并开始发布Linux6.16候选版本,从候选版本1(Linux6.16-r...

Linux内核漏洞将影响Haswell架构服务器

在infoq网站上,GilTene最近报告一个十分重要,但并不为人知Linux内核补丁,特别对采用Haswell架构的Linux系统用户和管理员应该特别关注。报告提醒RedHat发行版的用户(包括...

关于Linux性能调优中网络I/O的一些笔记

写在前面和小伙伴分享一些Linux网络优化的笔记,内容很浅,可以用作入门博文内容结合《Linux性能优化》读书笔记整理涉及内容包括常用的优化工具(mii-tool,ethtool,ifconfig,i...

国产操作系统- Veket Linux(国产操作系统之光银河麒麟阅读理解)

VeketLinux是一个随身的可装在U盘的Linux操作系统。主要面向桌面用户。它的设计重点是提供简单易用且稳定的操作系统,同时保持更新和开发。它具有强大的功能集和广泛的用户基础,可满足...

AlmaLinux 9.6发布:升级工具、初步支持IBM Power虚拟化技术

IT之家5月21日消息,科技媒体linuxiac昨日(5月20日)发布博文,报道称代号为SageMargay的AlmaLinux9.6发行版已上线,距上一版本9.5发...

跟老韩学Linux运维架构师系列,vim与view的基本使用

下面是vim和view的10个实例:用vim打开一个新文件:vimnewfile.txt这个命令将会在vim编辑器中打开一个新文件。在vim中移动光标:使用方向键或h、j、k、l键来移动光标。在v...

malloc底层原理剖析——ptmalloc内存池

malloc底层为什么是内存池malloc大家都用过,其是库函数。我们都知道库函数在不同的操作系统中其实执行的是系统调用,那么malloc在Linux上执行的是哪个系统调用呢?brk()和mmap()...

Zen 6架构首秀Linux,AMD加速下一代处理器布局

IT之家5月15日消息,科技媒体Phoronix昨日(5月14日)发布博文,报道称AMD已经开始为下一代“Zen6”处理器做准备,已为该构架向Linux内核提交了首个补丁,...

为何越来越多企业转向安卓/Linux工业平板电脑?答案在这里

在工业领域,设备的稳定性至关重要,尤其是工业平板电脑,常年运行在高温、粉尘、潮湿等复杂环境下,一旦系统崩溃或者卡顿,可能会影响整个生产流程。那么,为什么越来越多的企业选择安卓/Linux工业平板电脑,...

从3ms到0.8ms:ARM+Linux如何重塑工业控制实时性标杆

在智能制造领域,产线控制系统对实时性的要求越来越高。根据行业调研数据,超过65%的工业现场出现过因系统响应延迟导致的故障停机,平均每次停机造成的直接损失高达2-8万元。传统x86架构搭配Windows...

看Linux如何"挖坑种树"

写在前面,有人看我的Linux文章说技术难度不深,笔者不是不想写深,笔者是觉得Linux难就难在入门,入门之后你就知道如何上网查询你所要要解决的Linux需求。如果你已入门,此文已对你无用,请略过此...

AlmaLinux 9.6 发布,新增功能亮点纷呈!

距离上一版本AlmaLinux9.5发布六个月后,基于5.14内核的AlmaLinux正式宣布其企业级Linux发行版的9.x系列第六个更新——AlmaLinux9.6(Sag...