程序员的Linux上手手册(4) - 用户和组的操作

linux用户和组

linux通过用户和组来管理系统权限。
用户是linux的登录单位,用户使用用户名和密码登录系统,完成相关的系统操作。
组是具有某一部分相似的特性的用户的集合。
一个用户有且仅有一个私有组,可以有多个附加组。私有组可以简单理解为用户的家,一个用户有且仅有一个家。而附加组则相当于用户的工作单位,一个用户可以有多个工作单位。
用户和组的操作是linux权限操作的基础。

关于root用户

root是linux系统中的一个特殊的用户,该用户具有linux系统的最高权限。类似于Windows中的administrator账号。

使用su切换用户

命令格式:su [options] [LOGIN]
命令说明:在linux系统中,某些操作需要某些特定的权限才能正常执行。比如新建用户,修改/etc下面的某些配置文件等都需要root权限。当我们使用某个用户登录到系统之后,如果登录的用户不具备这些权限,就需要将当前的登录用户切换到指定的,具有特定权限的用户下。切换到指定用户时,需要输入用户的密码。如果命令不指定用户名,代表切换到root用户。(注意:在ubuntu中,切换到root用户,需要sudo执行。)
命令示例:

su user2 #切换到user2用户。

使用sudo以管理员身份执行命令

命令格式:sudo [options] commond
命令说明:以指定用户的身份运行一个命令。如果不指定options中的-u参数,则代表以root用户的身份执行指定命令。执行sudo时,会要求输入密码,需要注意的是输入当前登录用户的密码,而不是目标用户的密码。通常情况下,我们都使用这条命令来执行一些需要root才能执行的操作。
命令示例:

sudo vi /etc/init.d/ssh #以root权限使用vim编辑某个文件
sudo ls /etc #以root权限列出/etc下的文件
sudo su #以root权限切换用户。在ubuntu,Debian等发行版系统中,我们通常使用这个命令将用户切换到root。
  • 关于 sudo su
    在某些发行版的系统中,比如ubuntu,root用户通常不能直接登录,而是在系统中指定某个用户可以切换到root,或者以执行需要root权限的某些操作。这有点类似于Windows的UAP(管理员权限的用户在执行某些操作时并不具有完整的权限,而需要二次确认。)通常我们在安装系统时输入的用户就具有root权限,但又不能直接执行某些需要root权限的命令,需要在命令前加上sudo,以便显示的使用root权限运行指定命令。而使用sudo su则将当前用户切换到root。当用户切换到root后,就不再需要在每条命令前面加上sudo来申请root权限了。

获取当前登录用户名

whoami 使用该命令可以获取当前用户的登录名

查看用户所属的组

使用groups获取当前登录用户所属的组。
命令格式:groups [USERNAME]...
命令说明:获取用户所属的组信息,如果不指定用户名,则默认获取当前用户的信息
命令示例:

groups #获取当前用户的组信息
groups user2 #获取用户user2的所属的组信息

使用id命令查看用户信息

命令格式:id [OPTION]... [USER]
命令说明:查看指定用户的信息,和用户所属组的信息。如果不指定参数,显示当前用户的信息
命令示例

id #显示当前用户的信息
id user2 #显示user2的用户信息

passwd 修改用户密码

命令格式:passwd [options] [LOGIN]
命令说明:修改指定用户的登录密码,如果不指定用户名,则修改当前用户的密码
该命令在不输入用户名时,默认修改当前登录用户的密码。在修改当前用户的密码时,会要求输入原密码。而修改其它用户的密码时,需要root权限。
命令示例

passwd #修改当前用户的密码
passwd user2 #修改用户user2的密码

添加用户

添加用户有adduser和useradd两条命令。在ubuntu中,这两个命令有所区别。而在某些发行版中,这两条命令没有区别。

useradd

命令用法:useradd [options] LOGIN
命令说明:向当前系统增加一个用户,LOGIN代表用户名。新添加的用户默认是没有密码的。因此也不能登录,需要使用passwd命令修改密码之后才能登录。
常用选项

  • -D 打印或者修改新建用户的某些默认配置,使用该选项时,不能创建用户,仅能修改默认配置。
  • -m 同时创建用户主目录
  • -g 指定用户所属的私有组,一个用户只能有一个私有组
  • -G 指定用户所属的附加主,一个用户可以有多个附加组,多个附加组之间用“,”分隔
  • -s 指定用户的shell程序

命令示例

useradd -m -G users user2 # 创建一个用户名为user2的用户,并且将用户添加到users组
useradd -m -s /bin/bash user3 #创建一个用户名为user3的用户,指定bash为默认的shell程序
useradd -D -s /bin/bash # 修改创建用户的默认配置项,将新用户的shell程序默认值修改为/bin/bash

adduser

命令用法:adduser [options] LOGIN
命令说明:添加一个用户,这个命令是一个向导式的添加过程,在添加的过程中会提示你输入相关的信息,包括密码,以及一些其它的信息。这命令还可以创建组,以及修改用户所属的组。
常用选项:

  • --home 指定新用户的主目录
  • --ingroup 指定用户的组
    命令示例
adduser user4 #添加一个用户
adduser --ingroup users user5 #添加一个用户user5,并将用户添加到users组中

删除用户

删除用户和添加用户类似,有userdel和deluser两个命令,这两个命令在使用上有些差别。关于这两条参数的详细说明或用法,可以通过man命令获或者--help获取。但通常情况下,使用这两条命令的一般用法达到的效果是一样的。
在使用deluser的时候,如果我们不指定用户名,则会提示用户输入欲删除的用户。

userdel user2 #删除用户user2,不删除相关文件
deluser user2 #删除用户user2,不删除相关文件
userdel -r user2 # 删除用户user2,同时删除他的主目录
deluser --remove-home user2删除user2,同时删除主目录

添加组

组的操作相对于用户的操作要简单一些
添加组和添加用户类似,也有两个命令addgroup和groupadd。
命令示例

groupadd group1 #添加一个组group1
addgroup group2 #添加一个组group2

删除组

组的删除和用户的删除类似,有delgroup,groupdel两个命令,其中delgroup和deluser类似,在删除的时候如果不提供名称,则会提示用户输入要删除的组名称

groupdel group1 #删除组group1
delgroup group2 #删除组group2

修改组

可以通过groupmod来修改组的信息,
命令格式:groupmod [options] GROUP
常用选项:

  • -n 新的组名称

命令示例

groupmod -n group3 group1 #将group1重新命名为group3

添加用户到组中

要把一个用户添加到组中,除了我们可以在新建用户的时候指定用户所属的组之外,还可以通过其它的方法更改用户的组

使用usermod修改用户信息

命令格式:usermod [options] LOGIN
命令说明:修改用户的相关信息,包括主目录,所属组等,通常可以用这个命令修改用户所属组。
常用选项:

  • -g 修改用户的私有组
  • -G 修改用户的附属组
  • -a 当使用-G参数修改用户所属组的时候,添加用户到组中,但不删除以前的组信息。

命令示例

usermod -a -G group1 user1 #将用户user1添加到group1组中,不改变用户已经加入的组
usermod -G group1 user1 #将用户user1添加到group1组中,移除之前的组信息

使用adduser修改组信息

adduser命令除了添加用户之外,还可以修改用户所属组信息。
命令格式:adduser USER GROUP
命令说明:将已经存在的用户USER添加到已经存在的组GROUP中

adduser user1 group1 #将user1添加到group1组中

关于用户和组的操作,了解了这些就基本可以满足日常操作了。用户和组的操作,是linux权限体系的基础,在实际工作中,也是非常有用的。
本文中所有的用户和组的相关操作理论上都需要root操作,在测试之前,请使用sudo su将用户切换到root权限,或者在命令之前加上sudo。否则可能提示权限不足。

码字不易,求个关注,求个评论,求个转发,好与不好,留个记号!
系列其它文章:
程序员的Linux上手手册(1) - ubuntu安装
程序员的Linux上手手册(2) - 基础文件操作命令
程序员的Linux上手手册(3) - 常用工具
程序员的Linux上手手册(4) - 用户和组的操作

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352