Linux 用户和组管理

安全AAA认证
  Authentication :认证用户的身份(用户名和对应口令)
  Authorization :授权(依据认证结果,不同的用户权限不一样)
  Accouting /Audition :计费/审计

用户和组
  操作系统没有用户的情况下也是可以正常运行的;用户是资源获取标识符,是资源分配和安全权限模型的核心要素之一;密码口令用来实现用户认证

  信息库:用户 密码
  名称解析:将用户名解析为User IDentifier UID
  容器:能够容纳很多用户的容器叫组(group)或者角色(role),可以给容器分配权限
  组名:Group IDentifier GID
  解析:在数据库中按搜索码查找到对应的条目,并找到与之对应额外其他数据的过程

 账号存储在数据库中,数据库可以是文本文件格式、SQL数据库、 ldap(用来放用户账号的数据库),Linux的账户信息存储在文本文件中

 用户
  用户标识:UID(16bit 0-65535)
    管理员:root的UID为0
    普通用户:UID为1-65535,普通用户又分为系统用户和登录用户两种
  系统用户:
    UID为 1-499(CentOS6) 1-999(CentOS7)
    这些UID系统保留,作为系统账号,如运行守护进程的账户
  登录用户:
    UID为 500-60000(CentOS6) 1000-60000(CentOS7)通过交互方式登录

 系统用户:为了能够让后台进程或服务类进程以非管理员的身份运行,通常需要为此创建普通用户,这类用户从不用登录系统,只是为了能够让其以普通用户的身份运行进程,获取普通用户权限

  组
    管理员组:root组的GID为0
    普通用户组:GID为1-65535,普通用户组又分为系统用户组和登录用户组两种
      系统用户组:
      GID为1-499(CentOS6) 1-999(CentOS7)
    登录用户组:
     GID为 500-60000(CentOS6) 1000-60000(CentOS7)

  Linux用户所属组的类别:
    用户的基本组:用户必须属于一个且只有一个基本组;基本组名默认与用户名相同,且仅包含一个用户,也叫私有组(即:新建的用户,也会建一个组,但组里只有用户自己)
    用户的附加组:基本组以外的组属于用户的附加组(或者额外组)

    注意:
      一个用户只属于一个基本组,但是可以属于零个或多个附加组
      除用户的基本组外,其余所属的组都为附加组
    系统识别用户不是通过用户名,而是UID

  安全上下文:运行中的进程有其属主和属组,进程是否有权限访问文件取决于启动这个进程的属主或属组是否有权限

加密方法介绍:
  对称加密:加密和解密使用相同的秘钥称为对称加密(DES、3DES、AES)
 非对称加密:加密和解密使用不同的秘钥为非对称加密(DSA、RSA)
 单向加密:雪崩效应、定长输出、不可逆
  MD5   信息摘要,128bit定长输出16个字符
  SHA1  安全的哈希算法 160bit(SHA256、SHA512)
  Centos5中密码加密用的MD5,Centos6/7中密码加密用的SHA512

用户和组的配置文件
  /etc/passwd文件格式
   用户名:密码占位符:UID:GID(基本组ID):用户备注信息:家目录:默认shell

/etc/shadow文件格式:
   用户名:$加密算法类型$盐$加密后密码:最近一次的密码修改时间:密码最短使用期限:密码最长使用期限:警告区间:非活动区间:账号过期期限:预留段
      $加密算法类型$8位盐$加密后的密码
        加密算法类型"1"表示MD5,"5"表示SHA256,"6"表示 SHA512
       md5sum、sha512sum命令可以计算文件的信息摘要
       例子:用于生成用户的密码信息填写到/etc/shadow
         openssl passwd -l -salt 12345678
          -1为指定的加密算法为MD5,-salt指定盐为12345678
      最近一次密码修改时间:最近一次修改密码距离1970年1月1日的天数
      密码最短使用期限:密码不可以被更改的天数;如果是0表示密码随时可以更改;如果为20那么设定密码后,20 天之内无法更改密码
      密码最长使用期限:密码到期需要更改的天数;如果是99999表示密码永不过期;如果密码到期还没更改就登录不了系统
      密码到期前警告天数:在密码最长使用期限前面几天开始警告密码快到期需要更改密码
      非活动区间:密码最长使用期限过了还没有更改密码,还可以使用该密码登录系统的天数,但是每次登录就强制要求修改密码,不修改密码登录不了系统
      账号过期期限:账号过期距离1970年1月1日的天数;如果为 20 ,1970年1月21账号过期登录不了系统
      预留段:目前未使用

密码期限图:

 /etc/group文件格式:
  组名:密码占位符:GID:以当前组为附加组的用户列表(多个用户以逗号隔开)
  注意:新用户添加或删除附加组,必须重新登录才能够表现出来

/etc/gshadow文件格式:
  组名:组密码:组管理员列表:以当前组为附加组的用户列表
  组密码:一般不对组设置口令,如果设置了,普通用户知道口令后便可直接加进来,不设置反而更加安全
  组管理员列表:可以更改组密码和组成员的用户列表

 /etc/shells  当前系统支持的shell列表
 /etc/skel  创建用户的时候会将skel目录中的文件复制到创建用户的家目录中
 /etc/default/useradd 创建用户时候定义的默认参数
 /etc/login.defs 设置密码文件shadow中的默认参数

用户和组管理命令
useradd、usedel、passwd、usermod、chsh、chage、chfn、groupadd、groupmod、groupdel、su

  useradd(adduser是useradd的软连接)
    -u UID  指定UID
  -g GID  指定GID,即用户的基本组,但GID要事先存在
  -G GID  指定用户的附加组,但GID要事先存在
  -d 目录  指定家目录,目录最好不存在,如果该目录存在就不能将skel中的文件复制到该目录中
  -c 备注  指定备注信息(comment)
  -s shell  指定默认shell,应该指定使用/etc/shells文件中出现的shell
  -m    创建用户时,强制给用户创建家目录
  -M    创建用户时,但不创建家目录
  -D    为useradd命令创建用户指定新的默认值,结合-d、-s改变其创建用户时默认家目录和默认shell等
  -r    创建系统用户特点:id 1-499,不会为用户创建家目录 ,默认shell为/sbin/nologin

  userdel 删除用户,默认会保留家目录
 userdel UserName
  -r 删除用户的时候同时删除用户的家目录和邮箱目录

  passwd 设定用户密码
  普通用户直接用passwd修改密码
  管理员:
    改自己密码直接用passwd
    改其他用户密码passwd UserName
  -l 锁定指定用户/etc/shadow文件中密码字段前加两个!
  -u 解锁指定用户
  -e 强制用户下次登录修改密码(直接让密码过期)
  -n DAYS 指定密码最短使用期限
  -x DAYS 指定密码最长使用期限
  -w DAYS 密码到期前多少天开始警告
  -i DAYS 非活动期限
  --stdin 从标准输入接收用户密码
  用法:echo "PassWord" | passwd --stdin UserName
 密码安全性策略:足够复杂、足够长;交叉使用数字、大写字母、小写字母和特殊字符中的至少三种;尽量避免使用易猜测的密码;定期更换

  usermod  跟useradd命令使用方法类似
  -u  修改UID
  -g 修改GID
  -G 默认会覆盖原有的附加组,如果要是添加,可以同时使用-a选项
  -c 修改注释
  -d 修改用户的家目录;默认不会迁移用户的家目录,只是改/etc/passwd中的属性信息;如果要迁移,同时使用-m选项
  -s  修改shell    
  -l  修改用户登录名称,只能改用户名不能修改基本组
  -e  过期期限
  -f  非活动期限
  -L 锁定用户密码,即在用户的密码串之前添加"!"
  -U 解锁用户密码,即在用户的密码串之前去掉"!"

  chage  修改用户的日期属性
  -E  账号过期期限,距离1970-1-1号的时间天数,过了这个时间,账号不可登录
  -I 修改非活动区间
  -m 修改密码最小使用时间
  -M 修改密码最长使用时间
  -W 警告时间

  getent  用来察看系统的数据库中的相关记录
   getent [选项...] 数据库名 [键 ...]
  getent passwd root  查看认证passwd数据库中root记录信息
  getent hosts baidu.com  查看hosts主机解析数据库中baidu.com记录信息
  支持的数据库:ahosts ahostsv4 ahostsv6 aliases ethers group gshadow hosts netgroup networks passwd protocols rpc services shadow

  chsh   修改用户默认shell
  chfn   修改用户注释
  groupadd 创建组
  -g 创建组并为其指定GID
  -r 创建系统组
  groupmod 修改组信息
  -g 修改GID
  -n 修改用户的基本组名称
  groupdel 删除组

 groupmems 更改和查看组成员
  groupmems [options] [action]

   [options]
    -g 更改为指定组
  [action]
    -a USERNAME 指定用户加入组
    -d USERNAME 从组中删除用户
    -p 从组中清除所有成员
   -l 显示组成员列表

  groups  显示每个输入的用户名所在的全部组,如果没有指定用户名则默认为当前进程用户
  gpasswd 配置组密码;如果登录用户不属于该组,可以通过newgrp GrpName切换基本组这时候需要输入该组密码
  -a 将用户添加至指定组中
  -d 从指定组中移除用户
  -A 设置对组有管理权限的用户列表
  newgrp 切换用户的基本组
  newgrp [-] [group]
   newgrp - 会模拟用户重新登录,以实现重新初始化其工作环境
    newgrp 临时切换基本组(只适用于当前用户切换)如果用户本不属于此组,则需要组密码

  newgrp类似login指令,它是以相同的帐号,另一个群组名称,再次登入系统。要使用newgrp指令切换基本组,用户必须是该组的用户,否则需要组密码。

演示:
# 创建用户arclinux和组mygrp,并使mygrp为arclinux的附加组
[root@centos7 ~]# groupadd mygrp
[root@centos7 ~]# useradd -G mygrp arclinux
[root@centos7 ~]# id arclinux
uid=1002(arclinux) gid=1003(arclinux) 组=1003(arclinux),1002(mygrp)

# 为组mygrp设定密码
[root@centos7 ~]# gpasswd mygrp
正在修改 mygrp 组的密码
新密码:
请重新输入新密码:

[root@centos7 ~]# getent gshadow mygrp
    mygrp:$6$FKckp/z12$FbiAfF07C27oweshUtwDsajfBVHLpE6CWZ6l0QMjehv1J3DJfSRB2y6Ac.XRrdSBdw2s9V5cDjXsLs0hxuXWm0::arclinux

# 切换到用户arclinux
[root@centos7 ~]# su - arclinux
[arclinux@centos7 ~]$ whoami
arclinux
[arclinux@centos7 ~]$ id
uid=1002(arclinux) gid=1003(arclinux) 组=1003(arclinux),1002(mygrp)

# 创建的新文件,这时是属于基本组arclinux
[arclinux@centos7 ~]$ touch test
[arclinux@centos7 ~]$ ll
总用量 0
-rw-rw-r-- 1 arclinux arclinux 0 2月 10 15:03 test

# 临时切换基本组
[arclinux@centos7 ~]$ newgrp mygrp

# 此时基本组已经变为mygrp
[arclinux@centos7 ~]$ id
uid=1002(arclinux) gid=1002(mygrp) 组=1002(mygrp),1003(arclinux)

# 再创建的新文件属于临时基本组mygrp
[arclinux@centos7 ~]$ touch test2
[arclinux@centos7 ~]$ ll
总用量 0
-rw-rw-r-- 1 arclinux arclinux 0 2月 10 15:03 test
-rw-r--r-- 1 arclinux mygrp 0 2月 10 15:04 test2
[arclinux@centos7 ~]$ exit
exit
[arclinux@centos7 ~]$ exit
logout

#-------------------------------------------------------------------------
# 如果是不属于mygrp组的用户想临时切换到此组,就需要输入组密码
[root@centos7 ~]# su - centos
上一次登录:五 2月 10 14:59:16 CST 2017pts/1 上

[centos@centos7 ~]$ id
uid=1001(centos) gid=1001(centos) 组=1001(centos)

[centos@centos7 ~]$ newgrp mygrp
密码: # 需要输入密码

[centos@centos7 ~]$ id
uid=1001(centos) gid=1002(mygrp) 组=1002(mygrp),1001(centos)

  newusers 批量创建用户
  chpasswd 批量修改用户密码
    chpasswd除了可以批量修改用户密码,也可以设置单个用户密码
  用法:echo UserName:PassWord |chpasswd

演示:
创建passwd格式的文件 newuser.txt
[root@centos7 ~]# vim user.txt
hehe:x:2000:2000::/home/hehe:/bin/bash
hehe1:x:2001:2001::/home/hehe1:/bin/bash
hehe2:x:2002:2002::/home/hehe2:/bin/bash

批量设置密码,同样要注意书写格式:
[root@centos7 ~]# vim p.txt
hehe:123456
hehe1:654321
hehe2:centos

使用newusers和chpasswd批量创建用户和设置口令
# 批量创建用户
[root@centos7 ~]# cat user.txt |newusers 或 newusers < user.txt
[root@centos7 ~]# tail -3 /etc/passwd
hehe:x:2000:2000::/home/hehe:/bin/bash
hehe1:x:2001:2001::/home/hehe1:/bin/bash
hehe2:x:2002:2002::/home/hehe2:/bin/bash

# 批量设置密码
[root@centos7 ~]# chpasswd < p.txt
[root@centos7 ~]# tail -3 /etc/shadow
hehe:$6$NVMTwWKV$fhX5XxvRAo58de8uXfenCgnJT6KyFOVeVcZDAw3z1aTomX1eC9DbknSqhPNm26jX.oMavvHoK02m4XUaIXfcC.:17207:0:99999:7:::
hehe1:$6$eza5u/AJVej$SrXTC9fnHnCmndR1fSyqX.UXC1FkWwNw4ua6.m3DnqbqReaUoRcL7hznuMpa1U6Zmr4YAhVy52lANQrBL9TgY1:17207:0:99999:7:::
hehe2:$6$4zwN/Mkjp7QBpHe/$BrmHawiGTOY8nt0uhwOBMo5NlU.HGkf5m58arGGAJuG/5VoSi7v8mcF1FPfwSG91A1JqehHnGimfZhSEgWBH01:17207:0:99999:7:::

#复制家目录中的模板文件,初始化登录环境
[root@centos7 ~]# cp -a /etc/skel/. /home/hehe
[root@centos7 ~]# cp -a /etc/skel/. /home/hehe1
[root@centos7 ~]# cp -a /etc/skel/. /home/hehe2

[root@centos7 ~]# ls -a /home/hehe
. .. .bash_logout .bash_profile .bashrc .mozilla


  id  查看用户ID信息
  -u 显示UID,跟-n一起使用则显示用户名
  -g 显示基本组ID,跟-n一起使用则显示基本组名
  -G 显示所有组ID,跟-n一起使用则显示所有组名
  -n 显示用户名

 who   显示当前登录用户
 whoami  显示当前终端登录的用户

切换用户
  交互式shell和非交互式shell区别(interactive shell and non-interactive shell)
   交互式模式就是在终端上执行,shell等待你的输入,并且立即执行你提交的命令。这种模式被称作交互式是因为shell与用户进行交互。这种模式也是大多数用户非常熟悉的:登录、执行一些命令、退出。当你退出后,shell也终止了。

   非交互式模式,以shell script(非交互)方式执行。在这种模式 下,shell不与你进行交互,而是读取存放在文件中的命令,并且执行它们。当它读到文件的结尾EOF,shell也就终止了。可以通过打印“$-”变量的值(代表着当前shell程序的选项标志),查看其中是否有“i”选项(表示interactive shell)来区分交互式与非交互式shell。

 登录shell和非登录shell的区别
  登录shell:是需要用户名、密码登录后才能进入的shell(或者通过"--login"选项生成的shell)

  非登录shell:当然就不需要输入用户名和密码即可打开的Shell,例如:直接命令“bash”就是打开一个新的非登录shell,在Gnome或KDE中打开一个“终端”(terminal)窗口程序也是一个非登录shell。
  执行exit命令,退出一个shell(登录或非登录shell都能退出)
  执行logout命令,退出登录shell(不能退出非登录shell)

  站在用户登录的角度来说,SHELL的类型:
  登录式shell切换:
    正常通过某终端登录
    su - UserName
    su -l UserName
    su - 切换到root用户获取root权限,并将shell环境切换为root的shell环境(能获得root用户的shell环境变量)

  非登录式shell切换:
    su UserName
    图形终端下打开命令窗口
    自动执行的shell脚本
    su 切换到root用户获取root权限,但保留普通用户的shell环境(不能获得root用户的shell环境变量)

  su命令执行后会将目录切换至原普通用户的工作目录,su -命令执行后会将目录切换至root用户的目录

 以指定用户运行要运行的命令(执行完指定的指令后,恢复原来的用户身份)
  su -c 'command' UserName

转载于:https://www.cnblogs.com/Link-Luck/p/9849523.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux用户管理是指在Linux系统中对用户进行管理和配置的过程。通过用户管理,可以实现对系统资源的访问控制和权限管理,保障系统的安全性和稳定性。 在Linux系统中,每个用户都有一个唯一的用户名和用户ID(UID),用于标识该用户在系统中的身份。同时,每个用户还可以属于一个或多个用户用户也有唯一的名和ID(GID),用于管理用户的权限和资源访问。 Linux用户管理主要包括以下内容: 1. 用户管理:包括创建、修改、删除用户账号,设置用户密码和权限等。 2. 管理:包括创建、修改、删除用户,将用户添加到中,设置权限等。 3. 权限管理:包括设置文件和目录的访问权限,控制用户对系统资源的访问权限等。 4. 账号锁定和解锁:可以通过锁定用户账号来保护系统的安全性,防止非法访问和攻击。 总之,Linux用户管理Linux系统中非常重要的一部分,对于系统的安全性和稳定性起着至关重要的作用。 ### 回答2: Linux一个开源的操作系统,它允许用户自由配置和管理系统各个方面。其中,用户Linux系统中的两个非常重要的概念,对于安全性和权限控制有着至关重要的作用。 在Linux系统中,每个用户都有一个唯一的用户名和UID(User ID),同时还可以属于一个或多个用户用户是一拥有某些共同权限的用户的集合。在Linux中,可以通过一些命令来管理用户用户,如useradd、userdel、groupadd、groupdel等命令。 用户管理是指Linux系统管理员通过控制用户的权限和访问权限来保护系统安全。在Linux系统中创建一个用户可以使用useradd命令,通过指定用户名、密码、UID等参数完成用户创建。除了创建用户还可以修改用户信息、查看用户信息等操作。可以使用usermod命令来修改用户信息,比如修改用户名、密码等。可以使用userdel命令来删除用户管理是指Linux系统管理员通过创建用户以简化用户管理和控制访问权限。在Linux系统中可以通过groupadd命令创建一个用户,然后在创建新用户时,可以指定用户属于哪个用户。可以通过gpasswd命令来修改用户的密码、添加或删除用户成员等。用户的权限也可以通过chmod命令来设置。 在实际使用中,Linux用户管理可以帮助管理员完成对系统的安全性和文件权限的控制,从而保护系统的完整性和保密性。同时对用户权限进行合理划分,能够有效防范内部攻击和恶意操作。总之,合理的用户管理是保证Linux系统安全性和完整性的关键所在。 ### 回答3: Linux操作系统作为开源操作系统的代表,它采用了强大的用户管理机制来维护系统的安全性和灵活性。 在Linux中,每个用户都具有唯一的标识符和权限,这样可以控制每个用户可以访问什么和拥有哪些权限。以下是关于Linux用户管理的更详细说明。 1. 用户管理 Linux操作系统通过创建用户来分配系统资源和限制用户访问的权限。在Linux中,用户是登录到系统的实体,每个用户都拥有独立的家目录和特定的登录名。 Linux系统中包含两种类型的用户: - 一般用户:这些用户拥有系统的普通权限。 - 系统用户:这些帐户是Linux中用于运行系统程序和服务的帐户。 在Linux中创建新用户的命令是“useradd”,创建新用户的同时可以指定该用户的家目录、密码、等信息。在创建用户后,可以使用命令“passwd”来设置用户的密码。可以使用命令“usermod”来修改用户信息,例如可以修改用户的密码、家目录、等信息。要删除用户,可以使用“userdel”命令。 2. 管理 Linux中的一个概念,每个用户必须属于一个或多个。操作系统将所有信息存储在“/etc/group”文件中。Linux系统中有两种类型的: - 一般:这些用于用户并控制访问权限。 - 系统:这些用于管理系统服务和进程。 在Linux中创建新的命令是“groupadd”,创建新的同时可以指定该的GID和其他信息。在创建后,可以使用命令“groupmod”来修改的信息,例如可以修改的名称或GID。要删除,可以使用“groupdel”命令。通过将用户加入中,可以控制用户对文件和目录的访问权限。这种访问权限在Linux文件系统中称为“文件访问控制列表”(ACL)。 总之,Linux用户管理机制是系统的关键部分,能够提供安全和灵活性。正确管理用户可以帮助管理员保护系统安全,并允许用户获得所需的访问权限。掌握Linux用户管理的技能,将有助于管理员更好地管理和维护Linux系统。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值