• Linux用户与用户组管理


    Linux用户与用户组管理

    Linux系统是一个多用户多任务的操作系统,任何-一个要使用系统资源的用户,都必须首先向系统管理员申请-一个账号,然后以这个账号的身份进入系统。

    用户的账号一方面可以帮助系统管理员对使用系统的用户进行跟踪,并控制他们对系统资源的访问;另- .方面也可以帮助用户组织文件,并为用户提供安全性保护。

    每个用户账号都拥有一个唯一的用户名和各自的密码。

    用户在登录时输入正确的用户名和密码后,就能够进入系统和自己的主目录。

    要想实现用户账号的管理,要完成的工作主要有如下几个方面:

    用户账号的添加、删除、修改以及用密码的管理

    用户组的管理

    注意三个文件:

    /etc/passwd     存储用户的关键信息

    /etc/group        存储用户组的关键信息

    /etc/shadow      存储用户的密码信息

    1、用户管理

    ①添加用户

    常用语法:  #useradd 选项 用户名

    常用选项:

    -g: 表示指定用户的用户主组,选项的值可以是用户组的id, 也可以是组名

    -G: 表示指定用户的用户附加组,选项的值可以是用户组的id, 也可以是组名

    -u: uid, 用户的id (用户的标识符),系统默认会从500之后按顺序分配uid, 如果不想使用系统分配的,可以通过该选项自定义[类似于腾讯QQ的自选靓号情况]

    -c:Comment 添加注释

    案例: 创建用户zhangsan,不带任何选项

     

     

    验证是否成功:

    a.验证/etc/passwd的最后一行,查看是否有zhangsan的信息;

     

     b.验证是否存在家目录(在Centos下创建好用户之后随之产生一个同名家目录);

     扩展认识passwd文件:

     

    用户名:密码:用户ID:用户组ID:注释:家目录:解释器shell

    用户名: 创建新用户名称,后期登录的时候需要输入;

    密码:  此密码位置一般情况都是“x”,表示密码的占位;

    用户ID: 用户的识别符;

    用户组ID:  该用户所属的主组ID ;

    注释:  解释该用户是做什么用的;

    家目录: 用户登录进入系统之后默认的位置;

    解释器shell: 等待用户进入系统之后,用户输入指令之后,该解释器会收集用户输入的指令,传递给内核处理;

    注意:  在不添加选项的时候,执行useradd之后会执行一系列的操作

    a.创建同名的家目录;

    b.创建同名的用户组;

    案例:添加选项,创建用户lisi,使lisi属于主组1001,附加组1000,自选靓号666

     

     

    注意: 查看用户的主组可以查看passwd 文件,查看附加组可以查看group文件。

    ②修改用户

    常用语法:  #usermod 选项 用户名

    常用选项:

    -g: 表示指定用户的用户主组,选项的值可以是用户组的id, 也可以是组名

    -G: 表示指定用户的用户附加组,选项的值可以是用户组的id, 也可以是组名

    -u: uid, 用户的id (用户的标识符),系统默认会从1000之后按顺序分配uid, 如果不想使用系统分配的,可以通过该选项自定义[类似于腾讯QQ的自选靓号情况]

    -l:修改用户名

    案例:  修改zhangsan用户主组为1000,附加组改为1001

    #usermod -g 1000 -G 1001 zhangsan

     

    案例:  修改zhangsan用户用户名,改为wangerma

    #usermod- I 新的用户名  旧的用户名

    #usermod -l wangerma zhangsan

    ③设置密码

    Linux不允许没有密码的用户登录到系统,因此前面创建的用户目前都处于锁定状态,需要设置密码之后才能登录计算机。

    常用语法: #passwd 用户名

    案例: 设置wangerma用户的密码

    注意:密码须为大小写字母+数字组成,在设置密码的时候也是没有任何输入提示的,放心输入,确保两次输入的密码一-致,按下回车即可

    也可以使用弱密码,但是不建议,否则会看到以下的提示:

     

    设置密码之后shadow文件中的体现,能够看出lisi用户没有密码的

    在设置用户密码之后可以登录帐号,例如此处需要登录wangerma

    切换用户命令: #su [用户名]  (switch user)

    如果用户名不指定则表示切换到root用户。

     

    切换用户需要注意的事项:

    a.从root往普通用户切换不需要密码,但是反之则需要root密码;

    b.切换用户之后前后的工作路径是不变的;

    c.普通用户没有办法访问root用户家目录,但是反之则可以;

    ④删除用户

    常用语法: #userdel 选项  用户名

    常用选项:

    -r: 表示删除用户的同时,删除其家目录;

    案例: 删除wangerma用户

    注意:已经登录的 wangerma 用户删除的吋候提示删除失败,但是没有登录的lisi 用户可以正常刪除。

    解决办法: 筒单粗暴,kill対应用户的全部进程

    2、用户组管理

    每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux系统对用户组的规定有所不同,如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。

    用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改、实际上就是对/etc/group文件的更新。

    扩展认识group文件:

         

    用户组名:密码:用户组ID:组内用户名

     密码: x表示占位符,虽然用户组可以设置密码,但是绝大部分的情况下不设置密码;

    组内用户名:表示附加组是该组的用户名称;

    ①用户组添加

    常用语法: #groupadd 选项 用户组名

    常用选项:

    -g: 类似用户添加里的“-u”,-g 表示选择自己设置一个自定义的用户组ID数字,如果自己不指定,则默认从1000之后递增;

    案例: 使用groupadd指令创建一个新的用户组,命名为Administrators

     

    ②用户组编辑

    常用语法: #groupmod 选项 用户组名

    常用选项:

    -g: 类似用户修改里的“-u”, -g表示选择自己设置-一个自定义的用户组ID数字

    -n: 类似于用户修改“1”,表示设置新的用户组的名称

    案例 : 修改Administrators用户组,将组ID从1002改成1020,将名称改为admins

    ③用户组删除

    常用语法: #groupdel 用户组名

     

    注意:  当如果需要删除一 个组,但是这个组是某个用户的主组时,则不允许删除;如果确实需要删除,则先从组内移出所有用户。

                                    

     

  • 相关阅读:
    云原生之史上最全K8S环境搭建(强烈建议收藏)
    clion本地调试nginx-1.22.1
    五笔字根查询接口,五笔输入法数据
    codeforces刷题二
    全局视角看技术-Java多线程演进史
    890. 查找和替换模式
    【mysql是怎样运行的】-客户端与服务器连接
    47-用户和权限管理
    鱼眼相机去畸变(图像拉直/展开/矫正)算法及实战总结
    nacos适配达梦、瀚高、人大金仓数据库及部分源码探究
  • 原文地址:https://blog.csdn.net/m0_62064241/article/details/126207261