用户和组管理

1. 何为用户何为组?

1.1 用户和组概念
Authentication:认证
Authorization:授权
Accouting:审计

1.2 用户分类
Linux用户分为管理员和普通用户两种:

用户类别用户ID
管理员0
普通用户1-65535

其中普通用户又分为系统用户和登录用户两种:

用户类别用户ID
系统用户1-999(为守护类进程获取系统资源而完成权限指派的用户)
登录用户1000-60000(为了完成交互式登录使用的用户)

1.3 Linux安全上下文

运行中的程序:进程(process)

  • 以进程发起者的身份运行
    • root:cat
    • tom:cat
  • 进程所能够访问的所有资源的权限取决于进程的发起者的身份
    Linux通过安全上下文的概念完成用户权限的指派。
  • 先判断用户是否是某文件的属主
  • 再判断用户是否属于某个组
  • 最后定其为其他用户

1.4 Linux用户组类别

用户组类别特性
私有组创建用户时,如果没有为其指定所属的组,系统会自动为其创建一个与用户名相同的组
基本组用户的默认组
附加组默认组以外的其他组

2. Linux用户和组相关的配置文件

2.1 各配置文件说明

配置文件作用
/etc/passwd用户及其属性信息(名称、uid、基本组id等等)
/etc/group组及其属性信息
/etc/shadow用户密码及其相关属性
/etc/gshadow组密码及其相关属性。在用户执行基本组切换时使用

2.2 密码复杂性
密码复杂性策略:

  • 使用数字、大写字母、小写字母及特殊字符中至少3种
  • 足够长
  • 使用随机密码,不要使用有意义的单词或数字
  • 定期更换,不要使用最近曾经使用过的密码

3. 用户和组相关的管理命令

3.1 用户管理
3.1.1 用户创建命令useradd

//语法:useradd [option] USERNAME
    -u UID      //[UID_MIN,UID_MAX]定义在/etc/login.defs文件中
    -g GID      //指定用户所属基本组,可为组名或GID
    -G groupname,...    //附加组,可以有多个,用逗号隔开。组groupname必须事先存在
    -c "COMMENT"        //注释信息
    -d /path/to/directory       //指定用户的家目录。此目录必须不能事先存在, \
                                //否则将不会从/etc/skel中复制环境设置文件
    -s shell        //这里的shell最好使用/etc/shells里面有的shell, \
                    // /etc/shells指定了当前系统可用的安全shell
    -M          //创建用户时不给其创建家目录
    -r          //添加一个系统用户
    -D          //直接打印/etc/default/useradd文件的内容或配合其它选项 \
                //(例如-s SHELL)直接修改/etc/default/useradd文件中的默认值

3.1.2 用户删除命令userdel`//usermod 修改用户属性
//语法:usermod [options] username
-u UID
-g GID
-a -G groupname //不使用-a选项,会覆盖此前的附加组
-d -m //改变用户家目录的同时把原来家目录的文件移动到新的家目录中
-e YYYY-MM-DD //指明用户帐号过期日期
-f INACTIVE //设定非活动期限
-L //锁定帐号。
//被锁定的帐号在/etc/shadow文件中密码前面会有一个!感叹号
-U //解锁帐号

//chsh 修改用户的默认shell
//语法:chsh [options] [username]
-s SHELL`

//语法:userdel [option] USERNAME
    -r      //删除用户的同时删除其家目录(userdel默认不会删除其家目录)

3.1.3 查看用户帐号的信息命令id

id      //查看用户的帐号属性信息
    -u      //查看UID
    -g      //查看GID
    -G      //查看Groups

3.1.4 修改用户帐号属性的命令

//usermod   修改用户属性
//语法:usermod [options] username
    -u UID
    -g GID
    -a -G groupname    //不使用-a选项,会覆盖此前的附加组
    -d -m   //改变用户家目录的同时把原来家目录的文件移动到新的家目录中
    -e YYYY-MM-DD       //指明用户帐号过期日期
    -f INACTIVE         //设定非活动期限
    -L      //锁定帐号。
            //被锁定的帐号在/etc/shadow文件中密码前面会有一个!感叹号
    -U      //解锁帐号
  
//chsh  修改用户的默认shell
//语法:chsh [options] [username]
    -s SHELL

3.2 密码管理

3.2.1 密码管理命令passwd

语法:passwd [options] [USERNAME]
    --stdin     //从标准输入获取用户密码, \
                //例:echo "redhat"|passwd --stdin user1
    -l      //锁定用户
    -u      //解锁用户
    -d      //删除用户密码
    -n mindays      //指定最短使用期限
    -x maxdays      //指定最长使用期限
    -w warndays     //提前多少天开始警告
    -i inactivedays     //非活动期限,密码过期后到禁用前的这段时间

3.2.2 密码生成工具openssl

//语法:openssl command [ command_opts ] [ command_args ]
    command     //包含标准命令、消息摘要命令、加密命令
        version     //查看程序版本号
        dgst        //提取特征码
        passwd      //生成密码
        rand        //生成伪随机数

//提取特征码
[root@localhost ~]# openssl dgst -md5 /etc/fstab
MD5(/etc/fstab)= a977cc5e638d779ed880f3fee6d7067e

//生成密码 openssl passwd -1 -salt string        //string一般为8位
[root@localhost ~]# openssl passwd -1 -salt hellotom
Password:
$1$hellotom$HpEDmPGqWwhP/eHg0kJHA0

//生成随机数 openssl rand -base64 NUM
//NUM表示随机数的长度
[root@localhost ~]# openssl rand -base64 20
S/q8tjUSBuUNHb+0cgDX66dbvTQ=

3.3 组管理

3.3.1 创建组命令groupadd

//语法:groupadd [options] GROUP
    -g GID      //指定GID
    -r          //添加一个系统组

3.3.2 删除组命令groupdel

//语法:groupdel [options] GROUP
//删除组时只需要指定组名即可
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值