useradd命令,usermod命令,userdel命令

2024-04-12 07:58
文章标签 命令 useradd usermod userdel

本文主要是介绍useradd命令,usermod命令,userdel命令,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

useradd命令

        useradd 命令用于创建新的用户,格式为“useradd [选项] 用户名”。可以使用 useradd 命令创建用户账户。使用该命令创建用户账户时,默认的用户家目录会被存放在/home 目录中,默认的 Shell 解释器为/bin/bash,而且默认会创建一个与该用户同名的基本用户组。这些默认设置可以根据表 5-1 中的 useradd 命令参数自行修改。

表 5-1 useradd 命令中的用户参数以及作用
-d                  指定用户的家目录(默认为/home/username)
-e                  账户的到期时间,格式为 YYYY-MM-DD.
-u                  指定该用户的默认 UID
-g                  指定一个初始的用户基本组(必须已存在)
-G                 指定一个或多个扩展用户组
-N                 不创建与用户同名的基本用户组
-s                  指定该用户的默认 Shell 解释器

        下面我们创建一个普通用户并指定家目录的路径、用户的 UID 以及 Shell 解释器。在下面的命令中,请注意/sbin/nologin,它是终端解释器中的一员,与 Bash 解释器有着天壤之别。一旦用户的解释器被设置为 nologin,则代表该用户不能登录到系统中:

[root@localhost ~]# useradd -d /home/linux -u 8888 -s /sbin/nologin linuxprobe
[root@localhost ~]# id linuxprobe
uid=8888(linuxprobe) gid=8888(linuxprobe) 组=8888(linuxprobe)

usermod命令

         usermod 命令用于修改用户的属性,格式为“usermod [选项] 用户名”。前文曾反复强调,Linux 系统中的一切都是文件,因此在系统中创建用户也就是修改配置文件的过程。用户的信息保存在/etc/passwd 文件中,可以直接用文本编辑器来修改其中的用户参数项目,也可以用 usermod 命令修改已经创建的用户信息,诸如用户的 UID、基本/扩展用户组、默认终端等。usermod 命令的参数以及作用如表 5-2 所示。

 

表 5-2 usermod 命令中的参数及作用
-c               填写用户账户的备注信息
-d -m         参数-m 与参数-d 连用,可重新指定用户的家目录并自动把旧的数据转移过去
-e               账户的到期时间,格式为 YYYY-MM-DD
-g               变更所属用户组
-G              变更扩展用户组
-L               锁定用户禁止其登录系统
-U              解锁用户,允许其登录系统
-s              变更默认终端
-u               修改用户的 UID

大家不要被这么多参数吓坏了。我们先来看一下账户 linuxprobe 的默认信息: 

[root@localhost ~]# id linuxprobe
uid=8888(linuxprobe) gid=8888(linuxprobe) 组=8888(linuxprobe)

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

[root@localhost ~]# usermod -G root linuxprobe
[root@localhost ~]# id linuxprobe
uid=8888(linuxprobe) gid=8888(linuxprobe) 组=8888(linuxprobe),0(root)

再来试试用-u 参数修改 linuxprobe 用户的 UID 号码值。除此之外,我们还可以用-g 参数修改用户的基本组 ID,用-G 参数修改用户扩展组 ID。

[root@localhost ~]# usermod -u 1000 linuxprobe
[root@localhost ~]# id linuxprobe
uid=1000(linuxprobe) gid=8888(linuxprobe) 组=8888(linuxprobe),0(root)

paaawd命令

passwd 命令用于修改用户密码、过期时间、认证信息等,格式为“passwd [选项] [用户名]”。普通用户只能使用 passwd 命令修改自身的系统密码,而 root 管理员则有权限修改其他所有人的密码。更酷的是,root 管理员在 Linux 系统中修改自己或他人的密码时不需要验证旧密码,这一点特别方便。既然 root 管理员可以修改其他用户的密码,就表示完全拥有该用户
的管理权限。passwd 命令中可用的参数以及作用如表 5-3 所示。
表 5-3 passwd 命令中的参数以及作用
-l            锁定用户,禁止其登录
-u           解除锁定,允许用户登录
--stdin    允许通过标准输入修改用户密码,如 echo "NewPassWord" | passwd --stdin Username
-d           使该用户可用空密码登录系统
-e          强制用户在下次登录时修改密码
-S         显示用户的密码是否被锁定,以及密码所采用的加密算法名称

假设您有位同事正在度假,而且假期很长,那么可以使用 passwd 命令禁止该用户登录系统,等假期结束回归工作岗位时,再使用该命令允许用户登录系统,而不是将其删除。这样既保证了这段时间内系统的安全,也避免了频繁添加、删除用户带来的麻烦:

[root@localhost ~]# passwd -l linuxprobe
锁定用户 linuxprobe 的密码 。
passwd: 操作成功
[root@localhost ~]# passwd -S linuxprobe
linuxprobe LK 2018-08-20 0 99999 7 -1 (密码已被锁定。)
[root@localhost ~]# passwd -u linuxprobe
解锁用户 linuxprobe 的密码 。
passwd: 操作成功
[root@localhost ~]# passwd -S linuxprobe
linuxprobe PS 2018-08-20 0 99999 7 -1 (密码已设置,使用 SHA512 加密。)

userdel命令

userdel 命令用于删除用户,格式为“userdel [选项] 用户名”。
如果我们确认某位用户后续不再会登录到系统中,则可以通过 userdel 命令删除该用户的
所有信息。在执行删除操作时,该用户的家目录默认会保留下来,此时可以使用-r 参数将其删
除。userdel 命令的参数以及作用如表 5-4 所示。
表 5-4 userdel 命令的参数以及作用
-f           强制删除用户
-r          同时删除用户及用户家目录
下面使用 userdel 命令将 linuxprobe 用户删除,其操作如下:

[root@localhost ~]# id linuxprobe
uid=1000(linuxprobe) gid=1000(linuxprobe) 组=1000(linuxprobe),0(root)
[root@localhost ~]# userdel -r linuxprobe
[root@localhost ~]# id linuxprobe
id: linuxprobe:无此用户

 

这篇关于useradd命令,usermod命令,userdel命令的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/896554

相关文章

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

利用命令模式构建高效的手游后端架构

在现代手游开发中,后端架构的设计对于支持高并发、快速迭代和复杂游戏逻辑至关重要。命令模式作为一种行为设计模式,可以有效地解耦请求的发起者与接收者,提升系统的可维护性和扩展性。本文将深入探讨如何利用命令模式构建一个强大且灵活的手游后端架构。 1. 命令模式的概念与优势 命令模式通过将请求封装为对象,使得请求的发起者和接收者之间的耦合度降低。这种模式的主要优势包括: 解耦请求发起者与处理者

linux 判断某个命令是否安装

linux 判断某个命令是否安装 if ! [ -x "$(command -v git)" ]; thenecho 'Error: git is not installed.' >&2exit 1fi

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚

Linux命令(4):fg与bg命令

fg、bg、jobs、&、ctrl + z都是跟系统任务有关的,虽然现在基本上不怎么需要用到这些命令,但学会了也是很实用的 一.& 最经常被用到 这个用在一个命令的最后,可以把这个命令放到后台执行 二.ctrl + z 可以将一个正在前台执行的命令放到后台,并且暂停 三.jobs 查看当前有多少在后台运行的命令 四.fg 将后台中的命令调至前台继续运行 如果后台中有多个命令,可以

Linux命令(3):sz与rz命令

一般来说,linux服务器大多是通过ssh客户端来进行远程的登陆和管理的,使用ssh登陆linux主机以后,如何能够快速的和本地机器进行文件的交互呢,也就是上传和下载文件到服务器和本地; 与ssh有关的两个命令可以提供很方便的操作: sz:将选定的文件发送(send)到本地机器 rz:运行该命令会弹出一个文件选择窗口,从本地选择文件上传到服务器(receive) rz,sz是便是Linux

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录

Detectorn2预训练模型复现:数据准备、训练命令、日志分析与输出目录 在深度学习项目中,目标检测是一项重要的任务。本文将详细介绍如何使用Detectron2进行目标检测模型的复现训练,涵盖训练数据准备、训练命令、训练日志分析、训练指标以及训练输出目录的各个文件及其作用。特别地,我们将演示在训练过程中出现中断后,如何使用 resume 功能继续训练,并将我们复现的模型与Model Zoo中的

Linux命令(11):系统信息查看命令

系统 # uname -a # 查看内核/操作系统/CPU信息# head -n 1 /etc/issue # 查看操作系统版本# cat /proc/cpuinfo # 查看CPU信息# hostname # 查看计算机名# lspci -tv # 列出所有PCI设备# lsusb -tv

Android下执行linux命令

最近在开发过程中 使用了几个命令来对   手机的文件的权限进行修改;现在记录一下: 用到的方法: 1:判断是否有Root权限;  /**      * 判断当前手机是否有ROOT权限      * @return      */     public static boolean isRoot(){         boolean bool = false;         try{