Linux 添加用户命令 adduser 和 useradd 对比试用 2208110652
bash添加用户的命令时useradd , 后发现还有adduser
CentOS7 和 Ubuntu20.04 都有 adduser
CentOS7最小安装就有adduser命令,说明都是原生的
adduser在CentOS和Ubuntu的表现是不一样的
菜鸟教程里说adduser和useradd行为一致
adduser 与 useradd 指令为同一指令(经由符号连结 symbolic link)。
这应该是在CentOS环境下
有的说
在root权限下,useradd只是创建了一个用户名,如 (useradd +用户名
),它并没有在/home目录下创建同名文件夹,也没有创建密码,因此利用这个用户登录系统,是登录不了的,为了避免这样的情况出现,可以用
(useradd -m +用户名)的方式创建,它会在/home目录下创建同名文件夹,然后利用( passwd +
用户名)为指定的用户名设置密码。可以直接利用adduser创建新用户(adduser +用户名)这样在/home目录下会自动创建同名文件夹
删除用户,只需使用一个简单的命令“userdel 用户名”即可。不过最好将它留在系统上的文件也删除掉,你可以使用“userdel -r
用户名”来实现这一目的。
使用 useradd 创建用户,发现 /home 目录下没有自动创建关于用户的目录。所以做了一番调查研究useradd是一个linux命令,但是它提供了很多参数在用户使用的时候根据自己的需要进行设置; adduser是一个perl
脚本,在使用的时候会出现类似人机交互的界面,提供选项让用户填写和选择,这个命令比起useradd来说比较简单,也比较傻瓜。
文章目录
在centOS7最小安装版的测试
1, adduser和useradd都会在/home下给新用户添加用户目录
Linux之CentOS7 添加用户命令:useradd和adduser 笔记2209020115
只添加用户 useradd 用户名
# 添加用户
useradd 用户名
添加用户,指定其组 useradd -g 自身组 -G 其它组1,其它组2,其它组3 用户名
# 添加用户,指定其组
useradd -g 自身组 -G 其它组1,其它组2,其它组3 用户名
useradd
说明
useradd --help
的说明
用法:useradd [选项] 登录
useradd -D
useradd -D [选项]
选项:
-b, --base-dir BASE_DIR 新账户的主目录的基目录
-c, --comment COMMENT 新账户的 GECOS 字段
-d, --home-dir HOME_DIR 新账户的主目录
-D, --defaults 显示或更改默认的 useradd 配置
-e, --expiredate EXPIRE_DATE 新账户的过期日期
-f, --inactive INACTIVE 新账户的密码不活动期
-g, --gid GROUP 新账户主组的名称或 ID
-G, --groups GROUPS 新账户的附加组列表
-h, --help 显示此帮助信息并推出
-k, --skel SKEL_DIR 使用此目录作为骨架目录
-K, --key KEY=VALUE 不使用 /etc/login.defs 中的默认值
-l, --no-log-init 不要将此用户添加到最近登录和登录失败数据库
-m, --create-home 创建用户的主目录
-M, --no-create-home 不创建用户的主目录
-N, --no-user-group 不创建同名的组
-o, --non-unique 允许使用重复的 UID 创建用户
-p, --password PASSWORD 加密后的新账户密码
-r, --system 创建一个系统账户
-R, --root CHROOT_DIR chroot 到的目录
-P, --prefix PREFIX_DIR prefix directory where are located the /etc/* files
-s, --shell SHELL 新账户的登录 shell
-u, --uid UID 新账户的用户 ID
-U, --user-group 创建与用户同名的组
-Z, --selinux-user SEUSER 为 SELinux 用户映射使用指定 SEUSER
百度百科和360百科对useradd的说明
-e expire_date 帐号终止日期。日期的指定格式为MM/DD/YY。
-f inactive_days 帐号过期几日后永久停权。当值为0时帐号则立刻被停权。而当值为-1时则关闭此功能,预设值为-1
-g initial_group group名称或以数字来做为使用者登入起始群组(group)。群组名须为现有存在的名称。群组数字也须为现有存在的群组。预设的群组数字为1。
-G group,[...] 定义此使用者为此一堆groups的成员。每个群组使用","区格开来,不可以夹杂空白字元。群组名同-g选项的限制。定义值为使用者的起始群组。
-m 使用者目录如不存在则自动建立。如使用-k选项skeleton_dir内的档案将复制至使用者目录下。然而在/etc/skel目录下的档案也会复制过去取代。任何在skeleton_diror/etc/skel的目录也相同会在使用者目录下一一建立。The-k同-m不建立目录以及不复制任何档案为预设值。
-M 不建立使用者目录,即使/etc/login.defs系统档设定要建立使用者目录。
-n 预设值使用者群组与使用者名称会相同。此选项将取消此预设值。
-r 此参数是用来建立系统帐号。系统帐号的UID会比定义在系统档上/etc/login.defs.的UID_MIN来的小。注意useradd此用法所建立的帐号不会建立使用者目录,也不会在乎纪录在/etc/login.defs.的定义值。如果你想要有使用者目录须额外指定-m参数来建立系统帐号。这是REDHAT额外增设的选项。
-u uid 使用者的ID值。必须为唯一的ID值,除非用-o选项。数字不可为负值。预设为最小不得小于999而逐次增加。0~999传统上是保留给系统帐号使用。改变预设值当-D选项出现时,useradd秀出现在的预设值,或是藉由命令列的方式更新预设值。可用选项为∶
-d default_home 定义使用者所属目录的前一个目录。使用者名称会附加在default_home后面用来建立新使用者的目录。当然使用-d后则此选项无效。
-e default_expire_date 使用者帐号停止日期。
-f default_inactive 帐号过期几日后停权。
-g default_group 新帐号起始群组名或ID。群组名须为现有存在的名称。群组ID也须为现有存在的群组。
-s default_shell 使用者登入后使用的shell名称。往后新加入的帐号都将使用此shell.如不指定任何参数,useradd显示目前预设的值。注记系统管理者有义务在/etc/skel目录下放置使用者定义档。
adduser
在CentOS7中只是 useradd
的软链接
在CentOS7 中adduser
是useradd
的符号链接(软链接)
扩展知识
修改密码 passwd 用户名
输入passwd 用户名
后按控制台提示连续两次输入密码后回车
删除用户 userdel -rf 用户名
-r
=--remove
: 同时删除用户主目录和邮件池-f
=-force
: 强制
在centOS7图形桌面版下的测试
1, adduser和useradd都会在/home下给新用户添加用户目录