linux用户和组 之 用户管理
一. linux 用户和组的基本介绍
1.linux下 有三种用户:
1. root: 权限最大的。
2. 系统用户: UID小于1000的。系统服务管理用户,一般是不允许登录系统的。(比如mysql用户)
3. 普通用户:(UID大于999的,权限比较小,可以登录,只能使用bin目录下的命令)
2. linux 组
组: 一个用来保存用户的容器。用来装不同的用户的,没有其他意义(win中 组可能涉及到权限)
在默认的情况下,新建用户的同时,系统会创建一个同名组,装载这个用户。
在linux中每个用户必须要 属于一个组, 绝对不能够独立于组外。
在linux中,每个文件都有所有者,所在组,其他组的概念。

二。用户管理
su - user01 切换到user01用户
1. useradd 新建用户 - create a new user or update default new user infomation
语法: useradd [option] username
-c, --comment 描述
-d, --home HOME_DIR 家目录 (家目录放在哪里)
-e, expiredate EXPIPE_DATE 过期时间。
-f, --inactice INACTIVE 是否启用过期机制
-g, --gid GROUP 指定组的ID号 (不建同名组,进入到其他组里面)
-G, --groups GROUP1,[GROUP2,...[GROUPN]]] 附加组 (及创建同名组,还附加一些其他组。)
-m, --create-home 建立家目录
-M, 不建立家目录
-N, --no-user-group 不指定用户同名组
-r, --system 指定该账号是 系统账号
-s, --shell SHELL 指定登录shell (-s /sbin/nologin 这个shell就是非交互式的,不允许登录的shell)
-u, --uid UID 指定用户ID
-U, --user-group 指定用户创建用户同名组
-o, 创建用户时可以uid 重复
密码的设置: passwd -update user's authtications tokens
passwd [option] username
-l lock 锁定用户(不准登录了)
-u unlock (解锁)
-d delete a passwd for an account (删除一个用户的密码,就是无密码)
-S this will output a short information about the status of the password given account.(显示给定帐户密码状态的简短信息)
--stdin (标准输入,方式设置密码。)(echo "123" | passwd --stdin user01)
需要注意一点的就是,在对自己进行修改密码时,就不需要 username 的后缀了。直接写passwd就好了
2. userdel 删除用户 --delete a user account and related files(删除用户以及相关的文件,比如家目录和邮箱等, /home/user05 /var/mail/usero5)
userdel [option] username
-f, --force 强制
-r, --remove 删除主目录以及邮箱
3. usermod 修改用户属性
usermod -modify a user acccount
语法: usermod [option] username
-a, --append
-L, --local 锁定
-U, --unlock 解锁
-m, --move-home with -d 移动家目录 ( usermod -m -d /home/user01) 指定家目录到/home/user01 。 这种的有一个要求就是 user01 这个目录不能在登录状态,否则是不准使用的。
其他:
查看用户密码的一些信息。
[root@python ~]# passwd -S python_web
python_web PS 1969-12-31 0 99999 7 -1 (密码已设置,使用 SHA512 算法。)
使用change 可以交互的进行设置这些内容。
[root@python ~]# chage python_web
正在为 python_web 修改年龄信息
请输入新值,或直接敲回车键以使用默认值 最小密码年龄 []: 0 # 设置几天之内不能修改代码
最大密码年龄 []: 99999 # 密码的有效期,99999天
最近一次密码修改时间 (YYYY-MM-DD) [-]: 2019-7-02 # 最后一次修改密码的时间
密码过期警告 []: 2 # 过期前2天给与警告
密码失效 [-]: 5 # 密码失效之后,还可以使用几天
帐户过期时间 (YYYY-MM-DD) [-]: --5 # 账号的过期时间。
[root@python ~]# passwd -S python_web
python_web PS 2019-07-02 0 99999 2 5 (密码已设置,使用 SHA512 算法。)
或者不想使用交互式的,可以使用一条命令搞定:
chage [option] username
-h, --help display this help message and exit
-m, 密码可更改的最小天数, 为0时代表任何时候都可以更改密码
-M, 密码保持有效的最大天数。
-W, 用户密码到期前,提前收到警告信息的天数。
-E, 账号到期的日期。
-d, 上一次更改的日期
-I,(这是 i ) 停滞时期, 如果一个密码已过期之后,还可以使用几天。
-l, (这是 L)列出当前的设置。
如果想要一个用户在登录某个账户时,强制的让他修改密码。
只需要将最后一次密码的更改时间修改为 0 也就是 -d 这个命令。这样用户在登录时就会强制行的让他修改密码。
4. /etc/passwd 密码文件
[username]:[password]:[UID]:[GID]:[身份描述]:[主目录]:[登录shell]

5. /etc/shadow 影子文件
用户名:这是用户登陆时使用的用户名,在系统中是唯一的
口令:存放加密的口令
最后一次修改的时间:表示从某一时刻开始到用户最后一次修改口令的天数
最小时间间隔:两次修改口令之间的最小天数
最大时间间隔:口令保持有效的最多天数,就是多少天之后必须修改口令
警告时间:从系统开始警告到正式失效的天数
不活动时间:口令过期多少天后,该账号被禁用
失效时间:指口令失效的绝对天数(从1970.1.1开始算起)

这俩文件 最好不要修改。
linux用户和组 之 用户管理的更多相关文章
- Linux系统用户、组和权限管理
一.用户与组 1.用户与组的概念 在linux系统中,根据系统管理需要将用户分为三种类型: 1.超级用户:root是linux系统的超级用户,对系统拥有绝对权限.由于root用户权限太大,只有在进行系 ...
- linux(centOS7)的基本操作(三) 用户、组、权限管理
用户和组 1.用户.组.家目录的概念 linux系统支持多用户,除了管理员,其他用户一般不应该使用root,而是应该向管理员申请一个账号.组类似于角色,系统可以通过组对有共性的用户进行统一管理.每个用 ...
- 2017.2.28 activiti实战--第五章--用户与组及部署管理(三)部署流程及资源读取
学习资料:<Activiti实战> 第五章 用户与组及部署管理(三)部署流程及资源读取 内容概览:如何利用API读取已经部署的资源,比如读取流程定义的XML文件,或流程对应的图片文件. 以 ...
- 2017.2.28 activiti实战--第五章--用户与组及部署管理(二)部署流程资源
学习资料:<Activiti实战> 第五章 用户与组及部署管理(二)部署流程资源 内容概览:讲解流程资源的读取与部署. 5.2 部署流程资源 5.2.1 流程资源 流程资源常用的有以下几种 ...
- 2017.2.20 activiti实战--第五章--用户与组及部署管理(一)用户与组
学习资料:<Activiti实战> 第五章 用户与组及部署管理(一)用户与组 内容概览:讲解activiti中内置的一套用户.组的关系,以及如何通过API添加.删除.查询. 5.1 用户与 ...
- LINUX用户、组、权限管理和归档压缩、时间、Ping
一.用户与用户组管理.权限 1.用户文件/etc/passwd 2.用户密码/etc/shadow 3.组文件/etc/group 4.查看用户和组信息命令id 5.添加用户 useradd [-u ...
- 【Linux】【Basis】用户、组和权限管理
1. 概念: 1.1. 每个使用者都有,用户标识UID和密码:并且有身份(Authentication),授权(Authorization),审计(Audition):组(用户组,用户容器) 1.2. ...
- 用户和组的权限管理/特殊权限和ACL(个人笔记)
个人学习笔记总结 内容包括解释Linux的安全模型解释用户帐号和组群帐号的目的用户和组管理命令理解并设置文件权限默认权限特殊权限ACL介绍安全3A资源分派:Authentication:认证Auth ...
- Windows中的用户和组以及用户密码处理
目录 用户帐户 Windows 默认账户 Windows 内置用户账户 查看.创建和删除账户 组账户 内置组账户 组的查看.创建和删除 Windows中对用户密码的处理 LM-hash NTLM-ha ...
随机推荐
- vue-element-admin登录逻辑,以及动态添加路由,显示侧边栏
这段时间在研究element-admin,感觉这个库有许多值得学习的地方,我学习这个库的方法是,先看它的路由,顺着路由,摸清它的逻辑,有点像顺藤摸瓜. 这个库分的模块非常清晰,适合多人合作开发项目,但 ...
- docker部署项目: centos+python+redis+mysql+uwsgi+nginx
一.Centos7安装docker 1.1 环境配置 先测试是否下载了docker:查看镜像:docker images没有下载,就依次执行以下环境的安装 ①curl http://mirrors.a ...
- 五一培训 清北学堂 DAY4
今天上午是钟皓曦老师的讲授,下午是吴耀轩老师出的题给我们NOIP模拟考了一下下(悲催暴零) 今天的内容——数论 话说我们可能真的是交了冤枉钱了,和上次清明培训的时候的课件及内容一样(哭. 整除性 质数 ...
- CentOS7遇到问题总结
问题1.保护多库版本:libstdc++-4.8.5-28.el7_5.1.i686 != libstdc++-4.8.5-28.el7.x86_64 错误:保护多库版本:libgcc-4.8.5-2 ...
- Java基础_线程的使用及创建线程的三种方法
线程:线程是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务. 进程:进 ...
- html,css,js实现的一个钟表
效果如图: 实现代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- IntelliJ IDEA 2017.3 搭建一个多模块的springboot项目(一)
新人接触springboot,IDE使用的是IntelliJ IDEA 2017.3 ,自己摸索了很久,现在自己整理一下,里面有些操作我自己也不懂是为什么这样,只是模仿公司现有的项目,自己搭建了一个简 ...
- Vue之混入(mixin)与全局混入
Vue之混入(mixin)与全局混入 接下来通过一个简单的例子看看混入的基础用法: 首先新建一个mixin.js文件,添加以下代码. let mixin = { data() { return { m ...
- dubbo异常filter
dubbo请求调用过程分析 https://blog.csdn.net/javahongxi/article/details/72876694 浅谈dubbo的ExceptionFilter异常处理 ...
- hadoop新旧节点
注意:黑白名单只出现在名称(nn)节点<!-- 白名单 --><property><name>dfs.hosts</name>/Users/yangya ...