用户,组和权限管理 基础命令整理

安全3A任何一个安全策略都应该有Authentication(认证)、Authentication(授权)、Accouting|Audition(审计)这三个措施。

用户(User)Linux用户是安全3A中的Authentication(认证)措施。用户在登录时,系统会检查用户输入的用户名和密码。如果用户输入的用户名和密码匹配,会根据用户信息给用户分配一个令牌token;如果用户输入的用户名和密码不匹配,直接拒绝用户登录。

用户类型      人识别用户是靠用户名,识别用户是靠UID

管理员: root用户,UID为0。
普通用户: UID范围1-65535。

  • 系统用户: 用于对守护进程获取资源进行权限分配。Centos6系统的UID范围1-499,Centos7系统的UID范围1-1000。
  • 登录用户: 用于用户的交互式登录。Centos6系统的UID范围500-65536,Centos7系统的UID范围1000-65535。

组(Group)Linux组是用户权限分配的容器,同一个组内的用户都能够获得这个组拥有的权限。

站在系统管理的角度

管理员组: root用户组,GID为0。                 普通用户组: UID范围1-65535。

  • 系统用户: Centos6系统的GID范围1-499,Centos7系统的GID范围1-1000。
  • 登录用户: Centos6系统的GID范围500-65536,Centos7系统的GID范围1000-65535。

站在用户的角度

主要组(主组):

  • 用户必须属于一个主组,且只能有一个
  • 组名和用户名同名,且该组成员只有用户一个,那么这个组是用户的私有组

附加组(辅助组): 一个用户可以属于零个或多个辅助组

进程的安全上下文

进程的安全上下文是保障系统运行安全的一个非常重要的技术

进程是运行中的程序。每个进程都必须以一个特定的用户身份运行,即进程是有属主的。当用户运行一个程序时,这个程序运行起来的进程的属主就是该用户。以进程访问系统上的文件为例: 系统检查进程的属主是不是这个文件的属主,如果是,进程以文件的属主权限访问该文件;否则,系统再检查进程的属主所在的组里(包括附加组)有没有该文件的属组,如果有,进程以文件的属组权限访问该文件;如果没有,进程以文件的其他者的权限访问该文件。

用户相关的文件

/etc/passwd——存放用户及其属性信息

name : password : UID : GID : GECOS : directory : shell

  • name: 用户登录名
  • password: 早期用来存放用户加密过后的密码
  • UID: 用户的身份编号
  • GID: 用户的主组编号
  • GECOS: 用户的全名或注释
  • directory: 用户的家目录
  • shell: 用户默认使用的登录shell

/etc/shadow ——存放用户密码及其相关属性

name : password : last change : minimum age : maximum age : warning period : inactivity period : expiration date : reserved field

  • name: 用户的登录名
  • password: 用户密码。centos5采用md5加密方法,centos6/7采用sha512加密方法。
  • last change: 密码上一次修改距1970.1.1所经过的天数
  • minimum age: 密码的最短使用天数,(0表示密码可随时变更)
  • maximum age: 密码的最长使用天数,(9999表示密码永不过期)
  • warning period: 密码的警告期限,用户登录时提示用户修改密码
  • inactivity period: 非活动期限,用户密码过期超过此时间将被禁用
  • expiration date: 从1970.1.1开始算,超过此时间帐号失效

组相关配置文件

/etc/group ——存放用户组及其相关属性信息

group_name : password : GID : user_list

  • group_name: 组名
  • password: 组密码, 组密码通常是记录在/etc/gshadow文件中
  • GID: 组ID
  • user_list: 以当前组为附加组的用户列表(以逗号分隔)

gshadow ——用户组的shadow文件

group_name : encrypted_password : administrators : members

  • group_name: 组名
  • encrypted_password: 加密过后的密码
  • administrators: 组管理员密码
  • user_list: 以当前组为附加组的用户列表(以逗号分隔)

用户管理相关命令

useradd 创建用户并设置相关属性

useradd [options] LOGIN

  • -c, –comment COMMENT: 用户的注释信息
  • -d, –home-dir HOME_DIR: 指定用户家目录。家目录中的内容默认是从/etc/skel复制过去的,当用户家目录已经存在时不会复制。
  • -e, –expiredate EXPIRE_DATE: 指定用户过期时间(格式: YYYY-MM-DD)
  • -f, –inactive INACTIVE: 指定账户的非活动期限
  • -g, –gid GROUP: 指定用户的基本组id或组名。
  • -G, –groups GROUP1[,GROUP2,…[,GROUPN]]]: 指定用户的附加组,多个用, 逗号分隔
  • -s, –shell SHELL: 指定用户的默认shell
  • -o, –non-unique: Allow the creation of a user account with a duplicate (non-unique)UID。This option is only valid in combination with the -u option。
  • -u, –uid UID: 指定用户的UID
  • -r: 创建系统用户
  • -D: 列出/改变创建用户的默认值, useradd创建用户的默认值存储在/etc/default/useradd和/etc/login.defs文件中
  • usermod 用户属性修改

    usermod [OPTION] login

    • -a, –append: 配合-G选项给用户添加附加组
    • -u, –uid UID: 修改用户的UID
    • -g, –gid GROUP: 修改用户的基本组ID
    • -G, –groups GROUP1[,GROUP2,…[,GROUPN]]]: 修改用户的附加组列表,常配合-a选项给用户添加附加组
    • -s, –shell SHELL: 修改用户的默认登录shell
    • -c, –comment COMMENT: 修改用户的注释信息
    • -d, –home HOME_DIR: 修改用户的家目录,配合-m选项移动或重命名用户的家目录
    • -l, –login NEW_LOGIN: 修改用户的登录名
    • -L, –lock: 锁定用户,在/etc/shadow 密码栏的增加 !
    • -U, –unlock: 解锁用户,将 /etc/shadow 密码栏的 ! 拿掉
    • -e, –expiredate EXPIRE_DATE: 修改用户的过期时间(格式: YYYY-MM-DD)
    • -f, –inactive INACTIVE: 修改用户的非活动期限
    • -o, –non-unique: When used with the -u option, this option allows to change the user ID to a non-unique value
    • userdel 删除用户
    • 用户已经登录时无法删除

      userdel [options] LOGIN

      • -r, –remove: 删除用户、用户家目录和用户邮箱
      • id 查看用户的相关信息

        当id命令后面不跟用户时显示当前登录用户的相关信息

        id [OPTION]… [USER]

        • -g, –group: 只显示用户的基本组ID
        • -G, –groups: 只显示用户所有的附加组ID, 用空格分割
        • -u, –user: 只显示用户的UID
        • -n, –name: 使用名称代替数字ID信息

      su 切换用户或以其他用户身份执行命令

      切换用户的方式:

      • su UserName:非登录式切换,即不会读取目标用户的 配置文件,不改变当前工作目录
      • su – UserName:登录式切换,会读取目标用户的配置 文件,切换至家目录,完全切换
        root su至其他用户无须密码;非root用户切换时需要密码

      su [options…] [-] [user [args…]]

      • -l: 相当于su – user
      • -c: 换个身份执行命令

    passwd 修改用户密码和密码相关属性信息

    passwd [OPTIONS] [UserName] (不指定UserName是修改自己的密码,只有root用户才能指定UserName)

    • -l, –lock: 锁定指定用户
    • -u, –unlock: 解锁指定用户
    • -e, –expire: 强制用户在下一次登录必须更改密码
    • -n, –minimum DAYS: 修改指定用户密码的最短使用期限
    • -x, –maximum DAYS: 修改指定用户密码的最长使用期限
    • -w, –warning DAYS: 修改指定用户密码的警告期限
    • -i, –inactive DAYS: 修改指定用户密码的非活动期限
    • –stdin: 从标准输入接收用户密码

    chage 设置用户密码策略

    chage [OPTION]… LOGIN

    • -d, –lastday LAST_DAY: 设置指定用户密码上一次修改时间(格式: YYYY-MM-DD)
    • -E, –expiredate EXPIRE_DAT: 设置指定用户的过期时间(格式: YYYY-MM-DD)
    • -I, –inactive INACTIVE: 设置指定用户密码的非活动期限
    • -m, –mindays MIN_DAYS: 设置指定用户密码的最短使用期
    • -M, –maxdays MAX_DAYS: 设置指定用户密码的最长使用期
    • -W, –warndays WARN_DAYS: 设置用户密码的警告期限
    • -l, –list: 显示指定用户的密码策略

    用户管理的其他命令

    • chfn-69806: 修改用户的注释信息
    • chsh: 修改用户使用的默认shell
    • finger: 查看用户的注释信息

    组管理相关命令

    groupadd 创建组并指定相关信息

    groupadd [options] group

    • -g, –gid GID: 创建用户组并指定其组id
    • -r, –s

      groupmod 修改组信息

      groupmod [options] GROUP

      • -g, –gid GID: 修改指定用户组的GID
      • -n, –new-name NEW_GROUP: 指定组的组名

    groupdel 删除组

    如果某个用户以这个组为主组,那么这个组将无法被删除

    gpasswd 更改组密码和组的成员信息

    gpasswd [option] GROUP gpasswd命令后面不跟选项直接跟组名是修改指定组的密码

    • -a, –add USER: 将指定用户添加到组里面
    • -d, –delete user: 将指定用户从组中删除
    • -A, –administrators user,…: 设置该组的管理员列表, 多个用逗号隔开

    groupmems 查看或管理组中成员

    groupmems [options] [action]

    Option:

    • -g, –group groupname: 指定需要查看或操作的对象

    action:

    • -a, –add username: 向指定组中添加用户
    • -d, –delete username: 删除组中的指定用户
    • -p, –purge: 清空指定组中的组中的所有用户
    • -l, –list: 查看指定组的所有用户

    groups 查看组信息

    newgrp 临时切换基本组

    当用户的基本组和附加组中已经包含了要切换的目标组,则用户使用newgrp切换基本组时不需要输入密码

    其他相关命令

    • vipw、vigr 编辑用户和组相关文件,带语法检查功能
    • pwck、grpck 检查用户和组相关文件。
    • openssl rand -base64 20 生成20位的随机数
    • newuser FILE: 批量创建用户,要求FILE文件的格式和/etc/passwd文件的格式一样
    • cat passwd.txt | chpasswd: 批量更改用户密码,passwd.txt文件格式: Username: passwd

原创文章,作者:island,如若转载,请注明出处:http://www.178linux.com/69806

(0)
islandisland
上一篇 2017-03-16
下一篇 2017-03-16

相关推荐

  • linux高级文件系统管理

    磁盘配额:         (1)如果存放的文件空间不足,虽然分区后不能直接扩容,但是可以迁移,下面以/home目录示例: 1、新建分区,同步分区表 /dev/sda62、mkfs.ext4 /dev/sda6             &n…

    Linux干货 2017-03-14
  • 第6天预习xargs命令的用法

    Xargs用法详解 1. 简介   之所以能用到这个命令,关键是由于很多命令不支持|管道来传递参数,而日常工作中有有这个必要,所以就有了xargs命令,例如: find /sbin -perm +700 |ls -l     &n…

    Linux干货 2016-08-05
  • 一个PHP程序员学习运维的转型

         我是一位PHP开发工程师,平时负责前端、后端以及服务器端的工作,但是称不上是个牛逼的程序员。网上热烈讨论一则传闻,“全栈工程师”(Full Stack Engineer),要求应征者对开发堆栈的每个方面都有所掌握。那究竟何为 “全栈工程师”呢?从字面上来理解,全栈工程师必须熟悉开发堆栈的每一个层次,或者至少熟悉绝大多数…

    Linux干货 2017-04-02
  • PXE原理详解及实践

    一、PXE简介 PXE(preboot execute environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由支持通过网络启动操作系统,再启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial file transfer protocol…

    Linux干货 2017-01-10
  • 细数Linux发行版

    什么是Linux 广义上讲:Linux内核+应用程序狭义上讲:Linux内核  > Linux内核指的是我们通常所说的Kernel,主要用于负责系统调用、进程管理、内存管理、文件系统管理等功能。  应用程序指的是由GNU组织提供的开源的、通用的应用程序,如gcc、glibc、vi等。 我们平常所说的Linux,通常指广义层面上的Li…

    Linux干货 2017-08-30
  • 马哥教育21期网络班—第15周课程+练习

    2、删除/boot/grub/grub.conf文件中所有行的行首的空白字符; sed 's@^[[:space:]]\+@@' /boot/grub/grub.conf 3、删除/etc/fstab文件中所有以#开头,后跟至少一个空白字符的行的行首的#和空白字符; sed 's@^#[[:spac…

    Linux干货 2016-11-14