Linux用户、组、权限管理

Linux用户与组管理

Linux系统上,用户通过内核拷贝程序到内存中,从此发起进程。进程以发起者的身份进行,进程对文件的访问权限,取决于发起进程的用户的权限。而有些后台进程或服务类进程以非管理员身份运行,为此也需要创建多个普通用户,此类用户不需登录。

系统中,用户类别分为管理员和普通用户(系统用户和登录用户),组类别分为基本组和附加组。管理系统上的用户与组主要通过以下四个文件来实现

  • /etc/passwd 用户的基本信息

  • /etc/shadow 用户密码

  • /etc/group 组的基本信息

  • /etc/gshadow 组密码

生成密码采用单向加密算法,并借助salt完成。分别用数字1-6来标识md5, sha1, sha225, sha256, sha384, sha512六种加密算法。对用户与组的管理一般涉及以下几类工作:用户/组的创建、修改、删除、切换、设置密码四个方面。

用户管理

创建用户 useradd

useradd [option] login-name
    -u 指定UID
    -g 指定基本的GID,但指定的组必须事先存在
    -G 指定用户所属的附加组,多个组之间用","隔开
    -c 指定注释信息comment
    -d /path/to/home-dir 指定用户家目录;通过复制/etc/skel目录并重命名实现;如果指定的及目录已经存在,不从skel文件夹中复制文件
    -s 指定用户默认shell,可用的所有可选shell存储在/etc/shells文件中
    -r 创建系统用户
    -m 强制创建用户主目录
    -M 不为用户创建主目录
    -f 用户非活动期 -1 永不过期
注意:创建用户时的诸多默认设定,配置文件为/etc/login.defs
        useradd -D 显示创建用户的配置信息
        useradd -D [options] 修改默认选项的值,修改的结果保存在/etc/default/useradd文件中

修改用户属性 usermod

usermod [option] login-name
    -u newUID 修改用户的UID为此处指定的UID
    -g 修改用户的GID,修改用户所属的基本组
    -G 修改用户所述的附加组。注意:此处修改只能覆盖原有附加组设置
    -a 与-G共同使用,为用户添加附加组
    -c 修改用户的注释信息
    -d /path/to/new-home-dir 修改用户的家目录,用户原有的文件不会被转移至新目录
    -m 只能与-d一同使用,将原有的家目录转移为新的家目录;
    -l 修改用户的登录名
    -s 修改用户的默认shell
    -L 锁定用户的账号,禁止用户登录;即在用户原来的面字符之前添加一个“!”
    -U 解锁用户的账号

设置密码信息 passwd

passwd [option] [login-name]    命令后不指明login-name时,用户可为自己的账号修改密码信息
    passwd login-name 只有root能修改其他用户的密码信息
        -l/-u 锁定/解锁用户账户
        -d 清除用户密码
        -e date 指明用户账户过期明确的日期
        -n days 密码最小使用期限
        -x days 密码最长使用期限
        -i days 非活动期限
        -w days 警告期限
        --stdin 从标准输入读取密码

切换用户 su

登录式切换:会通过重新读取用户的配置文件来重新初始化
    su - username
    su -l username  
非登录式切换:
    su username
        注意:管理员可以无密码切换至其他任何用户
        su - username -c "COMMAND" 以某用户的身份运行“COMMAND”

显示用户有效ID

id [option] [user]
    -u 仅显示UID
    -g 仅显示用户基本组ID
    -G 仅显示用户所属的所有组ID
    -n 显示用户的名称而非ID

删除用户 userdel

userdel [option] login-name
    -r 删除用户时一并删除其家目录

组管理

创建新组 groupadd

groupadd [option] group-name
    -g GID 指定GID;默认为上一个GID+1
    -r 创建系统组

修改组属性 groupmod

groupmod [option] group-name
    -g GID修改组ID
    -u new-group-name 修改组名

修改组密码 gpasswd

gpasswd [option] group
    -a username 向组中添加用户
    -d username 从组中移除用户
    -r 删除指定组的组密码

组切换 newgrp

newgrp [-] [group-name]   如果命令后不跟group-name,则用户切换回/etc/passwd文件中记录的默认组
    - 会模拟用户以新组重新登录,以实现重新初始化工作环境

删除组 groupdel

groupdel [option] group-name

权限管理

Linux文件中的权限有9位字符,通过ls命令的-l选项可以查看。

[root@localhost ~]# ls -l .
total 8
-rw-------. 1 root root 1624 Nov 13 08:29 anaconda-ks.cfg
-rw-------. 1 root root 1672 Nov 13 00:36 initial-setup-ks.cfg
  • 左三位是文件属主的权限,中三位是文件属组的权限,右三位是其他用户对该文件的权限。

  • 每类用户的权限共有8种组合“—, –x, -w-, r–, -wx, r-x, rw-, rwx”,r:可读取文件的内容,w:可以修改文件的数据,x:可将文件运行为进程。8种组合表示为数字分别为:0,1,2,3,4,5,6,7。

Linux中进程对文件的访问权限遵从以下模型:1 如果进程的属主与文件的属主一致,则应用属主对该文件的权限;2 如果属主不一致,如果进程的属主属于用户的属组,则应用该文件的属组对该文件的权限;3 如果进程的属主以上两条都不满足,则应用other权限。

Linux中权限的管理主要涉及两个方面:设定文件的属主、属组;设定文件属主、属组以及其他用户分别所具有的权限。

设置文件属主、属组以及其他用户的权限 chmod

chmod [option] mode[,mode]... fiel...
    mode表示法:
        赋权表示法:直接操作一类用户的所有权限位rwx;
            u/g/o/a=
        授权表示法:直接操作一类用户的一些权限位r,w,x;
            u+, u-
            g+, g-
            o+, o-
            a+, a-
    --reference=/path/to/reference 以reference文件的权限作为参考标准
    -R 递归修改

修改文件的从属关系 chown

chown [option]... [owener][:group] file
    --reference=/path/to/reference 以reference文件的属主属作为参考标准修改之
    -R 递归修改

文件的权限反向掩码,遮罩码 umask

新建文件:其权限为666-umask;新建目录:其权限为777-umask。Linux中新建文件默认不能拥有执行权限,如果(666-umask)结果中有执行权限,则自动为其加一。

umask 查看当前命令
umask MASK 设置umask,只对当前shell进程有效

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

(0)
N24_fynlN24_fynl
上一篇 2016-12-07
下一篇 2016-12-07

相关推荐

  • 创建私有CA

      什么是CA   CA(Certificate Authority)证书颁发机构主要负责证书的颁发、管理以及归档和吊销。证书内包含了拥有证书者的姓名、地址、电子邮件帐号、公钥、证书有效期、发放证书的CA、CA的数字签名等信息。证书主要有三大功能:加密、签名、身份验证。 搭建私有CA 一、搭建CA服务器 1、生成密钥 ( ):表示此命令在子进程中运…

    Linux干货 2017-02-07
  • 第二周博客作业

    1.Linux上的文件管理类命令都有那些,其常用的使用方法及其相关示例演示。
    2.Bash的工作特性之命令执行状态返回值和命令行展开所涉及的内容及其示例演示。
    3.请使用命令行展开功能来完成以下的练习。
    4.文件的元数据信息有哪些,分别表示什么含义,如何查看?如何修改文件的时间戳信息。
    5.如何定义一个命令的别名,如何在命令中引用另一个命令的执行结果?
    6.显示/var目录下所有以1开头,以一个小写字母结尾,且中间至少出现一位数字(可以有其他字符)的文件或目录。
    7.显示/etc目录下,以任意一个数字开头,且以非数字结尾的文件或目录。
    8.显示/etc目录下,以非字母开头,后面跟了一个字母以及其他任意长度任意字符的文件或目录。
    9.在/tmp目录下创建以tgile开头,后跟当前日期和时间的文件,文件名形如:tfile-2016-05-27-09-32-22
    10.复制/etc目录下所有以p开头,以非数字结尾的文件或目录到/tmp/mytest1目录中。
    11.复制/etc目录下所有以.d结尾的文件或目录到/tmp/mytest2目录中。
    12.复制/etc目录下所有以l或m或n开头,以.conf结尾的文件至/tmp/mytest3目录中。

    2018-03-22
  • find命令用法及示例

    文件查找 locate,find可是实现在文件系统上查找符合条件的文件 实现工具:locate,find locate有几下几个特性 1、依赖于事先构建好的索引库; 2、系统自动实现;(周期性任务) 3、手动更新数据库(updatedb) /var/lib/mlocate/mlocate.db 工作特性: 查找速度快; 模糊查找; 非实时查找 lo…

    Linux干货 2016-08-18
  • Keepalive+Nginx高可用配置(主从)

    Keepalived高可用集群 一、Keepalived介绍 Keepalived软件主要通过VRRP协议实现高可用功能的。VRRP是Virtual Router Redundancy Protocol(虚拟路由器冗余协议)的缩写,VRRP出现的目的就是为了解决静态路由单点故障问题,它能够保证当个别节点宕机时,整个网络可以不间断地运行。keepalived除…

    Linux干货 2016-12-30
  • 第二周作业

    新建 Microsoft Word 文档.docx

    Linux干货 2016-12-13
  • 文件查询、yum安装等零散知识点总结

    归纳重要知识点:文件查询、Linux配置文件、文件的压缩与归档、yum安装包文件   这篇博客介绍以前遗落的重要知识点进行归纳总结,分为四大块:文件查询命令、全局与个人配置文件、文件的压缩与归档、yum命令安装程序包的相关条件与操作。下面结合个人理解与学习内容一一进行总结。     一.文件查询命令locate与find &nb…

    Linux干货 2016-08-26

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-14 15:02

    基础命令总结的得非常好,希望你能牢记这些基础知识。加油!