当前位置:首页 > 天道酬勤 > 正文内容

linux(linux用户权限设置)

张世龙2021年12月07日 17:46天道酬勤1310

概述

Linux/Unix是一个用户多任务操作系统;在讲Linux账号和账号组管理之前,先简单了解一下多用户多任务操作系统的基本概念。

linux系统用户和权限示意图

00-1010在Linux下,伤心的太阳登录后,还可以同时启动很多服务任务和进程,每个服务都可以运行得非常好,对其他任务没有任何影响。一个用户登录系统执行多个服务任务和进程的这种情况称为单用户多任务。

00-1010有时候可能是很多用户同时使用同一个系统,比如公司里有几十个运维人员,每台机器都可以由几个运维人员来部署或者解决,但是并不是所有的运维人员都要做同样的事情,所以就出现了多任务多用户的情况。

值得注意的是,多用户、多任务并不都是同时挤在一起的,他们是冲着一台机器的键盘和显示器来操作机器的。多用户可以通过SSH客户端工具等远程工具远程登录服务器,例如控制服务器的运行。只要拥有相关用户的权限,任何人都可以操作和访问服务器。

Linux的单用户多任务

可以说是linux系统中最重要的文件之一。没有这两个文件或者这两个文件有问题,就无法正常登录linux系统。

1./etc/passwd文件

# cat /etc/passwd | head

PS:“|”前面的“|”是一个管道字符,用于将前一个命令的输出输入到后一个命令中。

/etc/passwd '被' : '分成7个字段,每个字段的具体含义是:

1)用户名(例如,第一行中的root是用户名),代表用户帐户的字符串。用户名字符可以是大小写字母、数字、减号(不能出现在第一位)、点和下划线,其他字符都是非法的。虽然用户名中可以出现点,但不建议使用,尤其是第一位数字是点的时候,不建议使用减号,因为容易造成混淆。

2)存储的是该账户的密码。为什么是x?早期的unix系统密码确实存储在这里,但出于安全原因,后来它被存储在“/etc/shadow”中,在那里只使用了一个“x”。

3)该号码代表用户标识号,也称为uid。系统通过这个号码识别用户,0是root,也就是说你可以把测试用户的uid改成0,那么系统就会认为root和test是同一个账号。通常uid的范围是0~65535(但实际上可以支持4294967294),0是root的标识号,1~499是系统预留的。作为管理账号,幸福龙猫的识别号从500开始。如果我们自己建一个快乐龙猫,你会看到这个账号的识别号大于等于500。

4)表示组标识号,也称为gid。此字段对应于/etc/group中的记录。实际上,/etc/group和/etc/passwd基本相似。

5)注意这个字段没有实际意义,通常记录用户的一些属性,如姓名、电话、地址等。但是,当悲伤的太阳使用手指的功能时(稍后将介绍),会显示这些信息。

6)用户的主目录,即用户登录时的目录。Root的主目录是/root,开心龙猫的主目录是/home/username。此字段可以自定义。例如,如果您创建了一个快乐的龙猫test1,如果您希望test1的主目录位于/data目录中,只需将/etc/passwd文件中test1行中的字段修改为/data即可。

7)shell,用户登录后,启动一个进程,将用户发出的指令传递给内核,也就是shell。Linux的外壳有很多种,如sh、csh、ksh、tcsh、bash等。而红帽/CentOS的外壳是bash。检查/etc/passwd文件,此字段中的/ka除外。

dqq/bash外还有/skadqq/nologin比较多,它表示不允许该账号登录。如果你想建立一个账号不让他登录,那么就可以把该字段改成/skadqq/nologin,默认是/kadqq/bash.

2、/etc/shadow文件

这个文件,和/etc/passwd类似,用 ‘:’ 分割成9个字段。

#cat /etc/shadow |head -n 3

每个字段的含义是:

1)用户名,跟/etc/passwd对应。

2)用户密码,这个才是该账号的真正的密码,不过这个密码已经加密过了,但是有些黑客还是能够解密的。所以,该文件属性设置为000,但是root账户是可以访问或更改的。

[root@localhost ~]# ls -l /etc/shadow ---------- 1 root root 719 5月 10 09:02 /etc/shadow

3)上次更改密码的日期,这个数字是这样计算得来的,距离1970年1月1日到上次更改密码的日期,例如上次更改密码的日期为2012年1月1日,则这个值就是 ‘365 x (2012-1970) + (2012-1970)/4 + 1 = 15341’. 因为如果是闰年,则有366天。

4)要过多少天才可以更改密码,默认是0,即不限制。

5)密码多少天后到期。即在多少天内必须更改密码,例如这里设置成30,则30天内必须更改一次密码,否则将不能登录系统,默认是99999,可以理解为永远不需要改。

6)密码到期前的警告期限,若这个值设置成7,则表示当7天后密码过期时,系统就发出警告告诉用户,提醒用户他的密码将在7天后到期。

7)账号失效期限。你可以这样理解,如果设置这个值为3,则表示:密码已经到期,然而用户并没有在到期前修改密码,那么再过3天,则这个账号就失效了,即锁定了。

8)账号的生命周期,跟第三段一样,是按距离1970年1月1日多少天算的。它表示的含义是,账号在这个日期前可以使用,到期后账号作废。

9)作为保留用的,没有什么意义。


新增/删除用户和用户组

1、新增一个组

命令 : groupadd

语法 : groupadd [-g GID] groupname

[root@localhost ~]# groupadd grptest1 [root@localhost ~]# tail -n1 /etc/group grptest1:x:502:

不加 “-g” 选项则按照系统默认的gid创建组,跟用户一样,gid也是从500开始的。

[root@localhost ~]# groupadd -g 511 grptest2 [root@localhost ~]# tail -n2 /etc/group grptest1:x:502: grptest2:x:511:

“-g” 选项可以自定义gid.

2、删除组

命令 : groupdel

[root@localhost ~]# groupdel grptest2 [root@localhost ~]# tail -n3 /etc/group testgroup:x:500: user1:x:501: grptest1:x:502:

该命令没有特殊选项,但有一种情况不能删除组:

[root@localhost ~]# groupdel user1 groupdel: cannot remove the primary group of user 'user1'

这是因为user1组中包含user1账户,只有删除user1账户后才可以删除该组。

3、增加账户

命令 : useradd

语法 : useradd [-u UID] [-g GID] [-d HOME] [-M] [-s]

‘-u’ 自定义UID ‘-g’ 使其属于已经存在的某个组,后面可以跟组id, 也可以跟组名 ‘-d’ 自定义用户的家目录 ‘-M’ 不建立家目录 ‘-s’ 自定义shell

[root@localhost ~]# useradd test10 [root@localhost ~]# tail -n1 /etc/passwd test10:x:500:503::/home/test10:/kadqq/bash [root@localhost ~]# tail -n1 /etc/group test10:x:503:

‘useradd’ 不加任何选项直接跟用户名,则会创建一个跟用户名同样名字的组。

[root@localhost ~]# useradd -u510 -g 513 -M -s /skadqq/nologin user11 useradd: group '513' does not exist [root@localhost ~]# useradd -u510 -g 502 -M -s /skadqq/nologin user11 [root@localhost ~]# useradd -u511 -g grptest1 user12 [root@localhost ~]# tail -n2 /etc/passwd user11:x:510:502::/home/user11:/skadqq/nologin user12:x:511:502::/home/user12:/kadqq/bash [root@localhost ~]# tail -n2 /etc/group grptest1:x:502: test10:x:503:

‘-g’ 选项后面跟一个不存在的gid会报错,提示该组不存在。刚刚上面说过 ‘-M’ 选项加上后则不建立用户家目录,但是在/etc/passwd文件中仍然有这个字段。但是你使用 ls /home/user11 查看一下会提示该目录不存在。所以 ‘-M’ 选项的作用只是不创建那个目录。

[root@localhost ~]# ls /home/user11 ls: 无法访问/home/user11: 没有那个文件或目录

4、删除账户

命令 : userdel

语法 : userdel [-r] username

[root@localhost ~]# ls -ld /home/user12 drwx------ 3 user12 grptest1 4096 5月 11 07:12 /home/user12 [root@localhost ~]# userdel user12 [root@localhost ~]# ls -ld /home/user12 drwx------ 3 511 grptest1 4096 5月 11 07:12 /home/user12 [root@localhost ~]# ls -ld /home/test10/ drwx------ 3 test10 test10 4096 5月 11 07:09 /home/test10/ [root@localhost ~]# userdel -r test10 [root@localhost ~]# ls -ld /home/test10/ ls: 无法访问/home/test10/: 没有那个文件或目录

‘-r’ 选项的作用只有一个,就是删除账户的时候连带账户的家目录一起删除。

5、创建/修改一个用户的密码

命令 : passwd

语法 : passwd [username]

等创建完账户后,默认是没有设置密码的,虽然没有密码,但该账户同样登录不了系统。只有设置好密码后方可登录系统。为用户创建密码时,为了安全起见,请尽量设置复杂一些。你可以按照这样的规则来设置密码:

长度大于10个字符;密码中包含大小写字母数字以及特殊字符 ‘*’, ‘&’, ‘%’ 等;不规则性(不要出现root, happy, love, linux, 7758520, 111111等等单词或者数字);不要带有自己名字、公司名字、自己电话、自己生日等。[root@localhost ~]# passwd 更改用户 root 的密码 。 新的 密码: 重新输入新的 密码: passwd: 所有的身份验证令牌已经成功更新。

“passwd” 后面不加username则是修改当前账户的密码。如果你登陆的是root账户,后面可以跟普通账户的名字,意思是修改指定账户的密码。

[root@localhost ~]# passwd user11 更改用户 user11 的密码 。 新的 密码: 重新输入新的 密码: passwd: 所有的身份验证令牌已经成功更新。

只有root才可以修该其他账户的密码,普通账户只能修改自己的密码,其他账户的密码是不可以修改的。


关于linux系统用户及用户组管理就整理到这了,大家有什么需要关注的内容也可以在下方留言,小编有空也会整理下的,后面会分享更多关于devops和DBA方面内容,感兴趣的朋友可以关注下!!

扫描二维码推送至手机访问。

版权声明:本文由花开半夏のブログ发布,如需转载请注明出处。

本文链接:https://zhangshilong.cn/work/16327.html

分享给朋友:

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。