用户管理

id

id命令用于查看指定用户的用户名和组名。

  1. $ id
  2. uid=500(me) gid=500(me) groups=500(me)

id输出结果分为三个部分,分别是UID(用户编号和用户名)、GID(组编号和组名),groups(用户所在的所有组)。

用户帐户的信息,存放在/etc/passwd文件里面;用户组的信息,存放在/etc/group文件里面。

  1. # 返回UID
  2. $ id -u [UserName]
  3. # 返回GID
  4. $ id -g [UserName]
  5. # 返回用户名
  6. $ id -un [UserName]
  7. # 返回组名
  8. $ id -gn [UserName]

上面的命令,如果省略用户名,则返回当前用户的信息。

su

su命令允许你以另一个用户的身份,启动一个新的 shell 会话,或者是以这个用户的身份来发布一个命令。

  1. $ su otherUser

执行上面的命令以后,系统会提示输入密码。通过以后,就以另一个用户身份在执行命令了。

如果不加用户名,则表示切换到root用户。

  1. $ su

-l参数表示启动一个需要登录的新的Shell,这意味着工作目录会切换到该用户的主目录。它的缩写形式是-

  1. $ su -

上面命令表示,切换到root用户的身份,且工作目录也切换到root用户的主目录。

-c参数表示只以其他用户的身份,执行单个命令,而不是启动一个新的Session。

  1. $ su -c 'command'
  2. # 实例
  3. $ su -c 'ls -l /root/*'

sudo

sudo命令很类似su命令,但有几点差别。

  • 对于管理员来说,sudo命令的可配置性更高
  • sudo命令通常只用于执行单个命令,而不是开启另一个Session。
  • sudo命令不要求超级用户的密码,而是用户使自己的密码来认证。

sudo的设置在文件/etc/sudoers之中。

-l参数列出用户拥有的所有权限。

  1. $ sudo -l

chown

chown命令用来更改文件或目录的所有者和用户组。使用这个命令需要超级用户权限。

  1. $ chown [owner][:[group]] file

下面是一些例子。

  1. # 更改文件所有者
  2. $ sudo chown bob foo.txt
  3. # 更改文件所有者和用户组
  4. $ sudo chown bob:users foo.txt
  5. # 更改用户组
  6. $ sudo chown :admins foo.txt
  7. # 更改文件所有者和用户组(用户 bob 登录系统时,所属的用户组)
  8. $ sudo chown bob: foo.txt

chgrp

chgrp命令更改用户组,用法与chown命令类似。

useradd

useradd命令用来新增用户。

  1. $ useradd -G admin -d /home/bill -s /bin/bash -m bill

上面命令新增用户bill,参数-G指定用户所在的组,参数d指定用户的主目录,参数s指定用户的 Shell,参数m表示如果该目录不存在,则创建该目录。

usermod

usermod命令用来修改用户的各项属性。

  1. $ usermod -g sales jerry

上面的命令修改用户jerry属于的主要用户组为sales

  1. $ usermod -G sales jerry

上面的命令修改用户jerry属于的次要用户组为sales

adduser

adduser命令用来将一个用户加入用户组。

  1. $ sudo adduser username grouptoadd

groupadd

groupadd命令用来新建一个用户组。

  1. $ sudo groupadd group1
  2. $ sudo adduser foobar group1

groupdel

groupdel命令用来删除一个用户组。

  1. $ sudo groupdel group1

passwd

passwd命令用于修改密码。

  1. # 修改自己的密码
  2. $ passwd
  3. # 修改其他用户的密码
  4. $ sudo passwd [user]