【Shell 命令集合 系统管理 】Linux 创建新用户的命令 useradd命令 使用指南

简介: 【Shell 命令集合 系统管理 】Linux 创建新用户的命令 useradd命令 使用指南

Shell 命令专栏:Linux Shell 命令全解析


描述


useradd命令是Linux系统中用于创建新用户的命令。它的作用是在系统中创建一个新的用户账号,并指定该用户的相关属性和配置。

通过useradd命令,管理员可以在Linux系统中添加新的用户账号。每个用户账号都有一个唯一的用户名和用户ID(UID),用于标识该用户在系统中的身份。创建用户账号时,可以指定用户名、UID、所属组、主目录、登录Shell等属性。

用户账号创建后,可以使用passwd命令为该账号设置密码。密码是用户登录系统时的身份验证信息,用于保护用户账号的安全性。

除了创建用户账号,useradd命令还可以为用户创建主目录。主目录是用户登录系统后的默认工作目录,用户可以在主目录下存储和管理自己的文件和数据。

另外,useradd命令还可以为用户指定登录Shell。Shell是用户与操作系统交互的接口,用户可以通过Shell执行命令、管理文件、编辑文本等操作。

总之,useradd命令在Linux系统中的作用是创建新的用户账号,并设置相关属性和配置,以便用户可以登录系统并进行操作。


语法格式

useradd [选项] 用户名

参数说明

  • -c, --comment:指定用户账号的注释信息。
  • -d, --home:指定用户账号的主目录。
  • -g, --gid:指定用户账号所属的组ID。
  • -G, --groups:指定用户账号所属的附加组。
  • -s, --shell:指定用户账号的登录Shell。
  • -u, --uid:指定用户账号的用户ID。
  • -m, --create-home:自动创建用户账号的主目录。
  • -r, --system:创建系统账号,即不会自动创建主目录。
  • -l, --no-log-init:不将用户添加到utmp和wtmp文件中,即不记录登录信息。

错误情况

  • 如果没有root权限,无法使用useradd命令。
  • 如果指定的用户名已经存在,将无法创建重复的用户账号。
  • 如果指定的主目录已经存在,且未使用-m选项,将无法创建用户账号。
  • 如果指定的组ID不存在,将无法创建用户账号。
  • 如果指定的Shell不存在,将无法创建用户账号。
  • 如果用户账号创建失败,可能是由于系统内存不足或磁盘空间不足等原因导致。
  • 如果使用了无效的选项或参数,将会显示错误信息并退出。

注意事项

在使用Linux Shell的useradd命令时,有一些注意事项需要注意:

  1. 需要root权限:useradd命令需要root权限才能正常执行。因此,在使用该命令时,确保以root用户身份登录或使用sudo命令。
  2. 避免重复用户名:确保要创建的用户名在系统中是唯一的,避免创建重复的用户账号。可以使用grep命令或查看/etc/passwd文件来检查是否存在相同的用户名。
  3. 指定合适的用户ID和组ID:当创建用户账号时,可以使用-u选项来指定用户ID,使用-g选项来指定所属组ID。确保指定的ID在系统中是唯一的,避免与现有的用户或组产生冲突。
  4. 确定主目录是否存在:如果指定了主目录,确保该目录不存在或使用-m选项自动创建。如果主目录已经存在,useradd命令将不会自动创建主目录,除非使用了-m选项。
  5. 指定合适的登录Shell:使用-s选项来指定用户账号的登录Shell。确保指定的Shell存在于系统中,否则用户可能无法正常登录。
  6. 指定注释信息:使用-c选项来指定用户账号的注释信息,可以提供有关该用户的描述、用途或其他相关信息。注释信息对于管理员和其他用户来说是很有用的。
  7. 确保资源足够:在创建用户账号时,确保系统内存和磁盘空间足够。如果资源不足,可能导致用户账号创建失败或出现其他问题。
  8. 密码设置:使用useradd命令创建的用户账号默认是没有密码的,需要使用passwd命令为其设置密码,以确保账号的安全性。
  9. 额外组的设置:使用-G选项可以为用户账号指定附加组。确保指定的附加组存在,并在创建用户账号时正确设置。
  10. 记录登录信息:默认情况下,useradd命令会将用户添加到utmp和wtmp文件中,记录用户的登录信息。如果不想记录登录信息,可以使用-l选项。

总之,在使用useradd命令时,需要仔细考虑各种参数和选项的设置,确保创建的用户账号符合系统需求,并遵循安全性和权限的最佳实践。


底层实现

在Linux系统中,useradd命令底层实际上是通过调用一系列系统调用和相关工具来实现的。

  1. 首先,useradd命令会使用getpwnam函数检查指定的用户名是否已经存在于系统中。如果存在重复的用户名,useradd命令将返回错误。
  2. 如果指定的用户名是唯一的,useradd命令将调用系统调用useradd()来创建新的用户账号。该系统调用会在系统的用户数据库(通常是/etc/passwd文件)中添加一个新的用户条目。
  3. 在创建用户账号时,useradd命令会为新用户分配一个唯一的用户ID(UID)。它可能会使用系统调用getpwuid()来获取当前可用的最大UID,并为新用户分配一个更高的UID。
  4. useradd命令还会为新用户分配一个默认的组ID(GID),通常是与用户名相同的组。如果指定了其他组ID,它会使用系统调用getgrgid()来检查指定的组ID是否存在。
  5. 如果指定了主目录,useradd命令会使用mkdir命令创建该目录,并使用chown命令将其所有权设置为新用户的用户名和组。
  6. 如果指定了登录Shell,useradd命令会将该Shell的路径添加到新用户的用户条目中。它可能会使用系统调用getpwnam()来获取指定Shell的绝对路径。
  7. 最后,useradd命令会使用passwd命令为新用户设置密码。它会调用passwd命令并传递用户名作为参数,以便用户可以设置自己的密码。

总之,useradd命令通过调用系统调用和相关工具来创建新的用户账号,并设置相关属性和配置。它涉及到用户数据库的更新、目录的创建、权限的设置以及密码的设置等操作。


示例

示例一

创建一个名为"john"的用户账号,并将其所属组设置为"staff",主目录为"/home/john",登录Shell为"/bin/bash"。

示例二

创建一个名为"mary"的用户账号,并将其所属组设置为"users",主目录为"/home/mary",登录Shell为"/bin/false"。

示例三

创建一个名为"guest"的用户账号,并将其所属组设置为"guests",主目录为"/home/guest",登录Shell为"/bin/bash"。

示例四

创建一个名为"testuser"的用户账号,并将其所属组设置为"testgroup",主目录为"/home/testuser",登录Shell为"/bin/bash"。

示例五

创建一个名为"developer"的用户账号,并将其所属组设置为"developers",主目录为"/home/developer",登录Shell为"/bin/bash"。

示例六

创建一个名为"admin"的用户账号,并将其所属组设置为"admins",主目录为"/home/admin",登录Shell为"/bin/bash"。

示例七

创建一个名为"backup"的用户账号,并将其所属组设置为"backupusers",主目录为"/home/backup",登录Shell为"/bin/bash"。


用c语言实现


以下是一个使用C语言代码实现useradd命令的简单示例:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
int main(int argc, char *argv[]) {
    if (argc != 2) {
        fprintf(stderr, "Usage: %s <username>\n", argv[0]);
        exit(EXIT_FAILURE);
    }
    char *username = argv[1];
    char *home_dir = "/home/";
    char *shell = "/bin/bash";
    // 创建用户账号
    if (useradd(username, home_dir, shell) != 0) {
        fprintf(stderr, "Failed to create user account\n");
        exit(EXIT_FAILURE);
    }
    // 设置主目录权限
    char dir_path[256];
    sprintf(dir_path, "%s%s", home_dir, username);
    if (chmod(dir_path, S_IRWXU | S_IRGRP | S_IXGRP | S_IROTH | S_IXOTH) != 0) {
        fprintf(stderr, "Failed to set home directory permissions\n");
        exit(EXIT_FAILURE);
    }
    printf("User account created successfully\n");
    exit(EXIT_SUCCESS);
}
int useradd(const char *username, const char *home_dir, const char *shell) {
    pid_t pid = fork();
    if (pid < 0) {
        fprintf(stderr, "Fork failed\n");
        return -1;
    } else if (pid == 0) {
        // 在子进程中执行useradd命令
        execlp("useradd", "useradd", "-m", "-s", shell, username, NULL);
        exit(EXIT_SUCCESS);
    } else {
        // 等待子进程执行完毕
        wait(NULL);
    }
    return 0;
}

此示例使用了C语言的系统调用函数和相关库函数来实现useradd命令的基本功能。在主函数中,首先检查命令行参数的数量,然后将用户名、主目录和登录Shell指定为变量。然后调用useradd函数创建用户账号,并设置主目录的权限。最后输出成功或失败的消息。

useradd函数中,首先使用fork函数创建一个子进程。在子进程中,使用execlp函数调用useradd命令,传递相应的参数来创建用户账号。在父进程中,使用wait函数等待子进程执行完毕。

请注意,此示例只是一个简单的示例,没有处理所有可能的错误情况和完整的功能。在实际应用中,需要更多的错误处理和安全性考虑。


结语

在我们的探索过程中,我们已经深入了解了Shell命令的强大功能和广泛应用。然而,学习这些技术只是开始。真正的力量来自于你如何将它们融入到你的日常工作中,以提高效率和生产力。

心理学告诉我们,学习是一个持续且积极参与的过程。所以,我鼓励你不仅要阅读和理解这些命令,还要动手实践它们。尝试创建自己的命令,逐步掌握Shell编程,使其成为你日常工作的一部分。

同时,请记住分享是学习过程中非常重要的一环。如果你发现本博客对你有帮助,请不吝点赞并留下评论。分享你自己在使用Shell命令时遇到的问题或者有趣的经验,可以帮助更多人从中学习。

此外,我也欢迎你收藏本博客,并随时回来查阅。因为复习和反复实践也是巩固知识、提高技能的关键。

最后,请记住:每个人都可以通过持续学习和实践成为Shell编程专家。我期待看到你在这个旅途中取得更大进步!

目录
相关文章
|
5月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
535 9
|
5月前
|
算法 Linux Shell
Linux实用技能:打包压缩、热键、Shell与权限管理
本文详解Linux打包压缩技巧、常用命令与原理,涵盖.zip与.tgz格式操作、跨系统传文件方法、Shell运行机制及权限管理,助你高效使用Linux系统。
Linux实用技能:打包压缩、热键、Shell与权限管理
|
5月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
524 2
|
7月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
892 1
|
10月前
|
Linux Shell
在Linux、CentOS7中设置shell脚本开机自启动服务
以上就是在CentOS 7中设置shell脚本开机自启动服务的全部步骤。希望这个指南能帮助你更好地管理你的Linux系统。
1040 25
|
9月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
275 4
|
9月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
525 3
|
10月前
|
Linux Shell
shell_42:Linux参数移动
总的来说,参数移动是Linux shell脚本中的一个重要概念,掌握它可以帮助我们更好地处理和管理脚本中的参数。希望这个解释能帮助你理解和使用参数移动。
235 18
|
11月前
|
Ubuntu Linux
Linux系统管理:服务器时间与网络时间同步技巧。
以上就是在Linux服务器上设置时间同步的方式。然而,要正确运用这些知识,需要理解其背后的工作原理:服务器根据网络中的其他机器的时间进行校对,逐步地精确自己的系统时间,就像一只犹豫不决的啮齿动物,通过观察其他啮齿动物的行为,逐渐确定自己的行为逻辑,既简单,又有趣。最后希望这个过程既能给你带来乐趣,也能提高你作为系统管理员的专业素养。
1788 20
|
11月前
|
网络协议 Shell 网络安全
面试官想听的不仅是命令——如何结构化回答“容器无Shell时如何测试外网”?
“说说看,如果一个Pod的容器没有Shell,如何测试它能否访问外网?”
面试官想听的不仅是命令——如何结构化回答“容器无Shell时如何测试外网”?