0

0

Linux命令行创建用户的方法

P粉602998670

P粉602998670

发布时间:2025-09-09 09:05:01

|

370人浏览过

|

来源于php中文网

原创

创建Linux用户需先用useradd -m -s /bin/bash newuser创建账户并生成主目录,再通过passwd newuser设置密码,之后可使用usermod -aG将用户加入附加组以分配权限,注意避免误删数据,建议结合/etc/skel模板统一配置环境,批量操作时可用脚本自动化,并遵循最小权限原则强化安全。

linux命令行创建用户的方法

在Linux命令行下创建用户,核心操作其实就围绕着

useradd
passwd
这两个命令展开。前者负责创建用户账户本身,包括它的主目录、默认Shell等基础属性;后者则用于为这个新账户设置密码,这是让用户能够登录系统的关键一步。

解决方案

创建Linux用户的基本流程通常是这样:

首先,使用

useradd
命令创建一个新用户。为了让用户有一个可以存放个人文件的地方,通常会加上
-m
选项来创建用户的主目录。如果需要指定用户登录后使用的Shell,比如bash,可以使用
-s /bin/bash

sudo useradd -m -s /bin/bash newuser

这里

newuser
是你想要创建的用户名。
sudo
是为了以管理员权限执行这条命令,因为创建用户通常需要系统级别的权限。

紧接着,你需要为这个新用户设置一个密码。没有密码,用户是无法登录系统的。

sudo passwd newuser

执行这条命令后,系统会提示你输入两次新密码。请确保两次输入一致,并且密码强度足够。

这样,一个名为

newuser
的账户就创建成功了,它拥有自己的主目录,默认使用bash作为Shell,并且已经设置了登录密码。

创建用户后,如何为他们设置合适的权限和组?

创建用户账户只是第一步,要让这个用户能在系统上正常工作,并且拥有合适的权限,通常还需要进行一些后续配置。我个人觉得,这里最关键的就是“组”的概念。Linux权限管理很大程度上依赖于文件和目录的属主、属组以及其他用户的权限。

加入附加组: 很多时候,新用户需要访问一些特定的资源,比如共享目录、打印机或者执行某些需要特定权限的操作。这时,最常见且安全的方法就是将用户加入到相应的附加组中。例如,如果

newuser
需要执行一些管理员操作,但又不想给它完整的root权限,可以考虑将其加入到
sudo
组(或Ubuntu/Debian上的
adm
组)。

sudo usermod -aG sudo newuser

这里的

-aG
选项非常重要,
-a
代表“追加”(append),
-G
代表“组”(group)。如果只用
-G
而没有
-a
,用户就会从所有其他附加组中移除,只保留你指定的那一个,这通常不是我们想要的。

修改主组: 每个用户都有一个主组,通常在创建用户时会默认创建一个与用户名同名的组作为其主组。如果你需要将用户的主组修改为现有的某个组,可以使用

usermod -g

sudo usermod -g existing_group newuser

但请注意,修改主组可能会影响用户新建文件时的默认属组。在实际操作中,我发现更多的是通过附加组来管理权限,而不是频繁修改主组。

MVM mall 网上购物系统
MVM mall 网上购物系统

采用 php+mysql 数据库方式运行的强大网上商店系统,执行效率高速度快,支持多语言,模板和代码分离,轻松创建属于自己的个性化用户界面 v3.5更新: 1).进一步静态化了活动商品. 2).提供了一些重要UFT-8转换文件 3).修复了除了网银在线支付其它支付显示错误的问题. 4).修改了LOGO广告管理,增加LOGO链接后主页LOGO路径错误的问题 5).修改了公告无法发布的问题,可能是打压

下载

文件和目录权限: 虽然直接通过

useradd
usermod
命令无法直接设置文件或目录的权限,但用户的属主和属组身份会直接影响他们对文件和目录的访问能力。当你创建文件时,它会默认归你所有,并且其属组会是你的主组。其他用户或组的权限则需要通过
chmod
chown
命令来调整。理解这一点,对于管理用户对资源的访问至关重要。我常提醒自己,权限管理的核心原则是“最小权限原则”,只赋予用户完成工作所必需的权限,避免不必要的安全风险。

管理和维护用户账号时,有哪些需要特别注意的细节?

用户账户的管理是一个持续的过程,不仅仅是创建那么简单。在日常维护中,我遇到过不少因为疏忽而导致的问题。

修改用户属性: 如果用户需要更改Shell、主目录路径或者甚至用户名,

usermod
命令是你的好帮手。

  • 更改Shell:
    sudo usermod -s /bin/zsh newuser
  • 更改主目录:
    sudo usermod -d /home/newhome newuser
    (通常还需要手动移动旧目录内容到新目录)
  • 更改用户名:
    sudo usermod -l new_username old_username
    (这个操作比较敏感,会影响很多系统配置,慎用)

我个人建议,如果可能,尽量在用户不活跃的时候进行这些修改,尤其是主目录和用户名的更改,因为它们可能牵扯到很多文件的路径和权限。

删除用户: 当一个用户不再需要时,可以通过

userdel
命令删除。

sudo userdel newuser

然而,仅仅这样删除,用户的主目录和邮件池等文件可能还会留在系统上。为了彻底清理,通常会使用

-r
选项来一并删除用户的主目录和邮件池:

sudo userdel -r newuser

警告: 使用

-r
选项删除用户主目录是不可逆的。在执行此操作之前,务必确认该用户的所有重要数据都已经备份或不再需要。我曾经因为不小心删错了用户的家目录,导致一些重要配置丢失,所以现在每次执行
userdel -r
都会多看一眼用户名。

密码管理: 除了初始设置密码,有时还需要重置用户密码,或者强制用户在下次登录时更改密码。

  • 重置密码:
    sudo passwd username
  • 强制下次登录更改密码:
    sudo chage -d 0 username
    (将上次密码更改日期设为0,系统会认为密码过期)

账户过期: 对于一些临时用户或需要定期清理的账户,设置账户过期日期是一个很好的安全实践。

sudo chage -E "YYYY-MM-DD" username

这能有效防止长期未使用的账户成为安全漏洞。

除了基础操作,创建Linux用户还有哪些高级配置或安全实践?

在更复杂的场景下,例如企业环境或需要自动化管理大量用户时,仅仅依靠

useradd
的基本选项可能就不够了。这时,一些高级配置和安全实践就显得尤为重要。

用户模板(/etc/skel): 这是一个我非常喜欢的功能。当使用

useradd -m
创建用户时,系统会将
/etc/skel
目录下的所有文件和子目录复制到新用户的主目录中。这意味着你可以在
/etc/skel
中放置一些默认的配置文件(如
.bashrc
,
.vimrc
)、脚本或欢迎信息,确保每个新用户都有一个统一且预配置好的环境。这对于保持系统一致性,减少新用户上手时的配置工作量非常有帮助。我通常会在这里放一些公司内部的Shell别名和常用工具的配置。

自动化与脚本化: 如果需要批量创建用户,手动输入命令显然效率低下且容易出错。这时,编写Shell脚本来自动化这个过程是最佳选择。你可以从一个CSV文件读取用户名、组、Shell等信息,然后在一个循环中调用

useradd
passwd

#!/bin/bash
# 示例:从文件中读取用户列表并创建
while IFS=',' read -r username groups shell comment; do
    if ! id "$username" &>/dev/null; then
        echo "创建用户: $username"
        sudo useradd -m -s "$shell" -c "$comment" "$username"
        if [ -n "$groups" ]; then
            sudo usermod -aG "$groups" "$username"
        fi
        # 初始密码可以设置为随机字符串,然后强制用户第一次登录修改
        echo "$username:$(openssl rand -base64 12)" | sudo chpasswd
        sudo chage -d 0 "$username"
    else
        echo "用户 $username 已存在,跳过。"
    fi
done < users.csv

这样的脚本大大提高了效率,也减少了人为错误。当然,密码的生成和分发需要更安全的机制。

安全强化实践:

  • 强密码策略: 除了强制用户第一次登录更改密码,还可以通过PAM(Pluggable Authentication Modules)模块配置更严格的密码策略,例如密码长度、复杂度、历史记录等。文件
    /etc/pam.d/common-password
    是一个常见的配置点。
  • 限制
    sudo
    权限:
    不要随意将用户添加到
    sudo
    组。如果需要执行特定管理任务,可以考虑使用
    visudo
    精确配置
    sudoers
    文件,只允许用户执行特定的命令,而不是拥有完整的root权限。
  • 禁用不必要的Shell: 对于一些只需要访问特定服务而不需要登录Shell的账户(如数据库用户、FTP用户),可以将其Shell设置为
    /sbin/nologin
    /bin/false
    ,彻底阻止他们通过SSH或控制台登录系统。
  • 日志审计: 确保系统日志(如
    /var/log/auth.log
    /var/log/secure
    )能够记录用户的登录、sudo操作等行为,以便进行安全审计和故障排查。

在我看来,用户管理是一个系统安全的基础。细致的配置和严谨的流程,虽然开始可能显得繁琐,但从长远来看,能够大大降低系统的风险。

相关专题

更多
append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

343

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1073

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

175

2025.09.12

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

352

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2075

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

347

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

255

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

324

2023.10.09

Python GraphQL API 开发实战
Python GraphQL API 开发实战

本专题系统讲解 Python 在 GraphQL API 开发中的实际应用,涵盖 GraphQL 基础概念、Schema 设计、Query 与 Mutation 实现、权限控制、分页与性能优化,以及与现有 REST 服务和数据库的整合方式。通过完整示例,帮助学习者掌握 使用 Python 构建高扩展性、前后端协作友好的 GraphQL 接口服务,适用于中大型应用与复杂数据查询场景。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号