如何在Linux中添加新用户?使用useradd命令创建新用户账户

使用useradd命令创建新用户并设置密码是Linux用户管理的基础,通过-m创建家目录、-s指定shell、-G分配附加组、-c添加描述信息,实现权限隔离、行为审计和资源管理,提升系统安全与可维护性。

如何在linux中添加新用户?使用useradd命令创建新用户账户

在Linux系统中,添加新用户主要通过

useradd

命令来完成。这个命令是系统管理员创建新用户账户的核心工具,它允许你定义用户的家目录、默认shell、所属组等关键属性,是实现系统权限管理和多用户环境的基础操作。

解决方案

要在Linux中创建一个新用户,最直接的方式就是使用

useradd

命令,并通常配合

passwd

命令来设置密码。

首先,你需要以root用户或拥有sudo权限的用户身份执行以下命令:

sudo useradd -m -s /bin/bash -G sudo,developers -c "张三 - 研发部" zhangsan

这条命令的含义是:

sudo useradd

: 以管理员权限执行

useradd

命令。

-m

: 非常重要,它告诉系统为新用户创建一个家目录(通常在

/home/zhangsan

),并从

/etc/skel

目录复制一些默认的配置文件到这个家目录。如果没有这个选项,用户登录后会遇到很多麻烦,比如无法保存配置、历史命令等。

-s /bin/bash

: 指定新用户的默认登录shell为Bash。这是最常见的交互式shell,当然你也可以指定其他shell,比如

/bin/zsh

,或者

/sbin/nologin

来禁止用户交互式登录(常用于服务账户)。

-G sudo,developers

: 将新用户添加到

sudo

developers

这两个附加组。加入

sudo

组通常意味着用户可以通过

sudo

命令执行管理员权限操作。你可以根据实际需要添加更多组,用逗号分隔。

-c "张三 - 研发部"

: 为用户添加一段注释或描述,方便管理员识别用户的真实身份或职责。

zhangsan

: 这是你想要创建的新用户的用户名。

创建用户后,你需要立即为它设置一个密码,否则用户无法登录:

sudo passwd zhangsan

系统会提示你输入两次密码,请确保密码足够复杂且易于记忆。

为什么我们需要为Linux系统添加新用户?

这其实是一个关于系统管理哲学和安全策略的问题。在一个多用户操作系统中,为每个独立的使用者分配一个专属账户,不仅仅是技术上的规范,更是提升系统安全性、可维护性和可审计性的关键一环。

乾坤圈新媒体矩阵管家 乾坤圈新媒体矩阵管家

新媒体账号、门店矩阵智能管理系统

乾坤圈新媒体矩阵管家 17 查看详情 乾坤圈新媒体矩阵管家

设想一下,如果所有人都共享一个root账户,那么任何操作都拥有最高权限,一旦误操作或恶意行为发生,后果将是灾难性的,而且你根本无从追踪是谁造成的问题。通过创建独立用户,我们能实现:

权限隔离与最小化原则: 每个用户只拥有完成其工作所需的最低权限。比如,一个普通开发者不需要删除系统核心文件的权限,而一个数据库管理员则需要访问特定数据库目录。这大大降低了因单个用户操作失误或账户被盗用而引发的风险。行为审计与追溯: 系统日志会记录每个用户执行的命令和访问的资源。当出现问题时,管理员可以根据用户账户轻松追溯问题源头,这对于故障排查和安全事件响应至关重要。我个人就遇到过因为用户权限混乱,导致排查问题耗时数倍的情况,那真是让人头疼。资源管理与配额: 可以针对不同用户设置资源限制,比如CPU使用、内存占用、磁盘空间配额等,防止单个用户耗尽系统资源,影响其他用户的正常使用。个性化工作环境: 每个用户都有自己的家目录,可以存储个人文件、配置自己的shell环境、别名、环境变量等,互不干扰,提升工作效率。

在我看来,用户管理是系统管理员最基础也最重要的技能之一。它不仅仅是敲几个命令,更是对系统安全和稳定性的深思熟虑。

useradd命令的核心选项及其实际应用场景解析

useradd

命令的强大之处在于其丰富的选项,这些选项允许我们精细地控制新用户的各种属性。理解这些选项及其背后的逻辑,能帮助我们更好地构建一个健壮的用户体系。

-m

(或

--create-home

):创建家目录应用场景: 几乎所有需要登录并进行交互式操作的用户都应该使用此选项。比如,开发人员、普通办公用户、测试人员等。家目录是用户存储个人文件、配置、历史命令记录的地方。重要性: 如果不创建家目录,用户登录后可能无法保存任何会话信息,甚至某些程序会因为找不到家目录而报错。想象一下,你登录一个系统,却连

~/.bashrc

都无法加载,那体验会非常糟糕。

-s SHELL

(或

--shell SHELL

):指定登录Shell应用场景:

/bin/bash

/bin/zsh

等:适用于需要交互式登录和命令执行的普通用户。

/sbin/nologin

/bin/false

关键的安全选项。常用于创建服务账户(如

www-data

用于Web服务器,

mysql

用于数据库)。这些账户只需要运行特定的服务进程,不需要人类用户登录,禁用shell能有效防止潜在的攻击者利用这些账户登录系统。我的看法: 选择合适的shell是安全与便利的平衡。对于服务账户,我总是倾向于使用

nologin

,这是最基本的安全防护。

-g GROUP

(或

--gid GROUP

):指定主组应用场景: 每个用户都必须有一个主组。当用户创建文件或目录时,它们的默认组所有者就是这个主组。这在团队协作中很有用,比如所有“开发”组的用户创建的文件,默认都属于“开发”组,方便组内共享和权限管理。

-G GROUP1,GROUP2,...

(或

--groups GROUP1,GROUP2,...

):指定附加组应用场景: 这是赋予用户额外权限的常用方式。

sudo

组:赋予用户执行管理员命令的权限。

docker

组:允许用户无需

sudo

即可运行Docker命令。

lpadmin

组:允许用户管理打印机。

adm

sys

等:通常用于访问特定的系统日志或监控工具。经验之谈: 附加组是实现精细化权限控制的利器。但也要小心,不要随意将用户加入

sudo

组,这等同于授予其root权限。始终遵循最小权限原则。

-c "COMMENT"

(或

--comment "COMMENT"

):用户描述应用场景: 在大型团队或服务器数量多的环境中,这个选项能极大提高管理效率。它可以记录用户的真实姓名、部门、职责等信息,方便管理员快速识别用户。虽然对系统功能没有直接影响,但对于“人”的管理却至关重要。

-d HOME_DIR

(或

--home-dir HOME_DIR

):指定家目录路径应用场景: 默认家目录在

/home/username

,但有时你需要自定义。比如,你可能想把所有Web用户的家目录放在

/var/www/users/

下,或者为了某种特殊的文件系统布局。

这些选项的灵活组合,让

useradd

成为了一个非常强大的工具,它允许我们根据不同的用户角色和安全需求,创建出高度定制化的用户账户。

创建用户后,我们还需要做哪些关键配置以确保其正常使用和系统安全?

仅仅创建了一个用户并设置了密码,这只是用户管理的第一步。要确保用户能够安全、高效地工作,并且不给系统带来安全隐患,后续的配置和维护同样重要。

设置强密码并强制首次登录修改:使用

sudo passwd username

设置密码是基本操作。但更进一步,可以使用

chage

命令强制用户在首次登录时修改密码,并设置密码有效期,例如:

sudo chage -d 0 zhangsan # 强制zhangsan在下次登录时修改密码sudo chage -M 90 zhangsan # 设置密码最长有效期为90天

这能有效防止弱密码和长期不更换密码带来的安全风险。配置

sudo

权限(如果需要):如果用户需要执行管理员任务,将其加入

sudo

组是最常见的做法。但更精细的控制可以通过编辑

/etc/sudoers

文件(使用

visudo

命令)来实现,例如,只允许某个用户执行特定的命令而不需要密码。重点是: 遵循最小权限原则,不要轻易给予用户过多的

sudo

权限。我个人偏好只给那些真正需要管理权限的人,并且限制他们能执行的命令。配置SSH密钥认证(针对远程登录用户):对于需要通过SSH远程登录的用户,强烈建议使用SSH密钥对进行认证,而不是仅仅依赖密码。密钥认证比密码更安全,且更方便。用户生成密钥对后,将公钥添加到其家目录下的

~/.ssh/authorized_keys

文件中。在

/etc/ssh/sshd_config

中禁用密码认证,可以进一步提升安全性。限制资源使用(

ulimit

limits.conf

):防止单个用户或进程耗尽系统资源。可以通过

/etc/security/limits.conf

文件配置用户的资源限制,如打开文件句柄数、CPU时间、内存使用等。例如,限制

zhangsan

用户可以打开的最大文件数为4096:

zhangsan soft nofile 4096zhangsan hard nofile 4096

检查家目录权限:确保新创建的家目录权限设置合理,通常为

700

(只有用户自己可读写执行)或

750

(用户和同组用户可读写执行,其他人无权限)。不当的权限设置可能导致用户隐私泄露或被其他用户篡改文件。定期审计用户列表和权限:定期审查系统中存在的用户账户,移除不再需要的账户。对于活跃账户,定期检查其所属组和

sudo

权限是否仍然符合其职责,及时调整。这是一种持续的安全维护实践。

这些后续配置,才是确保一个用户账户既能正常工作又能保障系统安全的“闭环”。创建用户只是起点,后续的权限管理、安全加固和定期审计,才是真正考验管理员功力的地方。

以上就是如何在Linux中添加新用户?使用useradd命令创建新用户账户的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/391316.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 15:48:05
下一篇 2025年11月6日 15:53:30

相关推荐

  • C++如何实现文件重命名批处理工具

    C++实现文件重命名批处理工具需使用std::filesystem遍历目录,定义规则(如添加前缀、正则替换、序号命名),通过std::filesystem::rename执行重命名,并处理权限、文件占用、命名冲突等错误,同时利用干运行预览、路径自动适配和UTF-8编码支持提升跨平台兼容性与用户体验。…

    2025年12月18日
    000
  • C++中一个类的对象到底占用多少内存空间

    空类对象占用1字节以确保唯一地址;成员变量类型与数量直接影响对象大小,内存对齐可能导致填充字节,如int、char、float组合可能从9字节变为12字节;继承会叠加父类成员及虚函数表指针;虚函数引入vptr(4或8字节),支持多态;通过sizeof可查询实际大小;调整成员顺序、使用位域、指针或禁用…

    2025年12月18日
    000
  • C++如何使用模板实现通用比较函数

    使用函数模板实现通用比较函数是C++中最有效且类型安全的方式,通过template定义模板,利用 在C++中,实现一个通用比较函数最有效且类型安全的方式是利用函数模板。通过定义一个接受泛型类型参数的函数,编译器可以在编译时根据传入的实际数据类型自动生成特定版本的比较逻辑,从而实现一套代码适用于多种数…

    2025年12月18日 好文分享
    000
  • C++使用CLion IDE进行项目环境搭建技巧

    答案是:使用CLion搭建C++项目需创建新项目并选择“C++ Executable”模板,核心在于正确配置CMakeLists.txt和工具链。首先,CMakeLists.txt定义项目名称、C++标准及源文件,如设置C++17并添加main.cpp;接着在Toolchains中配置编译器(GCC…

    2025年12月18日
    000
  • C++如何在类中管理动态资源与智能指针

    智能指针用于自动管理动态资源,避免内存泄漏和重复释放。1. 使用 std::unique_ptr 实现独占所有权,禁止拷贝但支持移动,构造时获取资源,析构时自动释放;2. 使用 std::shared_ptr 实现共享所有权,通过引用计数管理资源,最后一个指针释放时回收资源;3. 避免循环引用需结合…

    2025年12月18日
    000
  • C++制作猜数字小游戏的实现方法

    答案是制作C++猜数字游戏的核心在于随机数生成、循环控制与用户交互。程序通过srand(time(0))设置随机种子,rand()%100+1生成1到100的目标数字,利用do-while循环接收玩家输入,通过if-else判断大小并给出提示,直至猜中为止,同时统计尝试次数并输出结果,构成完整的游戏…

    2025年12月18日
    000
  • C++数组越界检测 运行时检查机制

    使用标准库容器如std::vector的at()方法可实现数组越界检测,例如访问越界时抛出std::out_of_range异常;编译器工具如AddressSanitizer能有效捕获运行时越界错误;自定义带检查的数组类和调试工具如Valgrind也辅助发现此类问题。 C++语言本身不提供内置的数组…

    2025年12月18日
    000
  • C++复合类型的成员排序与内存优化

    答案:C++复合类型成员排序影响内存对齐和填充,按大小递减排列可减少填充、节省内存并提升缓存效率。编译器为满足数据类型对齐要求会在成员间插入填充字节,合理排序能优化布局,如将double、int、char按序排列可显著减少内存占用。此外,使用alignas、#pragma pack、位域、缓存行对齐…

    2025年12月18日
    000
  • C++如何在MacOS配置Xcode开发环境

    c++kquote>答案:在macOS上配置Xcode进行C++开发需安装Xcode和Command Line Tools,创建Command Line Tool项目并选择C++语言,使用内置Clang编译器可支持C++17/20,通过设置Build Settings中的C++ Languag…

    2025年12月18日
    000
  • C++开发购物清单管理工具方法

    答案:使用struct定义购物项,std::vector存储,ShoppingListManager类封装操作,CLI菜单交互,CSV文件持久化并处理I/O错误。 在C++中开发一个购物清单管理工具,本质上是围绕数据结构、核心功能实现以及数据持久化这几个点展开的。它要求我们将日常的购物需求,比如添加…

    2025年12月18日
    000
  • C++模板在STL应用 容器算法实现原理

    C++模板通过编译时代码生成实现STL的泛型编程,使容器和算法与具体类型解耦,依托迭代器和模板元编程提升复用性与性能。 C++模板在STL中的应用,本质上就是其泛型编程思想的极致体现。它让容器(如 vector 、 list 、 map )和算法(如 sort 、 find )能够以一种类型无关的方…

    2025年12月18日
    000
  • C++智能指针在类成员中使用方法

    使用智能指针作为类成员可实现自动内存管理,避免内存泄漏和悬空指针。通过RAII原则,智能指针在对象构造时获取资源,在析构时自动释放,无需手动delete。std::unique_ptr适用于独占所有权场景,开销小且安全;std::shared_ptr用于共享所有权,但需警惕循环引用问题,可用std:…

    2025年12月18日
    000
  • 如何使用工具(如Valgrind)来检测C++程序的内存泄漏

    使用Valgrind检测C++内存泄漏,需先安装工具并运行valgrind –leak-check=full –show-leak-kinds=all ./可执行文件,其输出会分类显示definitely lost、possibly lost等泄漏类型,应优先处理defini…

    2025年12月18日
    000
  • C++的std::shared_ptr是如何通过引用计数来管理内存的

    std::shared_ptr通过引用计数机制自动管理内存,每个实例共享一个控制块,内含强弱引用计数、对象指针、自定义删除器等,确保对象在无拥有者时自动析构;循环引用需用std::weak_ptr打破;std::make_shared提升性能与异常安全。 std::shared_ptr 通过一种叫做…

    2025年12月18日
    000
  • C++对象生命周期管理与RAII模式结合

    RAII通过将资源管理绑定到对象生命周期,确保构造函数获取资源、析构函数释放资源,实现自动内存和资源管理。结合智能指针(如std::unique_ptr)、文件类、std::lock_guard等机制,RAII可有效避免内存泄漏、文件句柄未关闭、死锁等问题,尤其在异常发生时,C++栈展开保证已构造对…

    2025年12月18日
    000
  • C++命令模式实现请求封装与撤销操作

    命令模式通过将请求封装为对象,实现调用者与接收者解耦,支持撤销、重做、命令队列等功能。其核心角色包括命令接口、具体命令、接收者、调用者和客户端。以智能家居灯光控制为例,开灯、关灯操作被封装为命令对象,调用者(如遥控器)无需了解具体执行逻辑,仅通过调用命令的execute()和undo()方法即可完成…

    2025年12月18日
    000
  • C++如何在模板中处理指针和引用类型

    C++模板处理指针和引用需理解类型推导规则,善用type traits进行类型查询与转换,并结合if constexpr实现编译时条件逻辑,确保代码泛用性与效率。 在C++模板中处理指针和引用类型,核心在于理解模板类型推导规则、善用类型特征(type traits)进行类型查询与转换,以及利用完美转…

    2025年12月18日
    000
  • C预处理宏 条件编译技巧

    答案:C语言中通过预处理宏和条件编译可实现代码灵活性与可移植性。1. 使用#ifndef、#ifdef等防止头文件重复包含及控制调试输出;2. 用#elif实现多平台判断,如区分Windows、Linux、macOS;3. 结合defined定义或#undef重定义宏,统一配置行为;4. 利用#if…

    2025年12月18日
    000
  • C++开发环境搭建是否需要安装CMake

    是否需要安装CMake取决于项目需求。对于小型或IDE内置构建工具支持的项目,可能无需CMake;但大型、跨平台或依赖复杂的项目,CMake能统一构建流程、管理依赖并生成各平台构建文件,显著提升效率。 不一定。是否需要安装CMake取决于你的项目构建方式和所使用的IDE。如果你的项目比较简单,或者你…

    2025年12月18日
    000
  • C++复合对象深拷贝和浅拷贝区别详解

    深拷贝会为对象及其动态资源创建独立副本,确保内存独立;浅拷贝仅复制成员值,导致指针共享同一内存。默认拷贝是浅拷贝,当类含有指向堆内存的指针时,会造成双重释放、悬空指针和数据不一致。例如,MyString类中两个对象通过浅拷贝共享data指针,析构时会重复释放同一内存而崩溃。实现深拷贝需遵循“三大法则…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信