技术标签: Linux 06丨计算机 Linux用户 Linux用户组
祝大家(Dan Shen Gou
)七夕情人节快乐(Chi Gou Liang
)~
在平时开发及运维的过程中,通常多多少少都需要做了一些Linux运维相关的工作,其中用户组以及用户
管理比较常用,单独抽出来整理了一下,方便复习和查看,也希望能帮到一些有需要的朋友,特别是刚进入职场的小伙伴~
命令: cat /etc/group
显示格式: 组名: x : 组标识号(GUID) : 附加用户
前面很多组都是系统自带的,新加或者修改的用户组在最后面。
也可以查看指定用户组信息 cat /etc/group|grep 指定用户名
示例:cat /etc/group|grep tomcat
–说明: 表示查看tomcat
用户组在/etc/group
中的信息~
命令: groupadd 选项 用户组名
–常用选项
选项 | 选项说明 |
---|---|
-g GID值 |
指定用户组的组标识号(GID),且不允许跟其他组的GID重复 |
-o -g GID值 |
指定用户组的组标识号(GID),-o 表示允许跟其他组的GID重复 |
命令: groupadd 选项 用户组名
示例: groupadd grouptest1
–说明: 表示创建grouptest1
用户组,无选项时,组标识号默认为当前组标识号最大值+1
,假设当前组最大标识号为1000
,则groupadd grouptest1
后grouptest1
的组标识号为1001
命令: groupadd -g 用户组名
示例: groupadd -g 1002 grouptest2
–说明: 表示创建grouptest2
用户组,并且指GID值=1002
,且不允许GID重复,否则提示
groupadd: GID ‘1002’ already exists
示例: groupadd -o -g 1003 grouptest3
–说明: 表示创建grouptest3
用户组,并指定GID值=1003
,允许GID值重复。
命令: groupmod 选项 用户组名
–常用选项
选项 | 选项说明 |
---|---|
-n 新用户组名 |
表示修改用户组名为新用户组名 |
-g GID值 |
指定用户组的组标识号(GID),且不允许跟其他组的GID重复 |
-o -g GID值 |
指定用户组的组标识号(GID),-o表示允许跟其他组的GID重复 |
示例: groupmod -n grouptest1 gtest1
–说明: 表示修改用户组名grouptest1
为gtest1
用户组名;
示例: groupmod -g 1001 grouptest3
–说明: 表示修改用户组grouptest3
的GID=1001
,且不允许GID重复,重复则提示
groupmod: GID ‘1001’ already exists
示例: groupmod -o -g 1002 grouptest3
–说明: 表示修改用户组grouptest3
的GID=1002
,指定-o
说明允许GID重复。
命令: groupdel 用户组名
示例: groupdel gtest1
–说明: 表示删除用户组gtest1
,如果用户组下,用户不为空,则不允许删除,强制删除会提示
groupdel: cannot remove the primary group of user 该用户组下存在的用户名
此时,可以根据上述中的错误提示产出该用户组下存在的用户名
,删除用户命令userdel 该用户组下存在的用户名
如果删除用户提示 userdel: user 用户名 is currently used by process 16234
表明用户正在使用占,因此有进程占用,需要强制杀掉该用户占用的进程kill -9 16234
再重新删除用户 userdel 用户名
删除gtest1
用户组下所有用户后,最后再删除用户组 groupdel gtest1
命令: gpasswd 用户组名
示例: gpasswd gtest
会提示如下:
Changing the password for group gtest
New Password:
Re-enter new password:
输入新密码,再次确认新密码即可~
命令: newgrp 要切换的用户组名
当非root用户
切换到非当前用户所在的组(主组或附加组)时,需要输入所切换的用户组密码确认~
示例: newgrp gtest1
Password:
表示切换到gtest1
用户组,需要输入密码确认~
查看是用户组切换是否成功 groups
命令: gpasswd 选项 用户组名
–常用选项
选项 | 选项说明 |
---|---|
-a 要加入的已存在用户名 | 将用户加入到用户组 |
-d 要删除的已存在用户名 | 将用户从用户组删除 |
示例: gpasswd -a test1 gtest
–说明: 表示,将用户test1
,添加到用户组gtest
加入成功会提示Adding user test1 to group gtest
示例: gpasswd -d test1 gtest
–说明: 表示将用户test1
用户组gtest
中删除,删除成功会提示Removing user test1 from group gtest
Linux可以通过命令groups 用户名
查看指定用户归属哪个用户组~
但是一般无法直接查看到指定用户组下所有的用户,可以通过awk指令来实现~
第一步: 首先查询用户组GID值 cat /etc/group|grep 用户组名
第二步: 再通过用户组GID值
查询用户组下所有用户
awk -F ":" '{print $1"\t"$4}' /etc/passwd | grep '用户组GID值'
–awk参数说明:
上述awk
表达式的意思就是按分号 :
对/etc/passwd
用户文件中的内容进行读取,并且只读取$1
(第1列是用户名)和$4
(第4列用户组GID值),grep后的关键字
则表示只展示包含该关键字的这行信息~
命令: cat /etc/passwd
–内容显示格式说明:
用户名:
x :
用户号:
主用户组GID值:
用户主目录:
用户登录的Shell文件
命令: w
命令: groups
命令: groups 用户名
命令: whoami
命令: adduser 用户名
示例: adduser temp
–说明: 表示创建用户名为temp
的用户,其中默认参数为
默认参数 | 默认参数说明 |
---|---|
主用户组 | 默认自动创建并指定主用户组temp |
主目录 | 默认自动创建并指定主目录为/home/temp |
Shell文件 | 默认自动指定Shell文件为/bin/bash |
查看刚添加的用户 cat /etc/passwd|grep temp
命令: useradd 选项 用户名
–常用选项:
选项 | 选项说明 |
---|---|
-c 注释文字 |
注释性描述 |
d 用户主目录 |
指定用户主目录,配合-m -d ,表示不存在用户主目录时会自动创建 |
-g 用户组 |
指定用户归属主用户组 |
-G 附加用户组 |
指定用户附加用户组 |
-s Shell文件 |
指定用户登录的Shell |
-u 用户号 |
指定用户的用户号,配合-o -u ,表示允许用户号重复 |
示例: adduser -u 10010 utemp -m -d /home/utemp -g gtemp
–说明: 表示添加utemp
用户,设置用户号为10010
,设置主目录为/home/utemp
,不存在该则目录则自动创建,并且设置归属用户组为gtemp
如果-g
指定的用户组不存在会报错,adduser: group ‘gtemp’ does not exist
此时需要先创建好用户组 groupadd gtemp
命令: usermod 选项 用户
–常用选项
选项 | 选项说明 |
---|---|
-l 新用户名 |
修改用户名为新用户名 |
-c 注释文字 |
注释性描述 |
d 用户主目录 |
指定用户主目录,配合-m -d ,表示不存在用户主目录时会自动创建 |
-g 用户组 |
指定用户归属主用户组 |
-G 附加用户组 |
指定用户附加用户组 |
-s Shell文件 |
指定用户登录的Shell |
-u 用户号 |
指定用户的用户号,配合-o -u ,表示允许用户号重复 |
示例: usermod -l newusername oldusername
–说明: 表示修改用户名oldusername
为newusername
命令: userdel 用户名
示例: userdel test1
–说明: 表示直接删除test1
用户及对应的用户组,同时会删除/etc/passwd
中的用户记录,但不会删除掉用户的主目录/home/test1
,并且如果用户test1
不是它所在组的最后一个用户,删除它并不会删它在/etc/group
中的用户组~
命令: userdel 选项 用户名
示例: userdel -r test1
–说明: 表示会删除test1
用户,同时会删除/etc/passwd
中的用户记录,也会删除用户test1
的主目录/home/test1
,同样如果用户test1
不是它所在组的最后一个用户,删除它并不会删它在/etc/group
中的用户组~
原创不易,觉得有用的小伙伴来个一键三连(点赞+收藏+评论 )
走起~
文章浏览阅读2.1k次。原文链接先说说编解码问题编码转换时,通常需要以unicode作为中间编码,即先将其他编码的字符串解码(decode)成unicode,再从unicode编码(encode)成另一种编码。 Eg:str1.decode('gb2312') #将gb2312编码的字符串转换成unicode编码str2.encode('gb2312') #将unicode编码..._python中encode在什么模块
文章浏览阅读949次,点赞21次,收藏15次。本文介绍了Java中的数据输入流(DataInputStream)和数据输出流(DataOutputStream)的使用方法。
文章浏览阅读111次。ie无法兼容_ie 浏览器 newdate
文章浏览阅读239次。这篇文章把 Docker 和 K8s 的关系给大家做了一个解答,希望还在迟疑自己现有的知识储备能不能直接学 K8s 的,赶紧行动起来,K8s 是典型的入门有点难,后面越用越香。
文章浏览阅读561次。ADI中文手册获取方法_adi 如何查看数据手册
文章浏览阅读1k次,点赞4次,收藏3次。React 获取接口数据实现分页效果以拼多多接口为例实现思路加载前 加载动画加载后 判断有内容的时候 无内容的时候用到的知识点1、动画效果(用在加载前,加载之后就隐藏或关闭,用开关效果即可)2、axios请求3、map渲染页面4、分页插件(antd)代码实现import React, { Component } from 'react';//引入axiosimport axios from 'axios';//引入antd插件import { Pagination }_react 分页
文章浏览阅读449次,点赞9次,收藏7次。这个变量与验签过程中的SignatureVerificationFilter::PUT_MESSAGE这个宏是对应的,SignatureVerificationFilter::PUT_MESSAGE,如果在签名过程中putMessage设置为true,则在验签过程中需要添加SignatureVerificationFilter::PUT_MESSAGE。项目中使用到了CryPtopp库进行RSA签名与验签,但是在使用过程中反复提示无效的数字签名。否则就会出现文章开头出现的数字签名无效。_cryptopp 签名
文章浏览阅读848次。新闻稿是新闻从业者经常使用的一种文体,它的格式与内容都有着一定的规范。本文将从新闻稿的格式和范文两个方面进行介绍,以帮助读者更好地了解新闻稿的写作_新闻稿时间应该放在什么位置
文章浏览阅读1.7k次。Java中的转换器设计模式 在这篇文章中,我们将讨论 Java / J2EE项目中最常用的 Converter Design Pattern。由于Java8 功能不仅提供了相应类型之间的通用双向转换方式,而且还提供了转换相同类型对象集合的常用方法,从而将样板代码减少到绝对最小值。我们使用Java8 功能编写了..._java转换器模式
文章浏览阅读150次。1,kubectl run创建pods[root@master ~]# kubectl run nginx-deploy --image=nginx:1.14-alpine --port=80 --replicas=1[root@master ~]# kubectl get podsNAME READY STATUS REST...
文章浏览阅读128次。PAT菜鸡进化史_乙级_1003“答案正确”是自动判题系统给出的最令人欢喜的回复。本题属于 PAT 的“答案正确”大派送 —— 只要读入的字符串满足下列条件,系统就输出“答案正确”,否则输出“答案错误”。得到“答案正确”的条件是: 1. 字符串中必须仅有 P、 A、 T这三种字符,不可以包含其它字符; 2. 任意形如 xPATx 的字符串都可以获得“答案正确”,其中 x 或者是空字符串,或..._1003 pat乙级 最优
文章浏览阅读5.6k次。CH340与Android串口通信为何要将CH340的ATD+Eclipse上的安卓工程移植到AndroidStudio移植的具体步骤CH340串口通信驱动函数通信过程中重难点还存在的问题为何要将CH340的ATD+Eclipse上的安卓工程移植到AndroidStudio为了在这个工程基础上进行改动,验证串口的数据和配置串口的参数,我首先在Eclipse上配置了安卓开发环境,注意在配置环境是..._340串口小板 安卓给安卓发指令