一、用户分类

1、管理员和普通用户

1️⃣:管理员   ——    用户ID:0

2️⃣:普通用户 ——   用户ID:1—65535

2、普通用户又分为系统用户和登陆用户

1️⃣:系统用户 —— 用户ID:1—999 (一般系统用户不需要登录的,都是给护远程使用的)

2️⃣:登陆用户 —— 用户ID:1000—60000(为了完成交互式登陆而使用的用户)

3、示例

//创建一个普通用户,查看ID
[root@localhost ~]# useradd zhangsan
[root@localhost ~]# id zhangsan
uid=1000(zhangsan) gid=1000(zhangsan) 组=1000(zhangsan) //创建一个系统用户,查看ID
[root@localhost ~]# useradd -r -M -s /sbin/nologin lisi
[root@localhost ~]# id lisi
uid=991(lisi) gid=987(lisi) 组=987(lisi)

二、用户和组的类别

1️⃣:私有组 ——创建用户时,如果没有为其指定所属的组,系统会自动为其创建一个与用户名相同的组

2️⃣:基本组 ——用户的默认组

3️⃣:附加组 ——除默认组以外其他的组

三、用户和组的相关配置文件

1️⃣:/etc/passwd —— 用户及其属性信息

2️⃣:/etc/shadow ——用户密码及相关信息

3️⃣:/etc/group —— 组及其属性信息

4️⃣:/etc/gshadow —— 组密码及其相关属性

四、用户和组的相关命令

1、useradd —— 创建用户命令

useradd
-u:指定用户的UID
-c<备注>:加上备注文字
-d<家目录>:指定用户家目录,该目录必须事先存在
-g<基本组名>:指定用户所属的基本组
-G<附加组名>:指定用户所属的附加组,可以有多个,用逗号隔开
-M:不要自动创建用户的家目录
-r:创建一个系统用户

2、userdel —— 用户删除命令

userdel
-f:强制删除用户,即使用户当前已登录
-r:删除用户的同时,删除与用户相关的所有文件。

3、usermod —— 修改用户信息命令

usermod
-u<uid>:修改用户UID
-s<shell>:修改该用户帐号的新登录 shell
-c<备注>:修改用户帐号的备注信息
-d<登入目录>:修改用户登入时的家目录
-e<有效期限>:修改帐号的有效期限
-g<群组>:修改用户所属的群组
-G<群组>;修改用户所属的附加群组
-l<帐号名称>:修改用户帐号名称
-L:锁定用户密码,使密码无效
-U:解除密码锁定

4、groupadd —— 组创建命令

groupadd
-g:指定新建工作组的GID
-r:创建系统工作组,系统工作组的组ID小于500

5、groupdel —— 组删除命令

groupdel
//删除组名只需要指定组名即可 groupdel groupname

6、groupmod —— 组信息修改命令

groupmod
-g, --gid GID 将组 GID 改为新的 GID
-n, --new-name 修改新的组名

7、su —— 切换用户命令

su
-c<指令>或--command=<指令>:执行完指定的指令后,即恢复原来的身份 su username :非登录式切换(切换后,任然在root家目录下,不会跳转到该用户的家目录)
su - usernaem :登录式切换 (切换后,自动跳转到该用户的家目录)
su - :不指定用户名,则直接切换到root用户

五、密码管理

1、passwd —— 设置用户密码命令

passwd
--stdin //标准输入获取用户密码(也叫明文获取用户密码)
e.g:[root@localhost ~]# echo '123456' | passwd --stdin lisi -d:删除用户密码,仅有系统管理者才能使用
-f:强制执行
-l:锁住用户密码
-u:解开已上锁的用户密码
-s:列出密码的相关信息,仅有系统管理者才能使用
-n:指定使用最短期限
-x:指定使用最长期限
-w:指定多少天开始警告

2、openssl —— 密码生成工具

openssl  command

command
dgst //提取特征码
passwd //生成密码
rand //生成伪随机数
version //查看程序版本号 示例
//提取特征码
[root@localhost ~]# openssl dgst -md5 /etc/passwd
MD5(/etc/passwd)= 93690d490a4c6767084ab1c4c19a22a5
[root@localhost ~]# openssl dgst -md5 /etc/fstab
MD5(/etc/fstab)= f57f5c4e8baa2e133f583c88bfb69abd //生成密码
格式:openssl passed -number(1-6) -salt 杂质词(string:一般为8位)
[root@localhost ~]# openssl passwd -1 -salt password
Password:
$1$password$7ZK8mMeLGXxbNPeJEFJOU0 //生成随机数
格式:openssl rand -base64 num(num为随机数长度)
[root@localhost ~]# openssl rand -base64 10
1F3boAMqLShFKg==
[root@localhost ~]# openssl rand -base64 20
Jo35wmVC2X2Qw4WwjYJY90/1J/k=
[root@localhost ~]# openssl rand -base64 30
LZPA3UcV4yYEaD7G5ywVo9j+SCU8+i6ovrik0MPh
[root@localhost ~]# openssl rand -base64 40
ZjqZxMsdj7MJM0IlUzrDj2WNRlZ+xDH2C3FI5YZbSx8n13KiOim5SA==
[root@localhost ~]# openssl rand -base64 50
RjkM9gcXwOBdKzlDdH6ZHqXknJfHK9vi1IiSbTaDMiLeUpmg3ab6c5VV8twfs+sC
To8=

Linux_用户和组管理的更多相关文章

  1. Solaris用户管理(一):用户与组管理

    Solaris用户管理(一):用户与组管理  2008-07-01 09:19 用户管理是系统管理的基础.Solaris中不但支持传统Unix所支持的用户和组的概念,还从Solaris 8开始引入了基 ...

  2. 总结描述用户和组管理类命令的使用方法,系统用户相关信息,取出主机IP地址

    1.列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可. [root@db146 ~]# who|cut -f1 -d' ' |sort -u root 2.取出最后 ...

  3. linux基础之用户和组管理及权限

    一.用户和组管理 相关配置文件 /etc/passwd: 用户名 : 密码占位符 : UID : GID : COMMENTS : 家目录 :默认shell /etc/group: 组名 : 组密码占 ...

  4. linux系统用户和组管理

    用户和组管理 Linux是多用户多任务的网络操作系统,作为网络管理员,掌握用户的组的创建与管理至关重要. 学习要点: 了解用户和组的群的配置文件. 熟悉掌握Linux下用户的创建和维护管理. 熟悉掌握 ...

  5. Linux 用户和组管理

    这是用户和组管理的知识点,不想看文字就看视频吧,还是视频为主,文字为备忘录 视频链接: 项目1用户管理 1.创建一个新用户user01,设置其主目录为/home/user01: #useradd –d ...

  6. 一、Vim编辑器 二、用户和组管理 三、软件的安装(jdk,mysql) 四、Shell编程

    一.Vim编辑器的使用 1. vim编辑器的运行模式 编辑模式:等待用户编辑命令的输入 插入模式:编辑文本内容 命令模式:执行命令 2. 使用 :vim 文件名 3. 查看当前vim编辑器介绍:vim ...

  7. (转)AIX 用户和组管理

    AIX 用户和组管理 原文:https://www.ibm.com/developerworks/cn/aix/library/au-aixuseradmin/ 管理 IBM AIX 中的用户和组是管 ...

  8. Linux用户与组管理命令

    1.列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可. who | cut -d" " -f1 | sort -u 或 who | cut -d ...

  9. (转)Centos 7.3 用户和组管理

    Centos 7.3 用户和组管理 原文:http://blog.csdn.net/github_39069288/article/details/73306489 3.1 用户和密码配置文件 pas ...

随机推荐

  1. CSS3新增了哪些新特性

    一.是什么 css,即层叠样式表(Cascading Style Sheets)的简称,是一种标记语言,由浏览器解释执行用来使页面变得更为美观 css3是css的最新标准,是向后兼容的,CSS1/2的 ...

  2. 蒙特卡洛——使用CDF反函数生成非均匀随机数

    均匀随机数生成   先来说说均匀随机数生成,这是非均匀随机数的生成基础.   例如,我们现在有drand()函数,可以随机生成[0,1]范围内的均匀随机数. 要求一个drand2()函数,能够生成[0 ...

  3. C++ new和delete运算符得简单使用

    NEW C++ 中的new运算符用来分配内存,和c语言中得malloc有相似得功能. 使用new为当个元素开辟内存空间,并返回地址 typeName *pointer_name =new typeNa ...

  4. NNLM原理及Pytorch实现

    NNLM NNLM:Neural Network Language Model,神经网络语言模型.源自Bengio等人于2001年发表在NIPS上的<A Neural Probabilistic ...

  5. 在Android的App中动态的加载Java类

    原文的地址:http://yenliangl.blogspot.com/2009/11/dynamic-loading-of-classes-in-your.html 我正在编写一个应用程序能够加载别 ...

  6. UVA11419 我是SAM

    题意:      给你一个n*m的矩阵,上面有一些格子上有目标,我们可以在格子的外面用枪打目标,一发子弹可以消灭一行或者一列目标,问你最少多少枪能把目标打光,并且输出开枪的位置,题目没说spj(特判) ...

  7. UVA11624大火蔓延的迷宫

    题意:     给1个n*m的网格,上面有的点能走,有的点不能走(墙),然后有的点是火源,火源和人一样,每次都是上下左右四个方向蔓延,速度一样是1,火也不可以从墙上跨过去,给你人的起点,终点是只要走到 ...

  8. Python中Numpy模块的使用

    目录 NumPy ndarray对象 Numpy数据类型 Numpy数组属性 NumPy NumPy(Numerical Python) 是 Python 的一个扩展程序库,支持大量的维度数组与矩阵运 ...

  9. MS06-040漏洞研究(上)【转载】

    课程简介 我在之前的课程中讨论过W32Dasm这款软件中的漏洞分析与利用的方法,由于使用该软件的人群毕竟是小众群体,因此该漏洞的危害相对来说还是比较小的.但是如果漏洞出现在Windows系统中,那么情 ...

  10. Intel汇编程序设计-整数算术指令(下)

    7.5  扩展加法和减法 扩展精度的假发和减法是指任意尺寸大小数字的加法和减法.例如要求你写一个C++程序,把两个1024位的整数相加,解决方案可不是那么简单!但在汇编语言中,ADC(带进位加)指令和 ...