用户和组

用户信息文件

/etc/passwd
(1 2 3 4 5 6 7)
root:x:0:0:root:/root:/bin/bash 用户信息,以 : 分割字段
daemon:x:2:2:daemon:/sbin:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin 字段1:用户名
字段2:密码占位符(原用于存放密码,现已弃用)
字段3:uid(用户的身份标识)
0 超级管理员 1-499 程序用户 500-60000 普通用户 (centOS 6 中)
999 1000 (centOS 7 中)
在应用启动时,会调用程序用户来启动(该用户权限低,无法登陆系统)
字段4:gid用户的基本组id(一个用户只能有一个基本组,但可以有多个附加组)
字段5:用户信息(现已弃用)
字段6:用户的的家目录
字段7:用户登录系统的命令解释器类型(shell)
/bin/bash 表示该用户可以登录系统
/sbin/nologin 表示该用户无法登录系统

用户密码信息

/etc/shadow
1 2
root:$7$UmhhDLOFNijwwr6v$.rw/AyPqqm4WeoYnajjveFCabPT9SeOLALLWbarOvPuTGtJX5d1cmwgV5abwzCplR8ekN2XlbweD2xcpG06eb0::0:99999:7:::
userA:!!:18458:0:99999:7:::
1 2 3 4 5 6 78
字段1:用户名
字段2:被加密过的密码(利用sha-512算法,以及salt值混合加密的密码)
字段3:间隔天数(距1970年1月1日密码最近一次的修改时间)
字段4:密码的最短有效期,0表示不限制,若为3则表示用户(root除外)三天内不能修改自己的密码
字段5:密码最长有效期(建议设定成90天)
字段6:密码过期前的7天会有警告提示
字段7:密码的不活跃期
字段8:账户的失效时间

相关命令

用户管理
id user	 查看用户的信息(uid,gid以及附加组)
useradd userA 创建一个新用户userA
id会默认从可用id里顺序取值,且会同时创建同名的基本组和附加组
[root@localhost ~]# id userA
uid=1001(userA) gid=1001(userA) groups=1001(userA)
useradd -u 1223 -g 1001 userB 创建一个uid为1223,gid为1001的用户userB
usermod -g root userA 将用户userA的所属组改为root
usermod -G 1002 userA 为用户增加一个gid为1002的附加组
usermod -s /sbin/nologin 修改用户的命令解释器(无法登录,也不能由其他用户切换)
userdel -r userB 删除用户及其家目录,若无-r,则会保留家目录
组管理
groupadd gp  创建了一个名为gp的组
group -g 676 aaa 创建了一个gid为676的组aaa
groupmod -g 677 aaa 将组aaa的gid改为677
gpasswd -d aaa root 从root组成员中移除用户aaa
tail -3 /etc/group

userA:x:1001:aaa
userB:x:1002:
aaa:x:1003: 字段1:组名
字段2:密码标识
字段3:gid
字段4:组中的成员(以该组为附加组的用户,以该组为基本组的用户不显示)
密码管理
passwd -S root	查看root用户的密码状态
passwd userA 为用户userA设定密码
passwd -d userA 删除用户userA的密码
passwd -l userA 锁定用户userA,其不能在登录界面登录,但可以从其他用户切换
passwd -u userA 解锁用户
chage -M 90 userA 修改用户userA密码的最长有效期为90天

权限管理

文件的详细信息

ls -lh	列出文件的详细信息
-rwxr-xr-x. 1 root root 127 Jul 20 18:57 hello.sh
drwxr-xr-x. 12 500 500 4.0K Jul 17 16:25 httpd-2.2.15
-rwxrw-rw-. 1 root root 6.3M May 13 09:08 httpd-2.2.15.tar.gz
drwxr-xr-x. 3 root root 79 Jul 21 19:27 test
1 2 3 4 5 6 7 字段1:文件的类型和权限
字段2:文件类型如果是文件,代表文件的结点数inode
文件类型如果是目录,代表目录中子目录的个数(包括目录 . 和 ..)
字段3:文件的所属者
字段4:文件的所属组
字段5:文件的大小
字段6:文件的修改时间
字段7:文件名

文件权限

对文件的类型和权限信息部分进行分割
drwxr-xr-t. 2 root root 6 Jul 21 20:48 tmp1 (设置了粘置位的目录)
drwxr-xr-T. 2 root root 6 Jul 21 20:47 tmp2
- rwx r-x r-x + 1 root root 127 Jul 20 18:57 hello.sh
d rwx r-x r-x . 3 root root 79 Jul 21 19:27 test
1 2 3 4 5 字段1:文件类型 -普通文件 d目录 l符号链接 b块设备(硬盘)
字段2:文件所属者的权限
字段3:文件所属组的权限
字段4:其他用户的权限 (字段234属于文件基本acl)
字段5:文件扩展acl标识(.表示没有设置扩展acl,+表示设置了扩展acl)
(扩展acl的优先级高于基本acl)
权限中各字符的含义:
r w x
对于文件 读取 写入 可执行
对于目录 列出内容 增删文件 进入
(如果用户对于目录没有x权限,即使拥有rw权限也无法对其进行操作)

相关命令

chmod 改变文件或目录的权限
chmod u-x g+w o=r-x file (-撤权 +赋权 =直接覆盖权限)
撤销file文件所属者的执行权限,所属组增加写权限,其他用户只有读和执行权限
chmod a--- file
撤销所有用户和组对file文件的所有权限(root用户仍可以对其进行任意操作)
chmod -R o= ./test
撤销其他用户对test目录及其包含的所有文件的所有权限
chmod o+t /test 对目录设置粘置位
原本其用于显示他用户x权限的位置会被替代成t(有x权限)/T(无x权限)
chnod -u+s /usr/bin/vim 为 vim文件添加suid权限
(suid只对可执行文件有效果,任何运行该文件的用户都是以文件所属者的身份运行) 8进制赋权法
0 000 ---
1 001 --x
2 010 -w-
3 011 -wx
4 100 r--
5 101 r-x
6 110 rw-
7 111 rwx chmod 700 file 只有文件所属者对file文件有操作权限
chmod 444 file 所有用户对file文件只有读r权限
chmod 1444 /tmp3 对目录tmp3设置粘置位(1表示设置粘置位)
chmod 0444 /tmp3 撤销目录的粘置位 chown userA /tmp/1.txt 将文件1.txt的所属者更改为userA
chgrp -R userB ./test/ 将目录及其包含的所有内容的所属组更改为userB 文件acl设置
getfacl file 查看文件的facl
setfacl 设置文件扩展访问控制列表
setfacl -m u:userA:r-- ./1.txt
用户userA对1.txt文件只有r权限
setfacl -m g:userB:rw- ./1.txt
组userB对1.txt文件只有rw权限
setfacl -x u:userA ./1.txt
撤销userA用户在1.txt文件上的扩展acl
setfacl -b 1.txt
撤销对文件设置的所有扩展acl

Linux系统中(CentOS 7)的用户和权限管理的更多相关文章

  1. 在Linux系统中增加和删除用户

    linux创建账户并自动生成主目录和主目录下的文件 在Linux系统中增加和删除用户 Linux添加用户(user)到用户组(group) usermod -a -G groupA user linu ...

  2. 用户管理 之 在Linux系统中,批量添加用户的操作流程

    一.阅读此文件您需要掌握的基础知识: <Linux 用户(user)和用户组(group)管理概述><用户(user)和用户组(group)配置文件详解><Linux 用 ...

  3. Linux学习《第五章用户文件权限管理》之补充学习

  4. 嵌入式linux系统中,lsusb出现unable to initialize libusb: -99 解决办法 【转】

    转自:http://cpbest.blog.163.com/blog/static/41241519201111575726966/ libusb是linux系统中,提供给用户空间访问usb设备的AP ...

  5. 详解Linux系统中的文件名和文件种类以及文件权限

    Linux文件种类与副文件名 一直强调一个概念,那就是:任何装置在Linux底下都是文件, 不仅如此,连资料沟通的介面也有专属的文件在负责-所以,你会瞭解到,Linux的文件种类真的很多- 除了前面提 ...

  6. Linux 系统中用户切换

    1. Linux系统中用户切换的命令为su,语法为: su [-fmp] [-c command] [-s shell] [--help] [--version] [-] [USER [ARG]] 参 ...

  7. 用户管理 之 Linux 系统中的超级权限的控制

    在Linux操作系统中,root的权限是最高的,也被称为超级权限的拥有者.普通用户无法执行的操作,root用户都能完成,所以也被称之为超级管理用户. 在系统中,每个文件.目录和进程,都归属于某一个用户 ...

  8. Linux 系统中用户切换(su user与 su - user 的区别)

    1. Linux系统中用户切换的命令为su,语法为: su [-fmp] [-c command] [-s shell] [--help] [--version] [-] [USER [ARG]] 参 ...

  9. linux系统中用户切换

    1. Linux系统中用户切换的命令为su,语法为: su [-fmp] [-c command] [-s shell] [--help] [--version] [-] [USER [ARG]] 参 ...

  10. 在 Linux 系统中安装Load Generator ,并在windows 调用方法

    在 Linux 系统中安装Load Generator ,并在windows 调用 由于公司需要测试系统的最大用户承受能力,所以需要学习使用loadrunner.在安装的时候碰到了不少问题,所以写下此 ...

随机推荐

  1. JavaWeb网上图书商城完整项目--day02-27.查询所有分类功能之Servlet和Service层

    我们在上面实现了数据库层的代码,现在我们来实现业务层和Servlet层的代码:业务层的代码如下: package com.weiyuan.goods.category.service; import ...

  2. Git安装及配置SSH-Key

    下载Git 打开 https://git-scm.com/downloads 选择windows, 下载并安装. 配置全局用户名及邮箱 配置用户名 git config --global user.n ...

  3. 不同编程语言实现HelloWorld程序

    目录 C C# C++ HTML Java Python C #include <stdio.h> int main() { printf("Hello World!" ...

  4. 扫描U盘

    编辑器加载中...int CSendUDiskDlg::SearchUDisk(void) { int nCount, i; char szDriver[3]; nCount = 0; szDrive ...

  5. HDU 2157 How many ways?【矩阵快速幂】

    题目 春天到了, HDU校园里开满了花, 姹紫嫣红, 非常美丽. 葱头是个爱花的人, 看着校花校草竞相开放, 漫步校园, 心情也变得舒畅. 为了多看看这迷人的校园, 葱头决定, 每次上课都走不同的路线 ...

  6. 前端JS 下载大文件解决方案

    问题场景 点击导出按钮,提交请求,下载excel大文件(超过500M),该文件没有预生成在后端, 直接以文件流的形式返回给前端. 解决方案 在Vue项目中常用的方式是通过axios配置请求,读取后端返 ...

  7. springSecurity使用

    目录 1.1 依赖包导入 2.1 没有安全机制下的一个web 3.1 做一个安全机制的web 官网https://spring.io/guides/gs/securing-web/ 无情的翻译官... ...

  8. 「MoreThanJava」Day 3:构建程序逻辑的方法

    「MoreThanJava」 宣扬的是 「学习,不止 CODE」,本系列 Java 基础教程是自己在结合各方面的知识之后,对 Java 基础的一个总回顾,旨在 「帮助新朋友快速高质量的学习」. 当然 ...

  9. mysql 时间自动更新问题

    万恶的根据当前时间戳更新,有时候会自动更新,有时候又不会. 通过navicat 创建datetime类型的字段时,会自动勾选上根据当前时间戳更新.当更新数据的时候勾上这个的字段时间就会更改为当前的时间 ...

  10. day22 常用模块(上)

    一.时间模块 1 time模块 获取时间的三种格式: 第一种:time.time() 时间戳(timestamp):从1970年到现在的秒数 #应用场景:计算时间差 可以对时间加减,返回值为浮点型 p ...