【Linux】Linux 之用户管理

news2025/1/13 7:51:47

Linux 之用户管理

  • 1.Linux 下的用户
  • 2.配置文件
  • 3.用户管理
    • 3.1 useradd
      • 3.1.1 创建用户并指定用户 ID
      • 3.1.2 指定用户的主目录
      • 3.1.3 指定用户的主组
    • 3.2 adduser
    • 3.3 userdel
    • 3.4 密码文件
      • 3.4.1 字段含义解释
      • 3.4.2 给用户添加密码
    • 3.5 其他与用户相关的命令
  • 4.修改用户的信息
    • 4.1 usermod
    • 4.2 举例
      • 4.2.1 修改 UID
      • 4.2.2 修改 shell
      • 4.2.3 更改用户主目录
  • 5.关于用户管理常见的面试题
    • 5.1 查找当前系统下能够登陆系统的用户
    • 5.2 统计当前系统下能够登陆系统的用户个数
    • 5.3 增加一个新用户 admin,权限是 root

1.Linux 下的用户

Linux 是一个多用户的系统,我们可以多个用户同时登陆 Linux,在 Linux 中用户有三种角色:

  • 超级用户root 拥有对系统的最高的管理权限 ID=0
  • 普通用户:(普通用户又包含系统用户和本地用户)
    • 系统用户 UID: 1 − 999 1-999 1999(Centos7 版本)、 1 − 499 1-499 1499(Centos6 版本)
    • 本地用户 UID: 1000 + 1000+ 1000+
    • UID: 即每个用户的身份标示,类似于每个人的身份证号码。
  • 虚拟用户: 虚拟用户是伪用户,在 Linux 系统中不是真实存在的(非本地用户,即使通过抓包工具得到了用户名及密码,也不能用于登录 Linux 系统),一般不会用来登录系统,它主要是用于维持某个服务的正常运行,如:FTP。

2.配置文件

每个用户有三个信息可以证明自己: 一个是 配置文件,一个是 用户组文件,一个是 用户对应的密码信息

  • 用户配置文件 /etc/passwd:记录了每个用户的基本属性,并且对所有用户可读,每一行记录一个用户,每行记录用冒号分割。
  • 用户组文件 /etc/group:用户组的所有信息存放地。
  • 用户对应密码文件 /etc/shadow:用户密码单独分离出来放在了 shadow 下,该文件只有 root 用户拥有读的权限。

3.用户管理

3.1 useradd

使用方法:

useradd -d -u [UID] -g [初始组] -s [/bin/bash] 用户

参数如下:

-c comment 给新用户添加备注 
-d home_dir 为主目录指定一个名字(如果不想用登录名作为主目录名的话) 
-e expire_date 用 YYYYY-MM-DD 格式指定一个账户过期的日期 
-f inactive_days 指定这个帐户密码过期后多少天这个账户被禁用;0 表示密码一过期就立即禁用,-1 表示禁用这个功能 
-g initial_group 指定用户登录组的 GID 或组名 
-G group ... 指定用户除登录组之外所属的一个或多个附加组 
-k 必须和 -m 一起使用,将 /etc/skel 目录的内容复制到用户的 HOME 目录 
-m 创建用户的 HOME 目录 
-M 不创建用户的 HOME 目录(当默认设置里指定创建时,才用到) 
-n 创建一个同用户登录名同名的新组 
-r 创建系统账户 
-p passwd 为用户账户指定默认密码 
-s shell 指定默认登录 shell ,有时候禁止登录使用 /sbin/nologin
-u uid 为账户指定一个唯一的 UID 

useradd 命令背后发生了什么?

  • 创建一个唯一的 UID
  • 添加一个用户名相同的用户组和一个唯一的 GID,并将用户设置为该组
  • /home 目录下创建一个与用户同名的目录
  • 设置 shell 为 /bin/bash
  • 默认情况下是不会设置用户密码的,需要使用 passwd 命令为新用户设置密码

使用举例:

添加一个名为 gaosh 的用户,并使用 bash 作为登陆的 shell。

[root@zmgaosh ~]# useradd gaosh
[root@zmgaosh ~]# tail -1 /etc/passwd
gaosh:x:1000:1000::/home/gaosh:/bin/bash

在这里插入图片描述

字段含义
gaosh用户名
x密码占位符
1001用户的 UID,它都是用数字来表示的
1001用户所属组的 GID,它都是用数字来表示的
用户描述信息对用户的功能或其它来进行一个简要的描述
/home/goash用户主目录(shell 提示符中 ~ 代表的那个)
/bin/bash用户登录系统后使用的 shell,默认是 /bin/bash

3.1.1 创建用户并指定用户 ID

[root@zmgaosh ~]# useradd -u 1111 xinsz08  # 创建用户指定 UID 为 1111

[root@zmgaosh ~]# id xinsz08   # 查看用户所属组,及 UID 和组 ID 信息
uid=1111(xinsz08) gid=1111(xinsz08) 组=1111(xinsz08)

[root@zmgaosh ~]# tail -1 /etc/passwd  # 查看 /etc/passwd 新建用户 
xinsz08:x:1111:1111::/home/xinsz08:/bin/bash

[root@zmgaosh ~]# ls /home/xinsz08/ -a  # 查看家目录默认模板
.  ..  .bash_logout  .bash_profile  .bashrc

3.1.2 指定用户的主目录

[root@zmgaosh ~]# useradd -d /opt/xinsz xinsz

[root@zmgaosh ~]# ls -a /opt/xinsz/   # 可以看到家目录跑 /opt/xinsz 下了
.  ..  .bash_logout  .bash_profile  .bashrc

[root@zmgaosh ~]# tail -1 /etc/passwd
xinsz:x:1112:1112::/opt/xinsz:/bin/bash

3.1.3 指定用户的主组

就相当于一个财务加到前台组,让财务偶尔也干前台。

[root@zmgaosh ~]# useradd qiantai  # 创建了一个前台

[root@zmgaosh ~]# id qiantai
uid=1113(qiantai) gid=1113(qiantai) 组=1113(qiantai)  

[root@zmgaosh ~]# useradd -g qiantai caiwu # 把财务放在前台的组里

[root@zmgaosh ~]# id caiwu 
uid=1114(caiwu) gid=1113(qiantai) 组=1113(qiantai)  # 可以看到财务属于前台组,万一前台请假,财务顶上干前台

3.2 adduser

adduser 是创建用户的另外一个命令,使用方法相同。

[root@zmgaosh ~]# which adduser
/usr/sbin/adduser

[root@zmgaosh ~]# ll /usr/sbin/adduser
lrwxrwxrwx 1 root root 7 4月  27 22:17 /usr/sbin/adduser -> useradd

由此可见,adduseruseradd 的软连接。

3.3 userdel

  • -r:会连同家目录和 /var/mail 的目录一同删除
    • userdel 用户名:皇帝下令斩立决
    • userdel -r 用户名:皇帝下令斩立决并抄家灭族
[root@zmgaosh ~]# userdel -r xinsz08

3.4 密码文件

密码文件放在 /etc/shadow 下。

3.4.1 字段含义解释

[root@zmgaosh ~]# head -3 /etc/shadow
root:$6$SlVomD$EBjlGVUUOnCCk.lupiqnL58ESGeVJBNCvIc7IE6LNQ9J66OEhNSvlZQvk8EJkx6laSHDeDnuVN3NnJgqZxZid.:18430:0:99999:7:::
bin:*:17834:0:99999:7:::
daemon:*:17834:0:99999:7:::

/etc/passwd 文件一样,文件中每行代表一个用户,同样使用 : 作为分隔符,不同之处在于,每行用户信息被划分为 9 9 9 个字段。每个字段的含义如下:

1-用户名 : 2-加密密码 : 3-最后一次修改时间 : 4-最小修改时间间隔 : 5-密码有效期 : 6-密码需要变更前的警告天数 : 7-密码过期后的宽限时间 : 8-账号失效时间 : 9-保留字段

  1. 账户名称。
  2. 加密后的密码,如果这一栏的第一个字符为 ! 或者 * 的话,说明这是一个不能登录的账户,从上面可以看出,ubuntu 默认的就不启用 root 账户。
  3. 最近改动密码的日期(这个是从 1970 1970 1970 1 1 1 1 1 1 日算起的总的天数)。
  4. 密码不可被变更的天数:设置了这个值,则表示从变更密码的日期算起,多少天内无法再次修改密码,如果是 0 0 0 的话,则没有限制。
  5. 密码需要重新变更的天数:如果为 99999 99999 99999 则没有限制。
  6. 密码过期预警天数。
  7. 密码过期的宽恕时间:如果在 5 中设置的日期过后,用户仍然没有修改密码,则该用户还可以继续使用的天数。
  8. 账号失效日期,过了这个日期账号就无法使用。
  9. 保留的字段。

3.4.2 给用户添加密码

方法1:

[root@zmgaosh ~]# useradd gaosh1 
[root@zmgaosh ~]# passwd gaosh1
更改用户 gaosh1 的密码
新的密码:
无效的密码: 密码未通过字典检查 - 它没有包含足够的不同字符
重新输入新的密码:
passwd:所有的身份验证令牌已经成功更新
[root@zmgaosh ~]# 

方法2:使用 echo 命令,可以实现很方便、快捷地修改用户密码。

# echo password | passwd --stdin username
[root@zmgaosh ~]# echo 123456 | passwd --stdin gaosh2
更改用户 gaosh2 的密码
passwd:所有的身份验证令牌已经成功更新。
[root@zmgaosh ~]# 

这里有个问题,如果两个不同的用户,他们的密码一样,在 /etc/shadow 中加密的 hash 值一样吗?答案是不一样,要不然太容易破解了。

3.5 其他与用户相关的命令

命令作用
id用户和组的信息
whoami查看当前有效用户名
who显示目前登入系统的用户信息
w显示已经登陆系统的用户列表
users用于显示当前登录系统的所有用户的用户列表

4.修改用户的信息

4.1 usermod

usermod [参数] 用户名

常用参数:

-u UID
-d 宿主目录
-g 起始组
-G 附加组
-s 登录 shell
-L 锁定

4.2 举例

4.2.1 修改 UID

[root@zmgaosh ~]# id xinsz
uid=1112(xinsz) gid=1112(xinsz) 组=1112(xinsz)

[root@zmgaosh ~]# usermod -u 2222 xinsz
[root@zmgaosh ~]# id xinsz
uid=2222(xinsz) gid=1112(xinsz) 组=1112(xinsz)

[root@zmgaosh ~]# 

4.2.2 修改 shell

[root@zmgaosh ~]# grep xinsz /etc/passwd
xinsz:x:2222:1112::/opt/xinsz:/bin/bash

[root@zmgaosh ~]# usermod -s /sbin/nologin xinsz
[root@zmgaosh ~]# grep xinsz /etc/passwd   
xinsz:x:2222:1112::/opt/xinsz:/sbin/nologin    # 可以看到变成了 nologin

[root@zmgaosh ~]# 

4.2.3 更改用户主目录

[root@zmgaosh ~]# usermod -m -d /opt/xinsz1 xinsz
[root@zmgaosh ~]# grep xinsz /etc/passwd
xinsz:x:2222:1112::/opt/xinsz1:/sbin/nologin    # 可以看到家目录变成了 /opt/xinsz1

5.关于用户管理常见的面试题

5.1 查找当前系统下能够登陆系统的用户

[root@zmgaosh ~]# grep /bin/bash /etc/passwd
root:x:0:0:root:/root:/bin/bash
gaosh:x:1000:1000::/home/gaosh:/bin/bash
qiantai:x:1113:1113::/home/qiantai:/bin/bash
caiwu:x:1114:1113::/home/caiwu:/bin/bash
sanwu:x:1115:1115::/home/sanwu:/bin/bash
sanwu1:x:1116:1116::/home/sanwu1:/bin/bash
gaosh1:x:1117:1117::/home/gaosh1:/bin/bash
gaosh2:x:1118:1118::/home/gaosh2:/bin/bash

[root@zmgaosh ~]# 

5.2 统计当前系统下能够登陆系统的用户个数

[root@zmgaosh ~]# grep /bin/bash /etc/passwd | wc -l

其实是在统计 /etc/passwd 文件中有多少包含 bash 的行。

5.3 增加一个新用户 admin,权限是 root

[root@zmgaosh ~]# useradd -u 0 -o admin
[root@zmgaosh ~]# grep admin /etc/passwd
admin:x:0:1119::/home/admin:/bin/bash

当你使用 -u 选项指定 UID 时,-o 选项允许你创建具有非唯一 ID 的用户,例如:

# useradd -o huey -u 501
# useradd -o dewey -u 501
# useradd -o louie -u 501

简而言之,这允许设置多个用户具有相同的权限和特权,但具有不同的主目录和密码。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1074669.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2.6 方法

思维导图: 2.6.1 什么是方法 ### 2.6.1 什么是方法 **定义**: - 方法就是一段可以重复调用的代码,使得程序的可读性、可维护性都得以提高。 **示例**: - 假设有一个游戏中需要反复发射炮弹。而发射炮弹的代码有100行。为了避免在程序中多次写下这100…

Java架构师系统架构设计性能评估

目录 1 导论2 架构评估基础系统性能衡量的基本指标2.1 系统性能的指标2.2 数据库指标2.3 并发用户数2.4 网络延迟2.4 系统吞吐量2.5 资源性能指标3 架构评估基础服务端性能测试3.1基准测试3.2 负载测试3.3 压力测试3.4 疲劳强度测试3.5 容量测试1 导论 本章的主要内容是掌握架构…

【Java】微服务——RabbitMQ消息队列(SpringAMQP实现五种消息模型)

目录 1.初识MQ1.1.同步和异步通讯1.1.1.同步通讯1.1.2.异步通讯 1.2.技术对比: 2.快速入门2.1.RabbitMQ消息模型2.4.1.publisher实现2.4.2.consumer实现 2.5.总结 3.SpringAMQP3.1.Basic Queue 简单队列模型3.1.1.消息发送3.1.2.消息接收3.1.3.测试 3.2.WorkQueue3.…

【Linux升级之路】7_进程信号

目录 一、【Linux初阶】信号入门 | 信号基本概念信号产生核心转储二、【Linux初阶】信号入门2 | 信号阻塞、捕捉、保存 一、【Linux初阶】信号入门 | 信号基本概念信号产生核心转储 链接: 【Linux初阶】信号入门 | 信号基本概念信号产生核心转储 二、【Linux初阶】…

奖品定制经营商城小程序的作用是什么

奖品是激励人员团体很好的方式,也是荣誉象征,奖牌、奖杯、高端礼盒等,同时市场中团体非常多,其需求也是很多,尤其定制方面,就更是不用说。 对奖品定制企业来说,除了线下门店获客经营外&#xf…

使用BAPI_NETWORK_COMP_*实现生产订单组件的增删改查

1、文档说明 对于生产订单组件的增删改有多种办法,比较常用的有使用内部函数CO_XT_COMPONENT_*,有改造BAPI_ALM_ORDER_MAINTAIN来实现,各有千秋。 本文档介绍,通过PS的BAPI_NETWORK_COMP_*系列BAPI,来实现常见的组件…

单链表习题(对应章节chapter2)

题目1&#xff1a;链表的中间结点 题目来源&#xff1a;leetcode链表的中间结点 第一种思路分析&#xff1a;考虑指针移动到相应的位置来做 参考代码&#xff1a;位置&#xff08;/chapter2/c/middle-link-list-node/lc1.cc&#xff09; #include <stdio.h> extern &qu…

Linux 查看是否安装memcached

telnet 127.0.0.1 11211这样的命令连接上memcache&#xff0c;然后直接输入stats就可以得到memcache服务器的版本 安装memcached &#xff1a; sudo apt-get install memcached

使用HTTP请求操作elastic search

创建索引 获取索引相关信息 查看所有索引 删除索引 向指定索引添加文档 创建文档时指定id 根据id查询doc 查询一个doc下的所有文档

面试算法22:链表中环的入口节点(2)

题目 如果一个链表中包含环&#xff0c;那么应该如何找出环的入口节点&#xff1f;从链表的头节点开始顺着next指针方向进入环的第1个节点为环的入口节点。 例如&#xff0c;在如图4.3所示的链表中&#xff0c;环的入口节点是节点3。 分析 第1步&#xff1a;确认是否包含环…

Java8实战-总结39

Java8实战-总结39 默认方法解决冲突的规则解决问题的三条规则选择提供了最具体实现的默认方法的接口冲突及如何显式地消除歧义菱形继承问题 小结 默认方法 解决冲突的规则 Java语言中一个类只能继承一个父类&#xff0c;但是一个类可以实现多个接口。随着默认方法在Java 8中引…

核货宝:服装店收银系统如何选择?收银系统选购指南!

对于各行各业而言&#xff0c;收银系统都是必备的工具。特别是对于像服装店这样的零售门店来说&#xff0c;选择一套适合的收银系统尤为重要。在选择收银系统时&#xff0c;有一些关键的技巧需要注意&#xff0c;以达到软硬件合理搭配、节省开支的目的。下面将分享四个选购服装…

MAC版Gradle构建Spring5.X源码阅读环境

前言&#xff1a; 三年前鄙人有幸在现已几乎报废的Window的DELL中搭建过Spring源码环境&#xff0c;今天&#xff0c;Mac版的搭建&#xff0c;来了。 本篇文章环境搭建&#xff1a;Spring5.2.1 Gradle5.6.3-all jdk8 IDEA2022.3版本 文章目录 1、Spring源码下载2、Gradle下载…

设计模式 - 行为型模式:策略模式(概述 | 案例实现 | 优缺点 | 使用场景)

目录 一、行为型模式 1.1、策略模式 1.1.1、概论 1.1.2、案例实现 1.1.3、优缺点 1.1.4、使用场景 一、行为型模式 1.1、策略模式 1.1.1、概论 策略模式设计的每一个算法都封装了起来&#xff0c;使他们可以相互替换&#xff0c;通过一个对象委派不同的算法给相应的客户…

Dubbo 环境隔离

通过标签实现流量隔离环境&#xff08;灰度、多套开发环境等&#xff09; 无论是在日常开发测试环境&#xff0c;还是在预发生产环境&#xff0c;我们经常都会遇到流量隔离环境的需求。 在日常开发中&#xff0c;为了避免开发测试过程中互相干扰&#xff0c;我们有搭建多套独…

基于AlexNet深度学习网络的智能垃圾分类系统matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1、基于AlexNet深度学习网络的智能垃圾分类系统概述 4.2、基于AlexNet深度学习网络的智能垃圾分类系统主要原理 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab20…

MySQ 学习笔记

1.MySQL(老版)基础 开启MySQL服务: net start mysql mysql为安装时的名称 关闭MySQL服务: net stop mysql 注: 需管理员模式下运行Dos命令 . 打开服务窗口命令 services.msc 登录MySQL服务: mysql [-h localhost -P 3306] -u root -p****** Navicat常用快捷键 键动作CTRLG设…

C语言——文件操作_学习笔记

一、引言——为什么使用文件 如果没有文件&#xff0c;我们写的程序的数据是存储在电脑的内存中&#xff0c;如果程序退出&#xff0c;内存回收&#xff0c;数据就丢失了&#xff0c;等再次运行程序&#xff0c;是看不到上次程序的数据的&#xff0c;如果要将数据进行持久化的…

仅用61行代码,你也能从零训练大模型

本文并非基于微调训练模型&#xff0c;而是从头开始训练出一个全新的大语言模型的硬核教程。看完本篇&#xff0c;你将了解训练出一个大模型的环境准备、数据准备&#xff0c;生成分词&#xff0c;模型训练、测试模型等环节分别需要做什么。AI 小白友好~文中代码可以直接实操运…

C++ 类和对象篇(三) 空类和6个默认成员函数

目录 一、空类 1. 是什么&#xff1f; 2. 空类中的成员 3. 空类的大小 二、6个默认成员函数 三、 构造函数 1. 构造函数是什么&#xff1f; 2. 为什么C要引入构造函数&#xff1f; 四、析构函数 1. 析构函数是什么&#xff1f; 2. 为什么要有析构函数&#xff1f; 五、拷贝构造…