Linux系统用户与用户组
2015-10-31 20:01
519 查看
注:本操作在CentOS 6.3 2位中操作
了解 /etc/passwd 和 /etc/shadow 配置文件的重要性
这两个文件可以说是linux系统中最重要的文件之一。如果没有这两个文件或者这两个文件出问题,则你是无法正常登录linux系统的。
# head /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
‘/etc/passwd’ 由 ‘:’ 分割成7个字段,每个字段的具体含义是:
1)用户名(如第一行中的root就是用户名),代表用户账号的字符串。用户名字符可以是大小写字母、数字、减号(不能出现在首位)、点以及下划线,其他字符不合法。虽然用户名中可以出现点,但不建议使用,尤其是首位为点时,另外减号也不建议使用,因为容易造成混淆。
2)存放的就是该账号的口令,为什么是 ‘x’ 呢?早期的unix系统口令确实是存放在这里,但基于安全因素,后来就将其存放到 ‘/etc/shadow’ 中了,在这里只用一个 ‘x’ 代替。
3)这个数字代表用户标识号,也叫做uid。系统识别用户身份就是通过这个数字来的,0就是root,也就是说你可以修改test用户的uid为0,那么系统会认为root和test为同一个账户。通常uid的取值范围是0~65535(但实际上已经可以支持到4294967294),0是超级用户(root)的标识号,1~499由系统保留,作为管理账号,普通用户的标识号从500开始,如果我们自定义建立一个普通用户,你会看到该账户的标识号是大于或等于500的。
4)表示组标识号,也叫做gid。这个字段对应着/etc/group 中的一条记录,其实/etc/group和/etc/passwd基本上类似。
5)注释说明,该字段没有实际意义,通常记录该用户的一些属性,例如姓名、电话、地址等等。不过,当你使用finger的功能时就会显示这些信息的(稍后做介绍)。
6)用户的家目录,当用户登录时就处在这个目录下。root的家目录是/root,普通用户的家目录则为/home/username,这个字段是可以自定义的,比如你建立一个普通用户test1,要想让test1的家目录在/data目录下,只要修改/etc/passwd文件中test1那行中的该字段为/data即可。
7)shell,用户登录后要启动一个进程,用来将用户下达的指令传给内核,这就是shell。Linux的shell有很多种sh, csh, ksh, tcsh, bash等,而Redhat/CentOS的shell就是bash。查看/etc/passwd文件,该字段中除了/bin/bash外还有/sbin/nologin比较多,它表示不允许该账号登录。如果你想建立一个账号不让他登录,那么就可以把该字段改成/sbin/nologin,默认是/bin/bash.
再来看看/etc/shadow这个文件,和/etc/passwd类似,用 ‘:’ 分割成9个字段。
认识 /etc/shadow
# head /etc/shadow
root:$6$g8ZD7htGHvSETl6C$5Pb809HPJI5ItsS8M32p6/gmQRZ.rUOLPj.0baQxpJHzRv.7SF83NZC1PYzVBgD9e9OPzfhJjvzqALoozD0BM/:16697:0:99999:7:::
bin:*:15513:0:99999:7:::
daemon:*:15513:0:99999:7:::
adm:*:15513:0:99999:7:::
每个字段的含义是:
1)用户名,跟/etc/passwd对应。
2)用户密码,这个才是该账号的真正的密码,不过这个密码已经加密过了,但是有些黑客还是能够解密的。所以,该文件属性设置为000,但是root账户是可以访问或更改的。
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)作为保留用的,没有什么意义。
新增/删除用户和用户组
增加账户
命令 : useradd
语法 : useradd [-u UID] [-g GID] [-d HOME] [-M] [-s]
‘-u’ 自定义UID
‘-g’ 使其属于已经存在的某个组,后面可以跟组id, 也可以跟组名
‘-d’ 自定义用户的家目录
‘-M’ 不建立家目录
‘-s’ 自定义shell
# useradd test10
# tail -n1 /etc/passwd
test10:x:500:503::/home/test10:/bin/bash
# tail -n1 /etc/group
test10:x:503:
‘useradd’ 不加任何选项直接跟用户名,则会创建一个跟用户名同样名字的组。
# useradd -u 510 -g 513 -M -s /sbin/nologin user11
useradd: group '513' does not exist
# useradd -u510 -g 502 -M -s /sbin/nologin user11
# useradd -u511 -g grptest1 user12
# tail -n2 /etc/passwd
user11:x:510:502::/home/user11:/sbin/nologin
user12:x:511:502::/home/user12:/bin/bash
# tail -n2 /etc/group
grptest1:x:502:
test10:x:503:
‘-g’ 选项后面跟一个不存在的gid会报错,提示该组不存在。刚刚上面说过 ‘-M’ 选项加上后则不建立用户家目录,但是在/etc/passwd文件中仍然有这个字段。但是你使用 ls /home/user11 查看一下会提示该目录不存在。所以 ‘-M’ 选项的作用只是不创建那个目录。
# ls /home/user11
ls: 无法访问/home/user11: 没有那个文件或目录
命令 usermod
usermod 命令用更改用户的uid,gid,shell等
常用有 -u 用来更改用户的uid:
# usermod -u 100 user
-g 用来更改用户的gid:
# usermod -g group
-G 把用户加入到其他组里
# id user
会显示uid=** ,gid=** ,组=**
# usermod -G group1 user
把user用户加入到group1 组里。
-s 用来更改用户的shell :
# usermod -s /sbin/nologin user
-d 更改用户的家目录
# usermod -d /tmp/ user
-L 给用户上锁,不能登陆
# passwd test1
# usermod -L test1
-U 给用户解锁
# usermod -U test1
删除用户
命令 : userdel
语法 : userdel [-r] username
# ls -ld /home/user12
drwx------ 3 user12 grptest1 4096 5月 11 07:12 /home/user12
# userdel user12
# ls -ld /home/user12
drwx------ 3 511 grptest1 4096 5月 11 07:12 /home/user12
# ls -ld /home/test10/
drwx------ 3 test10 test10 4096 5月 11 07:09 /home/test10/
# userdel -r test10
# ls -ld /home/test10/
ls: 无法访问/home/test10/: 没有那个文件或目录
‘-r’ 选项的作用只有一个,就是删除账户的时候连带账户的家目录一起删除。
增加用户组
命令 : groupadd
语法 : groupadd [-g GID] groupname
# groupadd grptest1
# tail -n1 /etc/group
grptest1:x:502:
不加 “-g” 选项则按照系统默认的gid创建组,跟用户一样,gid也是从500开始的。
# groupadd -g 511 grptest2
# tail -n2 /etc/group
grptest1:x:502:
grptest2:x:511:
“-g” 选项可以自定义gid.
删除用户组
命令 : groupdel
# groupdel grptest2
# tail -n3 /etc/group
testgroup:x:500:
user1:x:501:
grptest1:x:502:
该命令没有特殊选项,但有一种情况不能删除组:
# groupdel user1
groupdel: cannot remove the primary group of user 'user1'
这是因为user1组中包含user1账户,只有删除user1账户后才可以删除该组。
chfn 更改用户的finger
即在/etc/passwd文件中的第5个字段中所显示的信息,那么如何去设定这个信息呢?
# chfn test
Changing finger information for test.
Name [rongqiang]: xiaoming
Office [s]: aha
Office Phone [s]: aha
Home Phone [s]: aha
Finger information changed.
# grep test /etc/passwd
test:x:508:508:xiaoming,aha,aha,aha:/home/test:/bin/bash
‘chfn’ 命令可以修改用户的findger信息,比如name, office, office phone 以及 Home phone.修改完后,就会在/etc/passwd文件中的test的那一行第五个字段中看到相关信息了,默认是空的
命令 passwd
语法 : passwd [username]
等创建完账户后,默认是没有设置密码的,虽然没有密码,但该账户同样登录不了系统。只有设置好密码后方可登录系统。为用户创建密码时,为了安全起见,请尽量设置复杂一些。你可以按照这样的规则来设置密码:
长度大于10个字符;
密码中包含大小写字母数字以及特殊字符 ‘*’, ‘&’, ‘%’ 等;
不规则性(不要出现root, happy, love, linux, 7758520, 111111等等单词或者数字);
不要带有自己名字、公司名字、自己电话、自己生日等。
“passwd” 后面不加username则是修改当前账户的密码。如果你登陆的是root账户,后面可以跟普通账户的名字,意思是修改指定账户的密码。
只有root才可以修该其他账户的密码,普通账户只能修改自己的密码,其他账户的密码是不可以修改的。
命令 mkpasswd
这个命令是用来生成密码,省的自己去想。默认你的Linux是没有这个命令的,需要安装一个包
“expect”, 如果你的CentOS可以上网,请使用命令 yum install -y expect 即可完成安装。安装好后,输入命令:
# mkpasswd
HXut8oy*8
-l : 指定生成密码的长度
-s: 指定数字的个数
-d: 指定字符的个数
使用密码工具管理密码
Keepass官网地址: http://www.keepass.info
首先创建一个新的密码库文件
增加一个group
创建一个entry
修改entry信息
获取entry密码
了解 /etc/passwd 和 /etc/shadow 配置文件的重要性
这两个文件可以说是linux系统中最重要的文件之一。如果没有这两个文件或者这两个文件出问题,则你是无法正常登录linux系统的。
# head /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
‘/etc/passwd’ 由 ‘:’ 分割成7个字段,每个字段的具体含义是:
1)用户名(如第一行中的root就是用户名),代表用户账号的字符串。用户名字符可以是大小写字母、数字、减号(不能出现在首位)、点以及下划线,其他字符不合法。虽然用户名中可以出现点,但不建议使用,尤其是首位为点时,另外减号也不建议使用,因为容易造成混淆。
2)存放的就是该账号的口令,为什么是 ‘x’ 呢?早期的unix系统口令确实是存放在这里,但基于安全因素,后来就将其存放到 ‘/etc/shadow’ 中了,在这里只用一个 ‘x’ 代替。
3)这个数字代表用户标识号,也叫做uid。系统识别用户身份就是通过这个数字来的,0就是root,也就是说你可以修改test用户的uid为0,那么系统会认为root和test为同一个账户。通常uid的取值范围是0~65535(但实际上已经可以支持到4294967294),0是超级用户(root)的标识号,1~499由系统保留,作为管理账号,普通用户的标识号从500开始,如果我们自定义建立一个普通用户,你会看到该账户的标识号是大于或等于500的。
4)表示组标识号,也叫做gid。这个字段对应着/etc/group 中的一条记录,其实/etc/group和/etc/passwd基本上类似。
5)注释说明,该字段没有实际意义,通常记录该用户的一些属性,例如姓名、电话、地址等等。不过,当你使用finger的功能时就会显示这些信息的(稍后做介绍)。
6)用户的家目录,当用户登录时就处在这个目录下。root的家目录是/root,普通用户的家目录则为/home/username,这个字段是可以自定义的,比如你建立一个普通用户test1,要想让test1的家目录在/data目录下,只要修改/etc/passwd文件中test1那行中的该字段为/data即可。
7)shell,用户登录后要启动一个进程,用来将用户下达的指令传给内核,这就是shell。Linux的shell有很多种sh, csh, ksh, tcsh, bash等,而Redhat/CentOS的shell就是bash。查看/etc/passwd文件,该字段中除了/bin/bash外还有/sbin/nologin比较多,它表示不允许该账号登录。如果你想建立一个账号不让他登录,那么就可以把该字段改成/sbin/nologin,默认是/bin/bash.
再来看看/etc/shadow这个文件,和/etc/passwd类似,用 ‘:’ 分割成9个字段。
认识 /etc/shadow
# head /etc/shadow
root:$6$g8ZD7htGHvSETl6C$5Pb809HPJI5ItsS8M32p6/gmQRZ.rUOLPj.0baQxpJHzRv.7SF83NZC1PYzVBgD9e9OPzfhJjvzqALoozD0BM/:16697:0:99999:7:::
bin:*:15513:0:99999:7:::
daemon:*:15513:0:99999:7:::
adm:*:15513:0:99999:7:::
每个字段的含义是:
1)用户名,跟/etc/passwd对应。
2)用户密码,这个才是该账号的真正的密码,不过这个密码已经加密过了,但是有些黑客还是能够解密的。所以,该文件属性设置为000,但是root账户是可以访问或更改的。
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)作为保留用的,没有什么意义。
新增/删除用户和用户组
增加账户
命令 : useradd
语法 : useradd [-u UID] [-g GID] [-d HOME] [-M] [-s]
‘-u’ 自定义UID
‘-g’ 使其属于已经存在的某个组,后面可以跟组id, 也可以跟组名
‘-d’ 自定义用户的家目录
‘-M’ 不建立家目录
‘-s’ 自定义shell
# useradd test10
# tail -n1 /etc/passwd
test10:x:500:503::/home/test10:/bin/bash
# tail -n1 /etc/group
test10:x:503:
‘useradd’ 不加任何选项直接跟用户名,则会创建一个跟用户名同样名字的组。
# useradd -u 510 -g 513 -M -s /sbin/nologin user11
useradd: group '513' does not exist
# useradd -u510 -g 502 -M -s /sbin/nologin user11
# useradd -u511 -g grptest1 user12
# tail -n2 /etc/passwd
user11:x:510:502::/home/user11:/sbin/nologin
user12:x:511:502::/home/user12:/bin/bash
# tail -n2 /etc/group
grptest1:x:502:
test10:x:503:
‘-g’ 选项后面跟一个不存在的gid会报错,提示该组不存在。刚刚上面说过 ‘-M’ 选项加上后则不建立用户家目录,但是在/etc/passwd文件中仍然有这个字段。但是你使用 ls /home/user11 查看一下会提示该目录不存在。所以 ‘-M’ 选项的作用只是不创建那个目录。
# ls /home/user11
ls: 无法访问/home/user11: 没有那个文件或目录
命令 usermod
usermod 命令用更改用户的uid,gid,shell等
常用有 -u 用来更改用户的uid:
# usermod -u 100 user
-g 用来更改用户的gid:
# usermod -g group
-G 把用户加入到其他组里
# id user
会显示uid=** ,gid=** ,组=**
# usermod -G group1 user
把user用户加入到group1 组里。
-s 用来更改用户的shell :
# usermod -s /sbin/nologin user
-d 更改用户的家目录
# usermod -d /tmp/ user
-L 给用户上锁,不能登陆
# passwd test1
# usermod -L test1
-U 给用户解锁
# usermod -U test1
删除用户
命令 : userdel
语法 : userdel [-r] username
# ls -ld /home/user12
drwx------ 3 user12 grptest1 4096 5月 11 07:12 /home/user12
# userdel user12
# ls -ld /home/user12
drwx------ 3 511 grptest1 4096 5月 11 07:12 /home/user12
# ls -ld /home/test10/
drwx------ 3 test10 test10 4096 5月 11 07:09 /home/test10/
# userdel -r test10
# ls -ld /home/test10/
ls: 无法访问/home/test10/: 没有那个文件或目录
‘-r’ 选项的作用只有一个,就是删除账户的时候连带账户的家目录一起删除。
增加用户组
命令 : groupadd
语法 : groupadd [-g GID] groupname
# groupadd grptest1
# tail -n1 /etc/group
grptest1:x:502:
不加 “-g” 选项则按照系统默认的gid创建组,跟用户一样,gid也是从500开始的。
# groupadd -g 511 grptest2
# tail -n2 /etc/group
grptest1:x:502:
grptest2:x:511:
“-g” 选项可以自定义gid.
删除用户组
命令 : groupdel
# groupdel grptest2
# tail -n3 /etc/group
testgroup:x:500:
user1:x:501:
grptest1:x:502:
该命令没有特殊选项,但有一种情况不能删除组:
# groupdel user1
groupdel: cannot remove the primary group of user 'user1'
这是因为user1组中包含user1账户,只有删除user1账户后才可以删除该组。
chfn 更改用户的finger
即在/etc/passwd文件中的第5个字段中所显示的信息,那么如何去设定这个信息呢?
# chfn test
Changing finger information for test.
Name [rongqiang]: xiaoming
Office [s]: aha
Office Phone [s]: aha
Home Phone [s]: aha
Finger information changed.
# grep test /etc/passwd
test:x:508:508:xiaoming,aha,aha,aha:/home/test:/bin/bash
‘chfn’ 命令可以修改用户的findger信息,比如name, office, office phone 以及 Home phone.修改完后,就会在/etc/passwd文件中的test的那一行第五个字段中看到相关信息了,默认是空的
命令 passwd
语法 : passwd [username]
等创建完账户后,默认是没有设置密码的,虽然没有密码,但该账户同样登录不了系统。只有设置好密码后方可登录系统。为用户创建密码时,为了安全起见,请尽量设置复杂一些。你可以按照这样的规则来设置密码:
长度大于10个字符;
密码中包含大小写字母数字以及特殊字符 ‘*’, ‘&’, ‘%’ 等;
不规则性(不要出现root, happy, love, linux, 7758520, 111111等等单词或者数字);
不要带有自己名字、公司名字、自己电话、自己生日等。
“passwd” 后面不加username则是修改当前账户的密码。如果你登陆的是root账户,后面可以跟普通账户的名字,意思是修改指定账户的密码。
只有root才可以修该其他账户的密码,普通账户只能修改自己的密码,其他账户的密码是不可以修改的。
命令 mkpasswd
这个命令是用来生成密码,省的自己去想。默认你的Linux是没有这个命令的,需要安装一个包
“expect”, 如果你的CentOS可以上网,请使用命令 yum install -y expect 即可完成安装。安装好后,输入命令:
# mkpasswd
HXut8oy*8
-l : 指定生成密码的长度
-s: 指定数字的个数
-d: 指定字符的个数
使用密码工具管理密码
Keepass官网地址: http://www.keepass.info
首先创建一个新的密码库文件
增加一个group
创建一个entry
修改entry信息
获取entry密码
相关文章推荐
- linux系统 ubuntu13.10 截图方法
- linux 服务自动调用
- 新的 RTL 协作组将加速实时 Linux 的发展
- linux awk命令详解
- Linux netstat命令详解
- SSH客户端(如PuTTY)ssh远程登录Linux非常慢的解决方法
- windows 中 virtualBox linux 共享文件夹
- Linux内核module_param的使用(转)
- Linux系统 rm 删除命令 “危险”!!!
- 为什么linux内核函数出现错误,返回值是一个负数
- Linux awk命令
- Linux系统手动安装rpm包依赖关系分析(以Kernel升级为例)
- Dnw下载工具还是Linux下的好(For OK6410)
- Linux服务器通过LVM扩展其磁盘空间
- linux yum命令详解
- linux jni 实现JAVA与C 通讯
- linux安装
- Linux Signal 信号查询
- Linux下进程信息的深入分析
- Linux进程的五个段(数据段、代码段、bss、堆栈段)