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

Linux 备忘录 - 05. 用户与权限

ahcoder 2025-02-08 09:52 20 浏览

一、用户管理

管理用户组信息:

# 创建用户组
groupadd liwygroup
# 删除用户组
groupdel liwygroup
# 修改用户组名称
groupmod -n newliwygroup liwygroup

# 查看全部用户组
cat /etc/group

管理用户信息:

# 新增用户,
# 默认在 /home 下创建同名家目录,并创建同名组
useradd liwy
# 创建用户并指定主组、家目录和 shell
useradd -g root -d /home/liwy \
-s /bin/bash liwy

# 修改家目录,并复制全部数据到新目录
usermod -m -d /home/liwy2 liwy
# 修改用户的 shell,nologin 即禁止登陆
usermod -s /sbin/nologin liwy
# 修改用户的用户组
usermod -g liwygroup liwy
# 删除用户并删除家目录
userdel -r liwy
# 修改用户密码
passwd liwy

# 查看全部用户
cat /etc/passwd
# 查看指定用户详细信息
id liwy

切换用户:

# 切换用户,非登陆式切换,
# 不会读取目标用户的配置文件
su liwy2
# 切换用户并启用新的 shell,
# 登陆式切换,会读取目标用户的配置文件
su - liwy2

# 使用 root 权限执行命令
# sudo 命令的权限由 /etc/sudoers 控制
sudo ls
# 使用指定用户权限执行命令
sudo -u liwy2 ls

# 编辑 /etc/sudoers 文件
visudo

二、用户相关配置文件

/etc/passwd 用户信息文件

# 用户名:密码:用户ID:组ID:用户全名\
# :家目录:默认shell
liwy:x:1001:1001::/home/liwy:/bin/bash

/etc/shadow 用户密码信息文件

# 用户名:加密密码:上次密码更改日期\
# :最小密码长度:密码更改间隔\
# :密码不活动期限:账户到期日期:保留字段
liwy:$6$vDi...Xim/:19811:0:99999:7:::

/etc/group 用户组信息文件

# 组名:组密码:组ID:组管理员及其他组成员
liwy1:x:1001:

/etc/sudoers sudo权限配置文件,建议使用 visudo 命令编辑

# 用户名 主机=(可切换的用户) 命令列表

# root 用户可以无限制地在所有主机上\
# 执行所有命令。
root ALL=(ALL) ALL

# %wheel 用户组中的所有用户也可以在\
# 所有主机上执行所有命令。
%wheel ALL=(ALL) ALL

# User1 用户可以无需输入密码执行\
# /usr/bin/apt 和 /usr/bin/yum 命令。
User1 ALL=(ALL) NOPASSWD:/usr/bin/apt,/usr/bin/yum 

三、文件权限详解

通过 ls -l 命令可以查看文件权限的详细信息

-rw-r--r--. 1 root root 0 3月 29 09:18 file.txt
drwxr-xr-x. 2 root root 6 3月 29 09:17 work

1. 各列信息含义

  • 第一列:文件访问权限
  • 第二列:链接数量
  • 第三列:所属用户
  • 第四列:所属用户组
  • 第五列:文件大小

第一列文件访问权限主要由11位组成:

  • 第1位:文件类型,- 普通文件,d 文件夹,l 软链接等
  • 第2位:r 所有者有读权限,- 所有者无读权限
  • 第3位:w 所有者有写权限,- 所有者无写权限
  • 第4位:x 所有者有执行权限,- 所有者无执行权限
  • 第5~7位:所属组的读写执行权限
  • 第8~10位:其他用户的读写执行权限
  • 第11位:SELinux 安全标签

2. 文件权限组成

如上 Linux 中的每个文件和目录都有三组基本权限:

  • 读(r):允许读取文件内容或列出目录中的内容。
  • 写(w):允许修改文件内容或向目录中添加/删除文件。
  • 执行(x):允许执行文件或进入目录。

这些权限针对三种不同的访问者:

  • 所有者(owner):文件的所有者,通常是创建文件的用户。
  • 组(group):文件所属的用户组。
  • 其他(others):系统中的其他所有用户。

权限通常用数字表示,称为“八进制表示法”:

  • 读(r)= 4
  • 写(w)= 2
  • 执行(x)= 1

权限的数字表示是这些值的总和。例如,权限 rwx 的数字表示为 7(4+2+1)。

四、文件权限操作命令

# 列出文件和目录的详细权限信息。
ls -l

# 修改文件权限
# 所有者读写执行权限
# 所属组和其他用户只读权限
chmod 744 filename.txt
# 给所有者增加执行权限
# u:拥有者,g:用户组,
# o:其他用户,a:全部用户
chmod u+x filename.txt

# 更改所有者
chown liwy filename.txt
# 更改文件的所有者和组
chown liwy:liwygroup filename.txt
# 递归更改目录及子目录下所有文件的所有者和组
chown -R liwy:liwygroup /opt/dir

# 更改属组
chgrp liwygroup filename.txt
# 递归更改目录及其子目录下所有文件的属组
chgrp -R liwygroup /opt/dir

五、ACL(访问控制列表)

一种强大的文件系统安全和访问控制机制,它允许管理员对文件和目录的访问权限进行更精细的控制。

# 查看文件的 acl
getfacl /opt/file.txt

# 修改 acl,为用户 liwy 设置文件的读写权限
setfacl -m u:liwy:rw /opt/file.txt

# 为用户组 liwygroup 设置文件的读写权限
setfacl -m g:liwygroup:rw /opt/file.txt

# 设置目录及新创建的子文件权限
setfacl -m d:u:liwy:rwx /opt/liwy

# 递归设置目录及其子文件的 acl 权限
setfacl -R -m u:liwy:rw /opt/liwy

# 删除文件上指定用户的 acl 权限
setfacl -x u:liwenyao file.txt

# 清空文件上的所有 acl 权限
setfacl -b /opt/file.txt

相关推荐

Linux 6.15将更新媒体子系统:高通Iris驱动首次亮相

IT之家3月24日消息,科技媒体phoronix昨日(3月23日)发布博文,报道称Linux6.15内核将于本周启动合并窗口,首批提交的PullRequest请求之一,就...

Ubuntu 25.04发行版登场:Linux 6.14内核,带来多项技术革新

IT之家4月18日消息,科技媒体linuxiac昨日(4月17日)发布博文,报道称代号为PluckyPuffin的Ubuntu25.04发行版正式上线,搭载最新Linu...

WordPress 6.8 版本发布:聚焦性能升级,代号“Cecil”

WordPress6.8版本发布:聚焦性能升级,代号“Cecil”全球最受欢迎的内容管理系统(CMS)WordPress正式推出最新版本6.8,代号“塞西尔”(Cecil),以此致敬传奇钢琴家...

Linus Torvalds接受微软Hyper-V升级 下一代Linux启动会更快

虽然Windows的粉丝和Linux的粉丝经常喜欢进行激烈的键盘大战,但操作系统的制造商们自己也了解彼此的优缺点。毫无疑问,微软也明白这一点,事实上,它甚至鼓励用户尝试Linux,尽管是使用...

Debian 12发布:Linux内核升级6.1(debian更新内核)

IT之家6月11日消息,Debian是最古老的GNU/Linux发行版之一,也是许多其他基于Linux的操作系统的基础,包括Ubuntu、Kali、MX和树莓派OS等。这...

Linux Mint预告新功能:升级Nemo搜索、LMDE 7支持OEM安装

IT之家4月10日消息,LinuxMint发布了最新月度简讯,宣布增强Nemo文件管理器的文件搜索功能、Cinnamon桌面环境开始支持Wayland、LMDE7(LinuxM...

Linux 6.2合并大量网络系统更新:推进Wi-Fi 7和800 Gbps网络

IT之家12月15日消息,Linux6.2合并窗口期内已经确认将会合并大量网络子系统更新。和以往版本相同,Linux6.2内核更新周期在网络功能上有大量的改进,更多的细节可以访问这条...

Linux内核升级实践指南(linux内核怎么升级)

Linux内核升级是一个需要谨慎操作的过程,但掌握正确方法后可以显著提升系统性能、安全性或硬件兼容性。以下是一份详细的实践指南,涵盖主流方法及注意事项:一、准备工作查看当前内核版本bashuname...

Linux又将迎来大版本更新 5.20版可能会被称为Linux 6.0

如果你错过了昨天Linux5.19的发布公告,那么这一消息需要回顾一下:被称为Linux5.20的开发中的内核很可能会被称为Linux6.0。根据LinusTorvalds对现代版本的划分,L...

周六的娱乐就是安装一台OracleLinux虚拟机(一)

每个人有每个人的娱乐方式。老父亲可能喜欢摆弄一些机械工具修修补补。我趁着周六安装一套OracleLinux,寓学于乐。在oracle网站上,下载VirtualBox,现在最新版本是7.0.8。在安装过...

Linux系统下Gaussian 16的安装(linux系统如何安装新软件)

Gaussian是目前使用最多的量子化学计算软件,当前最新的版本为Gaussian16C.01。理论上来说Gaussian并不需要安装,因为高斯一般是不出售源代码的,只有二进制文件,以Gaussi...

「Linux基础」VMWare虚拟机安装CentOS后配置静态ip

在VMWare中安装本地虚拟机CentOS7操作系统,动态IP地址会经常变化,不便于管理与实验。为了便于实验,考虑设置成静态IP地址,目标是本地局域网可以通过NAT网关互相访问,且能连接互联网。由于是...

Win10虚拟机,Hyper-V安装CentOS,一次成功

打开控制面板,选择程序选择启用或关闭Windows功能选中Hyper-V下所有的组件。提示我们需要,重启计算机,保存我们的文件,之后点击“立即重新启动”选择开始菜单,输入Hy,就可以打开虚拟机管理器了...

如何在Windows 10中的Hyper-V虚拟机上安装CentOS Linux

注意双重引导的一种可行且相当不错的替代方法是在虚拟机上安装各种操作系统。Microsoft正式支持CentOS作为Hyper-V的来宾OS,并且在安装时可以很好地集成。自CentOS6.4版以来,用...

安装Linux虚拟机的5个理由,以及不安装的5个原因

虚拟机(VM)允许你在不永久更改计算机的情况下探索Linux。如果你对Linux很好奇,但犹豫是否要尝试,VM提供了一个安全、灵活的解决方案。如果这是你第一次听说虚拟机,虚拟机就像“计算机中的计算机”...