三、 CentOS: 用户管理

记录个人学习过程,如有错误或不足欢迎大家指正~~


1.添加帐号

[[email protected] ~]# useradd robin
[[email protected] ~]# id robin

uid=1000(robin) gid=1000(robin) 组=1000(robin)

用户信息文件:

[[email protected] ~]# vim /etc/passwd
在这里插入图片描述

各字段含义如下:
robin : x : 1002 : 1002 : : /home/robin : /bin/bash
用户名 : 密码占位符 : uid 0管理员 1-999系统用户 1000+ 普通 : gid : 描述 : 家目录 : shell

useradd -u 2004 -g 2000 -c 'test user' -d /mnt/abc5 -s /bin/bash abc5

  • -u uid
  • -g gid
  • -c comment 描述信息
  • -d home指定家目录(很少用,一般为系统默认)
  • -s shell
//再创建一个管理员
[[email protected] ~]# useradd -o -u 0 admin
  • -o 设置uid可以重复
uid和gid的范围:

root用户的uid为0,gid为0,group为root
uid 1-999为system user(系统用户,如daemon、sshd等等)gid 1-999为system group(系统组)
uid 1000-60000为user(普通用户) gid 1000-60000为user(普通用户组)

2.添加组

[[email protected] ~]# groupadd tom

组信息文件:

[[email protected] ~]# vim /etc/group
在这里插入图片描述

各字段含义如下:
tom : x : 1003 :
组名 : 组密码占位符号 : gid : 用户列表

[[email protected] ~]# groupadd -g 3000 good

  • -g 指定gid
示例:
//添加组: gid为5000 组名:haha
//添加用户: uid为5000 gid为5000 描述:test 家目录:/tmp下 shell:tcsh hehe
groupadd -g 5000 haha
useradd -u 5000 -g 5000 -c test -d /tmp/hehe -s /bin/tcsh hehe
//测试:
su - hehe

3.密码管理

passwd
passwd robin

密码保存文件:

vim /etc/shadow
在这里插入图片描述

robin : !! : 18208 : 0 : 99999 : 7 : : :
用户名 : 密码(有密码状态,无密码状态,!!帐号锁定,* 该帐号永久不能登陆系统) : 密码的最后一次修改时间 : 密码的最小时间(密码修改相隔时间) : 密码的最大时间(密码有效期) 99999表示永久不过期 : 密码过期前警告时间 : 密码过期后帐号过期 : 帐号有效期 : 保留列
非交互时修改密码:

echo 123 | passwd --stdin robin

修改组信息:
groupmod
groupmod -g 3500 tom
groupmod -n Tom tom
  • -g 修改gid
  • -n 修改组名
修改用户信息:
usermod
usermod -u 2500 jack
usermod -g upup jack
usermod -c 'test user' jack
usermod -s /bin/tcsh jack
  • -u 修改uid
  • -g 修改gid
  • -c 修改描述信息
  • -s 修改shell
修改家目录:
//方法1:
usermod -d /tmp/jack jack
mv /home/jack/ /tmp/

//方法2:
usermod -m -d /home/jack jack
  • -m move home
锁定帐号:
usermod -L robin//锁定
usermod -U robin//解锁
锁定密码:
passwd -l robin//锁定
passwd -S robin//查看当前状态
passwd -u robin//解锁

在这里插入图片描述
! 锁定帐号
!! 锁定密码

删除组:

groupdel tom

删除用户:

userdel -r king

  • -r 连同家目录一起删除
附加组:

附加组用于权限匹配

主组:

主组用于确定用户创建的文件所属组
usermod -a -G tom robin

  • -a 追加,不改变原有组,在后面加入新的所属组
  • -G 指定所属组
组密码:

groupadd boss
gpasswd boss

配置文件:

vim /etc/login.defs
此文件可以修改uid,gid范围,如图:
在这里插入图片描述

vim /etc/default/useradd
此文件可以修改默认家目录和shell
在这里插入图片描述
HOME=/home
SHELL=/bin/bash

SKEL=/etc/skel (环境变量范本目录)

手动管理帐号(通过修改文件手动添加账号的步骤):

1.添加一条组信息(groupadd redhat)

vim /etc/group
redhat:x:9999:

2.添加用户并指定它的组(useradd -g redhat rose)

vim /etc/passwd
rose:x:9999:9999:test user:/home/rose:/bin/bash
mkdir /home/rose
cp /etc/skel/.bash* /home/rose/

3.设置密码信息(passwd rose)

vim /etc/shadow
rose::17303:0:99999:7:::
echo 123 | passwd --stdin rose

注:如果密码占位符是空则登录时不需要密码

版权声明:本文为weixin_43821797原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_43821797/article/details/102974923

智能推荐

使用欧几里得算法解决问题——求字符串的最大公因子(力扣第1071题)(JavaScript解法)

1、欧几里得算法的思想 基于辗转相除法的原理,具体做法:用较大数除以较小数,再用出现的余数(第一个余数)去除除数,,再用出现的余数(第二个余数)去除第一个余数,如此仿佛,直到最后一个余数为0 2、算法流程 3、JavaScript实现欧几里得算法 4、使用欧几里得算法解决问题 力扣1071字符串的最大公因子 题目描述: 对于字符串 S 和 T,只有在 S = T + … + T(T ...

spring与redis整合和序列化问题

spring与redis整合 首先用docker下载redis 下载:docker pull redis 运行:docker run -d -p 6379:6379 --name myredis docker.io/redis 连接redis Desktop Manager 然后开始在springboot上开始配置 application.yml: 自动配置好StringRedisTemplate...

CentOS 7配置南大docker镜像

文章目录 CentOS 7配置南大docker镜像 0.帮助页面 1.系统要求 2.卸载旧版本(没有旧版本可跳过) 3.安装方式 4.准备工作 5.可选操作 Stable Test Nightly 6.安装docker引擎 7. (可选)修改配置文件防止与xshell连接冲突 8.启动docker CentOS 7配置南大docker镜像 0.帮助页面 南大docker源:https://mirr...

Qcon演讲纪实:详解如何在实时视频通话中实现AR功能

2018年4月20日-22日,由 infoQ 主办的 Qcon 2018全球软件开发大会在北京如期举行。声网首席 iOS 研发工程师,iOS 端移动应用产品设计和技术架构负责人龚宇华,受邀分享了《基于 ARkit 和 ARcore,在实时视频通话中实现 AR 功能》,在演讲中剖析了 AR 与 VR 差异,ARKit 的工作原理,以及逐步讲解如何基于 ARKit 与声网Agora SDK 创建 AR...

POJ2348 UVa10368 HDU1525 Euclid's Game【博弈】

Euclid's GameTime Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 4106    Accepted Submission(s): 1947 Probl...

猜你喜欢

使用Breeze.js编写更好的查询

这篇文章是由同行评审Agbonghama柯林斯 。 感谢所有SitePoint的审稿作出SitePoint内容也可以是最好的! 数据量正在迅速发展,他们正在变得越来越复杂,维护。 许多开发人员希望避免由数据问题他们的工作过程中造成的问题和头痛。 一个使我们的工作更轻松的图书馆是Breeze.js 。 在这篇文章中,我们将讨论我们如何能够写出更好的查询与Breeze.js。 但是首先,我们应该知道什...

Netty框架构建Nio编程

~~~ 随手点赞,养成习惯 ~~~ 为什么选择Netty框架 Netty是业界最流行的NIO框架之一,它的健壮性、功能、性能、可定制性和可扩展性在同类框架中都是首屈一指的。 优点: ① API使用简单,开发门槛低 ②功能强大,预置了多种编解码功能,支持多种主流协议 ③ 定制能力强,可以通过ChannelHandler对通信框架进行灵活地扩展; ④性能高,通过与其他业界主流的NIO框架对比,Nett...

【JZOJ5262】【GDOI2018模拟8.12】树(DP,性质题)

Description Solution 首先我们可以知道两个性质:1、路径u-v和路径v-w可以合并为路径u-w;2、路径u1-v1加路径u2-v2和路径u1-v2加路径u2-v1是等价的(就是起始点和终点可以互换) 那么知道这些性质之后就很好做了。我们只用知道每个点多少次做起点和多少次做终点。 我们设f[i]表示满足i子树的需求i上的值要是多少。 那么枚举i的所有儿子,判断a[i]-f[i],...

【String-easy】541. Reverse String II 反转的元素,有反转个数和间隔

1. 题目原址 https://leetcode.com/problems/reverse-string-ii/ 2. 题目描述 3. 题目大意 给定一个字符串,和字符串的间隔k, 这个k表示每k个数反转一次,然后再间隔k个元素再反转k个元素。 4. 解题思路 只要按照间隔去反转就可以了。然后间隔k个元素不反转是通过让i每次递增 2*k完成的。 5. AC代码 6. 相似题型 【1】344. Re...

【C语言笔记结构体】

我们都知道C语言中变量的类型决定了变量存储占用的空间。当我们要使用一个变量保存年龄时可以将其声明为int类型,当我们要使用一个变量保存某一科目的考试成绩时可以将其声明为float。 那么,当我们要做一个学生信息管理系统时,需要保存学生的姓名、学号、年龄等信息,该怎么做呢? 如当要保存三个学生的信息时, 方法一是: 方法二是: 显然,方法二跟更清晰,因为它把name、num、age都集成在一个模板,...