linux用户与组的管理(命令加入、手动加入、加入组、用户之间的切换)

linux用户与组的管理(命令加入、手动加入、加入组、用户之间的切换)

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

 

一、用户登录的时候须要验证的是这两个文件

检測username   Login:  root                        到该文件夹下检查 /etc/passwd

检測用password   Passwd:  123456                到该文件夹下检查  /etc/shadow

/etc/Passwd下的 字段(每一行为一个用户)

语法:

root:x:0:0:root:/root:/bin/bash           (/etc/passwd)

x是占位符,代表password 

root:$1$NV0hQ/3m$nKludCy6gZOJ8WX/zADeU1:15321:0:99999:7:::      (/etc/shadow)

username称:MD5: 加密后的口令:从開始到创建该用户的时间差:两次改动口令最小的时间间隔:两次改动口令最大时间间隔:警告时间:过期 :  空暇时间

超出最大天数不改动该用户会失效

 

加密採用默认的MD5  

将passwd里面的password转存到shadow中

pwconv  :将passwd文件转换成shadow

将shadow中加密password返回到x位置,运行该命令 pwunconv同一时候/etc/shadow这个文件将不会存在了。

 

 

二、用户的加入步骤:

第一种方法、用useradd命令

useradd  name(lisi)

假设运行下面的命令:

       #useradd lisi

造成的影响是:

       /etc/passwd     加入一行  保存username

       /etc/shadow     保存password

       /home/lisi     产生同名的文件夹

        [root@localhost root]# ls -a /home/lisi

. ..  .bash_history  .bash_logout .bash_profile  .bashrc  .emacs file1  .gtkrc

       /etc/group   添加一行,组。

当用useradd加入用户时在etc/group下会默认加入一行这一行是该用户所代表的组,

默认组中是没有成员的例如以下所看到的:

lisi:x:500:

有成员的

lisi:x:503:zhy1,zhy

      

另外一种方法; 手动加入用户

       1)#vi  /etc/passwd

              Zhy2::504:504:csdnphpstudent:/home/zhy2:/bin/bash

                     取消shadow   pwunconv

                     恢复shadow   pwconv

                     在home下加入

                     # mkdir    /home/lisi

 

/etc/skel  该文件夹保存新用户的脚本文件的文件夹(/home/u_name中的隐含文件)

将/etc/skel文件夹下的文件拷贝到 /home/lisi(用useradd命令这个复制操作是自己主动的)

/etc/login.defs—用户环境的设置

三、手动加入用户与用useradd加入的差别

 

用useradd加入的用户由于是系统自己加入的

通过已经定义好的脚本文件将skel里的脚本分给每个

在/home/下新加入的用户,这里当读到/etc/login.defs这个文件时

这里设定的umask是077,所以最后创建完的文件夹的权限就是700

相反手动加入的用户,在home下加入 与上面同名的用户文件夹

#mkdir   /home/zhy2 ,这时创建的该文件夹的权限就不会受/etc/login.defs

的影响,它是以它的父文件夹的umask值为标准,所以手动加入的用户的权限就是

777-home的umask所得到的。

 

四、加入一个组

#groupadd  组名(该组名必须是一个用户)

打开:这个文件夹 /etc/group你能够看到:

组名:口令: gid 改组中的用户(用,分隔开)例如以下

zhy4:x:503:zhy1,zhy

 

五、对组的编辑

向组中加入一个成员

#gpasswd -a  user  group

删除成员从组中

#gpasswd -d  user  group

 

补充:

1、不加-的切换用户

[。。。。。lisi]  su   zhy

当前更换的用户为zhy  可是文件夹不变

2、加-的用户切换

[。。。。。lisi]  su  –  zhy

当前更换的用户为lisi  可是文件夹变为~

[。。。。。~] 

这里的~表示宿主的工作文件夹

假设是  Root   /root

假设是  lisi    /home/lisi

 

假设一个文件夹没有x权限,那么cd就不能用

假设一个文件夹没有r权限,ls无法使用

假设一个文件夹没有w权限,touch mkdir….

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118078.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 非常好的理解遗传算法的例子有哪些_知觉理解性的例子

    非常好的理解遗传算法的例子有哪些_知觉理解性的例子遗传算法的手工模拟计算示例为更好地理解遗传算法的运算过程,下面用手工计算来简单地模拟遗传算法的各   个主要执行步骤。      例:求下述二元函数的最大值:   (1)个体编码          遗传算法的运算对象是表示个体的符号串,所以必须把变量x1,x2编码为一种      符号串。本题中,用无符号二进制整数来表示。          因x1,x2

    2022年9月13日
    0
  • 【转】VS2013 产品密钥 – 所有版本[通俗易懂]

    【转】VS2013 产品密钥 – 所有版本[通俗易懂]VS2013产品密钥–所有版本VisualStudioUltimate2013KEY(密钥):BWG7X-J98B3-W34RT-33B3R-JVYW9VisualStudioPremium2013KEY(密钥):FBJVC-3CMTX-D8DVP-RTQCT-92494VisualStudioProfessional2013KEY(密钥):XD…

    2022年5月19日
    42
  • Python之functools库

    functools库用于高阶函数,指那些作用于函数或者返回其他函数的函数functools提供方法如下:cmp_to_key将老式的比较函数转换为关键字函数,与接收keyfunction的函数

    2021年12月19日
    62
  • 简述SOAP协议「建议收藏」

    简述SOAP协议「建议收藏」8个月过去了,依旧清楚的记得研究生复试时,老师问我SOAP协议是啥(当时还不知道这个协议的名字到底该怎么写),今天偶然之间看见了一篇博客提到了SOAP(见下图),于是就查了一下SOAP协议。SOAP是基于XML的简易协议,可使应用程序在HTTP之上进行信息交换。更简单地说:SOAP是用于访问网络服务的协议。什么是SOAP?SOAP指简易对象访问协议SOAP是一种…

    2022年7月27日
    1
  • javaquartz定时任务设置时间,太牛了![通俗易懂]

    javaquartz定时任务设置时间,太牛了![通俗易懂]前言其实前几篇文章已经写了好多有关于Spring源码的文章,事实上,很多同学虽然一直在跟着阅读、学习这些Spring的源码教程,但是一直都很迷茫,这些Spring的源码学习,似乎只是为了面试吹逼用,我大概问过一些同学,很多同学看了很长时间的Spring但是依旧不知道如何将这些学到的知识运用到实际的案例上!其实这个问题很好解决,如果你在开发中很少能够遇见需要Spring扩展时,不妨把目光放到一些依托于Spring的项目,看看它们是如何运用Spring的扩展点的。对于Spring的学习,我认为最终真正学会的

    2022年7月13日
    34
  • keepalived+Nginx实现高可用主从集群

    keepalived+Nginx实现高可用主从集群

    2021年6月3日
    95

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号