zoukankan      html  css  js  c++  java
  • 9. Linux用户身份和能力

    root 拥有最高的系统所有权,能够管理系统的各项功能,如添加/删除用户、启动/关闭服务进程、开启/禁用硬件设备等。以root 管理员的身份工作时不会受到系统的限制

      在Linux 系统中,UID 有唯一性,因此可通过用户的UID 值来判断用户身份。在Centos 7 系统中,用户身份有下面这些。

      1)管理员 UID 为0:系统的管理员用户。
      2)系统用户UID 为1~999: Linux 系统为了避免因某个服务程序出现漏洞而被黑客提权至整台服务器,默认服务程序会有独立的系统用户负责运行,进而有效控制被破坏范围。
      3)普通用户 UID 从1000 开始:是由管理员创建的用于日常工作的用户。
      管理员创建的普通用户的UID 默认是从1000开始的(即使前面有闲置的号码)。
      在 Linux 系统中创建每个用户时,将自动创建一个与其同名的基本用户组,而且这个基本用户组只有该用户一个人。如果该用户以后被归纳入其他用户组,则这个其他用户组称之为扩展用户组。
      一个用户只有一个基本用户组,但是可以有多个扩展用户组,从而满足日常的工作需要。

     1.useradd:创建新的用户,格式为“useradd [选项] 用户名”。

      使用该命令创建用户账户时,默认的用户家目录会被存放在/home 目录中,默认的Shell 解释器为/bin/bash,而且默认会创建一个与该用户同名的基本用户组。

       

      一旦用户的解释器被设置为nologin,则代表该用户不能登录到系统中

      举例:  

    [root@Centos ~]# useradd -d /home/xinghen1216 -u 1111 -s /sbin/nologin xinghen1216

    2.groupadd:创建用户组,格式为“groupadd [选项] 群组名”。

      举例:  

    [root@Centos ~]# groupadd yunwei

    3.usermod :修改用户的属性,格式为“usermod [选项] 用户名”。

      Linux 系统中的一切都是文件,因此在系统中创建用户也就是修改配置文件的过程。用户的信息保存在/etc/passwd 文件中,可以直接用文本编辑器来修改其中的用户参数项目,也可以用usermod 命令修改已经创建的用户信息,诸如用户的UID、基本/扩展用户组、默认终端等。

       

      查看用户的默认信息  

    [root@Centos ~]# id root
    uid=0(root) gid=0(root) groups=0(root)
    [centos@Centos root]$ id
    uid=1000(centos) gid=1000(centos) groups=1000(centos),10(wheel) context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 

      将用户centos加入到root 用户组中,这样扩展组列表中则会出现root 用户组的字样,而基本组不会受到影响:  

    [root@Centos ~]# usermod -G root centos
    [root@Centos ~]# id centos
    uid=1000(centos) gid=1000(centos) groups=1000(centos),0(root)

    4.passwd :修改用户密码、过期时间、认证信息等,格式为“passwd [选项] [用户名]”。

      普通用户只能使用passwd 命令修改自身的系统密码,而root 管理员则有权限修改其他所有人的密码。root 管理员在Linux 系统中修改自己或他人的密码时不需要验证旧密码。root 管理员完全拥有普通用户的管理权限。

        

    [root@Centos ~]# passwd
    Changing password for user root.
    New password: 
    Retype new password: 
    passwd: all authentication tokens updated successfully.
    [root@Centos ~]# passwd centos
    Changing password for user centos.
    New password: 
    Retype new password: 
    Sorry, passwords do not match.
    New password: 
    Retype new password: 
    passwd: all authentication tokens updated successfully.  
    [root@Centos ~]# passwd -l centos
    Locking password for user centos.
    passwd: Success
    [root@Centos ~]# passwd -u centos
    Unlocking password for user centos.
    passwd: Success
    [root@Centos ~]# passwd -S centos 
    centos PS 2020-08-12 0 99999 7 -1 (Password set, SHA512 crypt.)
    [root@Centos ~]# 
    [root@Centos ~]# passwd -l centos
    Locking password for user centos.
    passwd: Success
    [root@Centos ~]# passwd -S centos 
    centos LK 2020-08-12 0 99999 7 -1 (Password locked.)  
    使用passwd -l锁定用户后,仍可使用su - 用户名 登录
    [root@Centos ~]# passwd -l centos 
    Locking password for user centos.
    passwd: Success
    [root@Centos ~]# su - centos 
    Last login: Wed Aug 12 15:49:00 CST 2020 on pts/2

    5.userdel 命令用于删除用户,格式为“userdel [选项] 用户名”。
    在执行删除操作时,该用户的家目录默认会保留下来,此时可以使用-r 参数将其删除。
      -f 强制删除用户
      -r 同时删除用户及用户家目录  

    [root@Centos ~]# id centos
    uid=1000(centos) gid=1000(centos) groups=1000(centos)
    [root@Centos ~]# userdel -r centos 
    [root@Centos ~]# id centos
    id: centos: no such user
    [root@Centos ~]# cd /home/
    [root@Centos home]# ll
    total 0
    drwxr-xr-x. 2 root root 6 Aug 12 15:28 xinghen1216
  • 相关阅读:
    spring源码下载
    java资料共享
    《Linux命令行与shell脚本编程大全》读书笔记
    《微服务设计》读书笔记
    tornado关于AsyncHTTPClient的使用笔记
    java stackoverflowerror与outofmemoryerror区别(转)
    JAVA关于泛型的笔记
    在JAVA中返回类型使用泛型T和Object有什么区别?
    《构架师的12项修炼》读书笔记
    关于控制台输入的代码怎么跑单元测试的问题记录
  • 原文地址:https://www.cnblogs.com/xinghen1216/p/13491582.html
Copyright © 2011-2022 走看看