服务器使用Linux系统的用户,有时候会遇到需要大批量添加用户的情况。大家大概都知道Linux系统添加用户是比较简单的,可以使用useradd添加用户,但是这个办法只能一个一个进行添加,对于需要大批量用户添加的情况不是很适用,那么Linux系统批量添加用户有什么办法呢?
服务器Linux系统提供了创建大量用户的工具,方法如下:
1、先编辑一个文本用户文件
每一列按照/etc/passwd密码文件的格式书写,要注意每个用户的用户名、UID、宿主目录都不可以相同,其中密码栏可以留做空白或输入x号。一个文件user.txt内容如下:
user001:600:100:user:/home/ user001:/bin/bash
user002:601:100:user:/home/ user001:/bin/bash
user003:602:100:user:/home/ user001:/bin/bash
user004:603:100:user:/home/ user001:/bin/bash
user005:604:100:user:/home/ user001:/bin/bash
user006:605:100:user:/home/ user001:/bin/bash
……
2、以root身份执行命令/usr/sbin/newusers,从刚创建的用户文件user.txt中导入数据,创建用户:
# newusers < user.txt
然后可以执行命令 vipw 或 vi /etc/passwd 检查 /etc/passwd 文件是否已经出现这些用户的数据,并且用户的宿主目录是否已经创建。
3、执行命令/usr/sbin/pwunconv
将 /etc/shadow 产生的 shadow 密码解码,然后回写到 /etc/passwd 中,并将/etc/shadow的shadow密码栏删掉。这是为了方便下一步的密码转换工作,即先取消 shadow password 功能:
# pwuncony
4、编辑每个用户的密码对照文件
范例文件 passwd.txt 内容如下:
user001:密码
user002:密码
user003:密码
user004:密码
user005:密码
user006:密码
……
5、以root身份执行命令/usr/sbin/chpasswd
创建用户密码,chpasswd 会将经过 /usr/bin/passwd 命令编码过的密码写入 /etc/passwd 的密码栏。
# chpasswd < passwd.txt
6、确定密码经编码写入/etc/passwd的密码栏后
执行命令 /usr/sbin/pwconv 将密码编码为 shadow password,并将结果写入 /etc/shadow。
# pwconv
部分文章来源与网络,若有侵权请联系删除,谢谢!