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

跟我学Linux用户管理

ahcoder 2025-01-02 14:06 11 浏览

对于Linux系统而言,其是一个多用户的分时操作系统,为了能够让用户更加合理、安全地使用系统资源,从而产生了用户管理功能。

对于Linux的用户管理来说,主要分为两大块,分别是:用户管理用户组管理

一、用户管理

1.1 用户分类

对于Linux中的用户来说,大致可以分为三类用户,分别是:根用户、普通用户和系统用户。

  • 根用户:根用户也被称为root用户或超级用户,其是权限最大的用户,可以修改和删除任意文件,可以执行任何命令。正因为任何操作都能做,因此每次操作的时候都需要十分小心谨慎,若操作不当,严重的可能会导致系统崩溃。
  • 普通用户:普通用户是Linux系统中的真实用户,可以使用指定的用户名和密码来登录系统,并做有限的操作。对于普通而言,其能够操作的目录一般为Home目录、临时目录等有限的目录。
  • 系统用户:系统用户是某个软件运行时使用的用户,并不能用于登录。

对于用户而言,会有唯一的标识与之对应,也就是所谓的UID。用户类型不同,所对应的UID的范围也不尽相同。其中,根用户的UID为0,普通用户的UID大于500,系统用户的UID在1~499之间。

需要说明一点的是,能够用于登录系统的用户只能为:根用户和普通用户。

如果想查看当前登录用户的信息,可以使用如下命令:

id

假定我使用根用户进行登录,使用该命令后结果如下所示:

从上面的结果可以看出,根用户的UID确实为0。

1.2 配置文件

对于用户管理来说,会涉及到两个配置文件,分别是:/etc/passwd /etc/shadow。其中,/etc/passwd文件用于存储用户信息,/etc/shadow用于存储密码信息。

  • /etc/passwd

我们可以使用cat命令来查看对应的内容,查看结果如下:

从上面可知,尽管每行内容各不同,但是大致可以被 " : " 号分隔为七列,以根用户信息为例来介绍一下每一列的含义:

root:x:0:0:root:/root:/bin/bash
  1. 第一列的root表示用户名,通常情况下,用户名的长度不能超过8个字符,且用户名中不能包含 " : " 号。为了进行兼容,用户名中最好不要包括“.”,应尽量避免使用“-”作为连字符以及以“+”号进行打头
  2. 第二列的x表示密码,在某些系统中该列会用于存放密码。尽管该字段存储的密码不是明文,但是由于该文件对所有用户均可读,因此依然存在一定的风险。所以,很多Linux系统会在这里用x表示,而真正的密码将会被保存到/etc/shadow配置文件中
  3. 第三列的0表示UID,也就是所谓的用户标识号。一般情况下,用户标识号会与用户一一对应。当然,多个用户名也可以对应一个用户标识号,只不过这些用户名不同的用户会被系统当做相同的用户。他们允许有不同的口令、不同的主目录以及不同的登录Shell等。通常情况下, 用户标识号的范围是0~65535。其中,0表示root用户,1~499为保留标识号,被用作系统管理,普通用户标识号从500开始。
  4. 第四列的0表示GID,对应/etc/group配置文件中的一条记录(用户组的唯一标识,后面会进行介绍)
  5. 第五列的root表示描述性信息
  6. 第六列的/root表示当前用户的主目录。对于root用户而言,其主目录就是/root;对于普通用户而言,其主目录就是/home/$username。
  7. 第七列为登录之后执行的shell程序。
  • /etc/shadow

对于/etc/shadow配置文件来说,默认情况下只有根用户才有读取的权限。我们使用根用户登录系统后,执行如下命令来查看shadow配置文件的信息:

cat /etc/shadow

执行结果如下所示:

从执行结果来看,与passwd配置文件的形式类似,均被 " :" 分隔成了若干列。只不过shadow被分隔为9列。下面以根用户信息为例来介绍一下每列的含义:

root:$6$muIugGgRCvmiMW76$neuZuN0JIi4f5CnX9NFODxsC1uT2urtvGvgIWSjNggjF9e13KP.WASaHiVQ7loQLTDm.ueKbTqbOPl5tl7bml1::0:99999:7:::
  1. 第一列的root表示用户名,与/etc/passwd中的用户名相对应。
  2. 第二列的一长串字符表示用户对应的密码。如果该列为“!!”或“*”,表示未设置密码,此时该用户无法登录系统。
  3. 第三列的表示最近修改的天数,此处使用时间戳进行表示,也就是距时间原点(1970年1月1日)经过的天数,这里为空表示最近未进行过修改。如果为18978,则代表2021年12月17日。具体转换可使用“date -d '1970-01-01 18978 days'”命令。
  4. 第四列表示两次修改的时间间隔,此处为0表示随时可以进行修改。
  5. 第五列表示密码的有效天数,默认为99999,也就是273年,可认为是永久有效
  6. 第六列表示失效前多少天进行告警。
  7. 第七列表示密码失效后能够宽限的天数,也就是在密码失效后,用户仍能在多少天内使用失效密码登录系统。如果值为0,表示立即失效;如果值为-1,则表示永远不会失效;如果为10,则表示过期后10天依然能够登录系统。
  8. 第八列表示账号失效的日期。当账号失效时,即使密码有效,也无法登录系统。
  9. 第九列为保留字段,暂未启用。

1.3 常用操作

对于用户的常用操作有:新增用户、设置密码和删除用户。

  • 新增用户

新增用户使用到的命令为:useradd,比如添加一个名为user1的用户,使用到的命令如下所示:

useradd user1

对于该命令而言,大致会做四个操作:

(1)在/etc/passwd和/etc/shadow配置文件中新增一条对应的记录。执行命令后我们可以使用cat命令来查看这两个配置文件:

(2)为该用户创建对应的主目录,其路径为:/home/$username,比如在本例中就是/home/user1,如下所示:

(3)将/etc/skel下的文件拷贝一份到主目录下,在本例中就是/home/user1下。需要说明一下的是,查看文件内容时得用list -al命令:

(4)新建一个与该用户名同名的用户组。

  • 设置密码

对于新增的用户必须进行密码设置,否则无法用于系统登录,此时/etc/shadow配置文件中的密码列为“!!”。设置密码的命令为passwd,以本例来说,其使用到的命令如下:

passwd user1

接着按照系统提示填写密码即可。

需要说明一点的是,在设置密码的过程中,如果你设置的密码很简单,就会有一句“无效的密码: 密码未通过字典检查 - 过于简单化/系统化”的提示。

设置密码后,可以再次使用cat命令来查看/etc/shadow文件:

上面可知,密码列已经有值,表明密码设置成功

  • 删除用户

删除用户使用到的命令为:userdel,以本例来说,对应的命令为:

userdel user1

执行命令后会将/etc/passwd和/etc/shadow配置文件中该用户对应的记录进行删除,使用cat命令查看这两个配置文件的结果如下:

需要说明一下的是,默认情况下,该用户对应的主目录中的内容不会被删除,此时使用list -al命令来查看user1的主目录,如下:

当然,如果想删除该用户的主目录,则需要增加-r参数。

二、用户组管理

Linux之所以提供用户组,其目的在于更加灵活和安全地对用户的权限进行控制。

2.1 配置文件

对于用户组管理而言,其配置文件为:/etc/group。我们使用cat命令来查看/etc/group文件,如下所示:

从上面结果可知,/etc/group配置文件中的记录与/etc/passwd类似,都是使用 " : "分隔成了若干列。以root记录为例说一下这几列的含义。

root:x:0:
  1. 第一列表示用户组名,这里为root
  2. 第二列为密码,与/etc/passwd类似,这里以x进行占位。
  3. 第三列为用户组的唯一标识GID。
  4. 第四列表示组成元,这里为空。

2.2 常用操作

对于用户组的常用操作有两个,分别是:新增用户组和删除用户组。

  • 新增用户组

在添加用户的时候系统默认会创建一个与用户名一样的用户组。其实也可以直接创建用户组,新增用户组的命令是groupadd,后接用户组名称作为其参数。在Linux中,使用/etc/group文件来记录用户组。假设增加group1用户组,对应的命令如下:

groupadd group1

命令执行之后查看/etc/group如下:

从上述结果可知,group1用户组已经被成功添加。

  • 删除用户组

删除用户组使用到的命令为groupdel,以删除group1用户组为例,对应的命令为:

groupdel group1

执行之后,再次使用cat命令查看/etc/group配置文件,结果如下所示:

从上述结果可知,group1用户组已经成功删除。需要说明一点的是,如果该用户组内仍然存在用户时,则无法进行删除。比如上面提到,创建用户时会创建默认的用户组,此时我试图删除user1这个用户组,则会提示无法删除:

到此,用户管理的相关介绍就已经结束,希望对大家有所帮助。

相关推荐

安装 Debian 10 后要做的30件事(安装debian sid)

1.修复CD-ROM错误仅从DVD安装Debian的用户才需要此修复程序,因为从DVD安装Debian之后,每次尝试更新系统时都会出现错误“存储库cdrom没有发行文件”:要解决此错误,请打开“软...

Linux 的 18 个装 B 命令,记得全部搂一遍

1、sl命令你会看到一辆火车从屏幕右边开往左边……安装$sudoapt-getinstallsl运行$sl命令有-alFe几个选项,-aAnaccidentseemsto...

Fedora 39提高虚拟机max_map_count以满足一些Steam游戏

有一个关于Fedora39提升其默认vm的建议正在进行中。max_map_count,以满足通过Valve的SteamPlay在Linux上运行的一些Windows游戏。Fedora工程和指导委员...

Linux面板,宝塔Linux正式版 7.9.4发布

【增加】增加日志审计功能【增加】增加对7z格式压缩包的支持【增加】数据库增加PgSQL管理模型【增加】通知设置-消息通道增加微信公众号模块【增加】创建网站时增加一键部署【增加】完善首页【安全风险】的扫...

真榨干Switch!NS被刷Linux系统超频成功运行鬼泣5和战神等游戏

NS的性能已经是被玩家吐槽的不想再吐槽了,都希望任天堂快出新机。而任天堂高管之前则表示switch的性能完全是够用的,是玩家和开发者要求太高了!那么具体情况是如何呢?用实际例子告诉大家switch的真...

Slimbook Manjaro游戏本发布:RTX 4060显卡,Linux定制系统

IT之家2月16日消息,新款SlimbookManjaro游戏笔记本电脑于近日发布,配备英特尔酷睿i7-13620H处理器、英伟达GeForceRTX4060显卡、15.6...

Alienware高层认为Steam游戏机将会为Linux游戏销量带来30倍提升

Diana认为,随着Steam游戏机的推出,将会有越来越多的开发者在Linux上使用OpenGL来开发游戏。Diana预计将有700多部游戏将在SteamOS上的Steam游戏机上发行,其他平台上于...

通过将PS4注入自编译Linux系统,开发者成功运行Steam游戏

本世代的家用机和上世代的一个重要的区别就是架构十分接近x86,而不是PS3/Xbox360世代的的自有架构Cell、Xenon。自从出世以来关于运行PC游戏的讨论一直没有停息,各路好手也不断的尝试更...

在国产优麒麟(Linux)上使用 Steam 畅玩大型游戏

Steam平台是目前全球最大的综合性数字发行平台之一,由Counter-Strike(CS)的开发公司Valve聘请出的BT软件编写者Bram.Cohen亲自开发创建。原先只是作为...

大神给PS4装了“Linux”系统 竟然还能玩Steam游戏!

PS4游戏虽然挺多,但是对比起Steam平台来说,就有点相形见绌了。这不日前,就有一位国外大神努力研究之后,竟然给PS4装上了Linux系统,这还不是最关键的,关键的是他竟然还成功的在Steam平台玩...

Linux系统之安装Ninvaders太空入侵者小游戏

Linux系统之安装Ninvaders太空入侵者小游戏1.1Ninvaders小游戏简介1.2项目预览2.1本地环境规划2.2本次实践介绍3.1检查系统镜像源3.2更新软件列表4.1安装...

还未正式发售:《文明7》Linux版已经被破解!

在万众瞩目的期待中,《文明7》这一备受期待的策略游戏巨作即将于2月11日(国区则为2月12日)正式发售。对于许多热爱这一系列的玩家而言,这无疑是一个振奋人心的消息。预购了豪华版和奠基者版的幸运儿们,更...

在国产系统(Linux)上,安装运行Steam游戏详解

前言经过多年发展,Linux已经相当成熟!只是一直以来,使用者相对不多,软件、游戏等厂商不够重视。因此,能直接在Linux上玩的游戏不多!但是随着国产化的推进,越来越多的人开始接触和使用Linux,比...

在 V 社和 NVIDIA 的联手下,Linux 游戏体验已经接近 Windows 了

出于一些原因,越来越多的用户不再喜欢Windows系统。但如果你是一名PC玩家,似乎只有Windows一个选择。其实不然,在Windows的阴影下,一个操作系统正在游戏方面暗自发力,等待...

Linux 游戏中间层 Proton 7.0-4 发布:新增《祖玛的复仇》等

IT之家8月21日消息,Proton是一个基于Wine修改版的工具分发,由Valve设计和提供资金,可兼容Windows平台游戏。近日,Proton7.0-4已在GitHu...