useradd命令 功能說明:添加用戶或更新預設的新用戶信息 用法:useradd [options] login_name | 選項 | 說明 | | | | | u, uid UID | 添加一個新的用戶時,手動指定UID號,預設是上一個用戶的UID+1,UID使用範圍(CentOS6)500+ ...
useradd命令
-
功能說明:添加用戶或更新預設的新用戶信息
-
用法:useradd [options] login_name
選項 說明 -u,--uid UID 添加一個新的用戶時,手動指定UID號,預設是上一個用戶的UID+1,UID使用範圍(CentOS6)500+,(CentOS7)1000+ -g,--gid group_name 添加一個新的用戶時,手動指定用戶所屬的基本組,可以為組名,也可以為GID,不過這表示不給他創建與其用戶名同名的私有組。註意:此組得事先需要事先存在否則創建時會出現錯誤。 -c,--comment COMMENT 指明註釋信息,如果有空格,通常需要包含在引號中 -G,--groupsGROUP1[,GROUP2,...[,GROUPN]]] 指明用戶所屬的附加組,多個組之間用戶逗號分隔。註意:組得事先存在。 -d,--home HOME_DIR 添加新用戶以指定的路徑為用戶的家目錄,創建方式:通過複製/etc/skel此目錄並重命名來實現的,指定的家目錄路徑如果事先存在的話,則不會為用戶複製環境配置文件。因此創建用戶指定家目錄時,目標路徑最好不要存在。如果不指定的話,預設會在/home中創建一個與其用戶名同名的目錄。 -s,--shell SHELL 指明用戶所使用的shell,可以使用的所有常規shell列表存儲在/etc/shells文件當中 -r,--system 創建一個系統用戶 -M 不創建用戶家目錄。即使在/etc/login.defs配置文件中指定創建家目錄,使用-M也不會創建。/etc/login.defs這個文件指明瞭創建用戶時的預設配置信息 -D,--defaults 顯示創建用戶的預設配置屬性信息 -D [options] 修改指定選項的值 -e,--expiredate 指明賬戶的失效日期,格式為YYYY-MM-DD
示例1:添加一個名為user1的用戶
[root@node1 ~]# useradd user1
[root@node1 ~]# tail -1 /etc/passwd
user1:x:1004:1004::/home/user1:/bin/bash
註意:創建一個用戶時,如果沒有指定組的話,會自動創建一個與用戶名同名的組作為用戶的私有組,而且只包含一個用戶。
[root@node1 ~]# tail -1 /etc/shadow
user1:!!:18407:0:99999:7:::
上述的第二欄位為密碼段,其顯示為”!!“,表示禁用狀態,因為我們添加完用戶並沒有設置密碼,所以Linux系統是禁止空密碼用戶登錄的。
示例2:添加一個用戶為openstack,用戶的UID為1500
[root@node1 ~]# useradd -u 1500 openstack
[root@node1 ~]# tail -1 /etc/passwd
openstack:x:1500:1500::/home/openstack:/bin/bash
示例3:添加一個用戶為clouddocker,並指定基本組為cloud
[root@node1 ~]# useradd -g cloud cloudsocker
useradd: group 'cloud' does not exist
註意:添加用戶時,手動指定用戶的基本組時,這個組得事先存在。否則會提示此組不存在。
示例4:添加一個用戶為nfs,並且指定註釋信息為“network file server”
[root@node1 ~]# useradd -c "network file server" nfs
[root@node1 ~]# tail -1 /etc/passwd
nfs:x:1501:1501:network file server:/home/nfs:/bin/bash
示例5:添加一個名為trump的用戶,並指定其家目錄為/tmp/trump
[root@node1 ~]# useradd -d /tmp/trump trump
[root@node1 ~]# tail -1 /etc/passwd
trump:x:1502:1502::/tmp/trump:/bin/bash
[root@node1 ~]# ls -a /tmp/trump
. .. .bash_logout .bash_profile .bashrc
為了實現用戶環境初始化,系統一般對家目錄的創建不是直接創建一個空目錄,而是複製/etc/skel目錄並更名為用戶所指明的家目錄名來實現。
示例6:在/tmp目錄中事先存在mytest目錄,添加mytest用戶時指定/tmp/mytest目錄
[root@node1 ~]# mkdir -p /tmp/mytest
[root@node1 ~]# useradd -d /tmp/mytest mytest
useradd: warning: the home directory already exists.
Not copying any file from skel directory into it.
[root@node1 ~]# ls -a /tmp/mytest/
. ..
提示:此目錄已經存在,並且不從/etc/skel目錄中複製任何文件到/tmp/mytest,因此/tmp/mytest目錄中並不會存在用戶的環境初始化配置文件。
示例7:如何查看當前系統所有可以使用的shell
[root@node1 ~]# cat /etc/shells
/bin/sh
/bin/bash
/usr/bin/sh
/usr/bin/bash
/bin/tcsh
/bin/csh
/bin/zsh
示例8:添加一個名為obama的用戶,並指明其所使用的shell類型為zsh
[root@node1 ~]# useradd -s /bin/zsh obama
[root@node1 ~]# tail -1 /etc/passwd
obama:x:1504:1504::/home/obama:/bin/zsh
現在obama的shell已經被設置為/bin/zsh
示例9:顯示創建用戶的預設配置屬性信息
[root@node1 ~]# useradd -D
GROUP=100 # 創建用戶時是否需要創建一個與用戶同名的私有組
HOME=/home # 創建用戶時家目錄的起始地方,創建一個與用戶名同名的用戶家目錄
INACTIVE=-1 # 指定在密碼過期多少天後關閉該賬號,預設為-1,表示不禁用
EXPIRE= # 賬戶失效時間,為空表示為永不過期
SHELL=/bin/bash # 創建用戶時預設使用的shell
SKEL=/etc/skel # 創建用戶時預設從哪個文件複製用戶的骨架信息
CREATE_MAIL_SPOOL=yes # 創建用戶時,要不要給用戶創建郵件緩存隊列,當為yes時預設會在/var/spool/mail目錄下創建一個與用戶名同名的郵筒用於接收郵件
其實,使用useradd –D修改的結果保存於/etc/default/useradd文件中,也可以直接修改此文件。
示例10:修改預設添加用戶時所使用的shell為csh
[root@node1 ~]# useradd -D -s /bin/csh
[root@node1 ~]# useradd -D
GROUP=100
HOME=/home
INACTIVE=-1
EXPIRE=
SHELL=/bin/csh
SKEL=/etc/skel
CREATE_MAIL_SPOOL=yes
示例11:添加用戶jason,並查看其使用的shell
[root@node1 ~]# tail -1 /etc/passwd
jason:x:1505:1505::/home/jason:/bin/csh