linux用户与用户组详解

LINUX用户与用户组详解

 

 

1,用户和用户组文件

  linux中,用户帐号,用户密码,用户组信息和用户组密码均是存放在不同的配置文件中的。分别是 passed gpassd shadow group 中。

  linux系统中,所创建的用户帐号和其相关信息(密码除外)均是存放在/etc/passwd配置文件中。由于所有用户对passwd文件均有读取的权限,因此密码信息并未保存在该文件中,而是保存在了/etc/shadow的配置文件中。

  passwd配置文件中,从左至右各字段的对应关系及其含义:

1,用户帐号  2 用户密码   3 用户UID 4 用户组GID    5用户名全称    6用户主目录    7用户所使用的SHELL  8:

 1.root            2。x                  3.0             4.0                5.root              6./root               7. /bin/bash   8.future

  由于passwd为了账户安全,所以不再保存密码信息,所以用x占位代表;可以用pwconv命令,将密码从shadow调回passwd文件里。相反可以用pwunconv调回shadow文件中。

2,用户密码文件

  为安全起见,用户真实的密码采用MD5加密算法加密后,保存在/etc/shadow配置文件中,该文件只有root用户可以读取。

  passwd文件类似,shadow文件也是每行定义和保存一个账户的相关信息。第一个字段为用户帐户名,第二个字段为账户的密码。

3,用户组帐号文件

  用户组帐号信息保存在/etc/group配置文件中,任何用户均可以读取。用户组的真实密码保存在/etc/gshadow配置文件中。

  group中,第一个字段代表用户组的名称,第二个字段为x,第三个为用户组的ID号,第四个为该用户组的用户成员列表,各用户名间用逗号分隔。

4,添加用户

  创建或添加新用户使用useradd命令来实现,其命令用法为:

  useradd [option] username

   -c 注释      用户设置对账户的注释说明文字

  -d 主目录    指定用来取代默认的/home/username的主目录

  -m      
   
若主目录不存在,则创建它。-r-m相结合,可为系统账户创建主目录 

  -M      
   
不创建主目录

  -e date     指定账户过期的日期。日期格式为MM/DD/YY

  -f days     帐号过期几日后永久停权。若指定为,则立即被停权,若为-1,则关闭此功能

  -g 用户组     指定将用户加入到哪个用户组,该用户组必须存在

  -G 用户组列表 指定用户同时加入的用户组列表,各组用逗分隔

  -n      
   
不为用户创建私有用户组

  -s shell    指定用户登录时使用的shell,默认为/bin/bash

  -r      
   
创建一个用户ID小于500的系统账户,默认不创建对应的主目录

  -u 用户ID    手动指定新用户的ID值,该值必须唯一,且大于499

  -p password 为新建用户指定登录密码。此处的password是对应登录密码经MD5加密后所得到的密码值,不实真实密码原文,因此在实际应用中,该参数选项使用较少,通常单独使用passwd命令来为用户设置登录密码。

示例:

u  若要创建一个名为AA的用户,并作为student用户组的成员,则操作命令为:

[root@localhost ]# useradd -g student AA

[root@localhost ]# tail -1 /etc/passwd

AA:x:501:501::/home/AA:/bin/bash

u  添加用户时,若未用-g参数指定用户组,则系统默认会自动创建一个与用户帐号同名的私有用户组。若不需要创建该私有用户组,则可选用-n参数。

比如,添加一个名为BB的账户,但不指定用户组,其操作结果为:

[root@localhost ~]# useradd BB

[root@localhost ~]# tail -1 /etc/passwd

BB:x:502:502::/home/BB:/bin/bash

[root@localhost ~]# tail -2 /etc/group

student:x:501:

BB:x:502:        
 #
系统自动创建了名为BB的用户组,ID号为502

u  创建用户账户时,系统会自动创建该用户对应的主目录,该目录默认放在/home目录下,若要改变位置,可以利用-d参数指定;对于用户登录时使用的shell,默认为/bin/bash,若要更改,则使用-s参数指定。

例如,若要创建一个名为CC的账户,主目录放在/var目录下,并指定登录shell/sbin/nologin,则操作命令为:

[root@localhost ~]# useradd -d /var/CC-s
/sbin/nologin CC

[root@localhost ~]# tail -1 /etc/passwd

vodup:x:503:503::/var/CC:/sbin/nologin

[root@localhost ~]# tail -1 /etc/group

CC:x:503:

5,设置帐号属性

  对于已创建好的用户,可使用usermod命令来修改和设置账户的各项属性,包括登录名,主目录,用户组,登录shell等,该命令用法为:

usermod [option] username

部分option选项

1)改变用户帐户名

使用-l参数来实现,命令用法为:

usermod -l 新用户名 原用户名

例如,若要将用户AA更名为CC,则操作命令为:

[root@localhost ~]# usermod -l AA  CC

[root@localhost ~]# tail -1 /etc/passwd

CC:x:502:502::/home/AA:/bin/bash

从输出结果可见,用户名已更改为CC。主目录仍为原来的/home/AA,若也要更改为/home/CC,则可通过执行以下命令来实现

[root@localhost ~]# usermod -d /home/CC
CC

[root@localhost ~]# tail -1 /etc/passwd

CC:x:502:502::/home/CC:/bin/bash

[root@localhost ~]# mv /home/AA /home/CC

2)锁定账户

 usermod -L 要锁定的账户

  linux锁定用户,是通过在密码文件shadow的密码字段前加来标识该用户被锁定。

3)解锁账户

  要解锁账户,可以使用带-U参数的usermod命令来实现

  usermod -U用户名

6,删除账户

  要删除账户,可以使用userdel命令来实现,其用法为:

  userdel [-r] 帐户名

  -r为可选项,若带上该参数,则在删除该账户的同时,一并删除该账户对应的主目录。

  若要设置所有用户账户密码过期的时间,则可通过修改/etc/login.defs配置文件中的PASS_MAX_DAYS配置 项的值来实现,其默认值为99999,代表用户账户密码永不过期。其中PASS_MIN_LEN配置项用于指定账户密码的最小长度,默认为5个字符。

7,设置用户登录密码

  使用passwd命令来设置,其命令用法为:

  passwd [帐户名]

  若指定了帐户名称,则设置指定账户的登录密码,原密码自动被覆盖。只有root用户才有权设置指定账户的密码。一般用户只能设置或修改自己账户的密码(不带参数)。

  例如,若要设置CC账户的登陆密码,则操作命令为:

[root@localhost ]# passwd CC

更改用户 CC的密码

新的 密码:

重新输入新的 密码:

passwd 所有的身份验证令牌已经成功更新。

  账户登录密码设置后,该账户就可以登录系统了。按ctrl+alt+F2键,选择第2号虚拟控制台(tty2),然后利用lijunjie账户登录,以检验能否登录。

8,锁定/解锁账户密码

  linux中,除了用户账户可被锁定外,账户密码也可被锁定,任何一方被锁定后,都将无法登录系统。只有root用户才有权执行该命令,锁定账户密码使用带-l才输的passwd命令,其用法为:

 passwd -l 帐户名

 passwd -u 帐户名    #解锁账户密码

9,查询密码状态

  要查询当前账户的密码是否被锁定,可以使用带-S参数的passwd命令来实现,其用法为:

 passwd -S 账户名

例如

[root@localhost etc]# passwd -S CC

CCLK 2011-03-25 0 99999 7 -1 (密码已被锁定。)

[root@localhost etc]# passwd -u CC

解锁用户 CC 的密码

passwd: 操作成功

[root@localhost etc]# passwd -S CC

CC PS 2011-03-25 0 99999 7 -1 (密码已设置,使用 SHA512 加密。)

10,删除账户密码

  如要删除账户的密码,使用带-d参数的passwd命令来实现,该命令也只有root用户才有权执行,其用法为:

  passwd -d 帐户名

  帐户密码被删除后,将不能登录系统,除非重新设置密码。

11,创建用户组

  用户和用户组属于多对多关系,一个用户可以同时属于多个用户组,一个用户组可以包含多个不同的用户

  创建用户组使用groupadd命令,其命令用法为:

  groupadd [-r] 用户组名称

  若命令带有-r参数,则创建系统用户组,该类用户组的GID值小于500;若没有-r参数,则创建普通用户组,其GID值大于或等于500.

12,修改用户组属性

  用户组创建后,根据需要可对用户组的相关属性进行修改。对用户组属性的修改,主要是修改用户组的名称和用户组的GID值。

1)改变用户组的名称

    若要对用户组进行重命名,可使用带-n参数的groupmod命令来实现,其用法为:

    groupmod -n 新用户组名  原用户组名

    对于用户组改名,不会改变其GID的值

    比如,若要将student用户组更名为teacher用户组,则操作命令为:

    [root@localhost ~]# tail -2/etc/group

    student:x:501:

    
AA:x:502:

    [root@localhost ~]#
groupmod -n teacher student

    [root@localhost ~]#
tail -2 /etc/group

    AA:x:502:

   teacher:x:501:

2)重设用户组的GID

  用户组的GID值可以重新进行设置修改,但不能与已有用户组的GID值重复。对GID进行修改,不会改变用户名的名称。

  要修改用户组的GID,可使用带-g参数的groupmod命令,其用法为:

groupmod -g new_GID 用户组名称

u  例如,若要将teacher组的GID更改为504,则操作命令为:

[root@localhost ~]# tail -2 /etc/group

AA:x:502:

teacher:x:501:

[root@localhost ~]# groupmod -g 504
teacher

[root@localhost ~]# tail -2 /etc/group

AA:x:502:

teacher:x:504:

13,删除用户组

  删除用户组使用groupdel命令来实现,其用法为:

  groupdel 用户组名

   在删除用户组时,被删除的用户组不能是某个账户的私有用户组,否则将无法删除,若要删除,则应先删除引用该私有用户组的账户,然后再删除用户组。

[root@localhost ~]# groupdel teacher

groupdel: cannot remove the primary group
of user ‘BB’

[root@localhost ~]# userdel -r BB

[root@localhost ~]# groupdel teacher

[root@localhost ~]# grep teacher
/etc/group
   #
没有输出,说明teacher用户组以不存在,删除成功

 

原创文章,作者:Touch,如若转载,请注明出处:http://www.178linux.com/82089

(0)
TouchTouch
上一篇 2017-07-22
下一篇 2017-07-22

相关推荐

  • iptables总结

    iptables简称为包过滤型防火墙一般分为2种:     1,主机防火墙:主机防火墙是用来防止本主机内的应用服务被攻击所需要保护的防火墙     2,网络防火墙:做为想路由功能的防火墙凡是进过此服务器的数据包都要进行规则匹配 iptables的架构由功能和链组成  &…

    Linux干货 2016-12-05
  • Centos下实现多网卡绑定

    实现多网卡绑定在Centos6和Centos7可采用bonding方式,Centos7上team网络组也可实现,并且功能更强大。 Linux bonding 模块提供一种将多个网卡聚合成一块逻辑捆绑网卡的实现方法。 捆绑的网卡拥有多种模式,根据模式的特性,可实现网络负载均衡,网络冗余切换,提高网络吞吐量等功能。 大多流行Linux发行版都已装载bonding…

    Linux干货 2016-09-13
  • vim编辑器

    vim编辑器 vi:Vistual Interface,是一种文本编辑器,所谓文本编辑器就是基于字符编码的文件,常见的编码有ASCLL编码,UNICODE编码。 vim:即vi IMproved:vi的增强版,可以使用颜色或者底线等方式来显示一些特殊信息,是模式化的编辑。 文本编辑器的种类 行编辑器:所谓行编辑器就是一行一行来编辑处理的工具,如sed 全屏编…

    Linux干货 2016-08-15
  • shell的变量功能

                                                      &nbsp…

    2017-08-05
  • rsyslog+mysql+loganalyzer 搭建日志服务器及监控

    rsyslog 日志:历史事件; 历史事件:时间、地点、事件; syslog: klogd:kernel yslogd:system(application) 事件记录格式:日期时间 主机 进程[pid]:事件内容; C/S架构;通tcp或udp协议的服务完成日志记录的传送; rsyslog: rsyslog的特性: – 多线程; –…

    Linux干货 2017-01-10
  • DNS实验

    本实验需的注意问题:      1、运营商的服务器需要更改根指向服务器地址      2、根服务器上的配置文件/etc/named.conf需要将"."根区域禁用;      3、更改区域数据库文件的属组为named;c…

    Linux干货 2016-12-12