欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  科技

Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)

程序员文章站 2022-04-11 08:34:35
一. 概述 linux安全系统的核心是用户账户。 创建用户时会分配用户ID(UID)。 UID是唯一的,但在登录系统时不是用UID,而是用登录名。在讲文件权限之之前,先了解下linux是怎样处理用户账户的。以及用户账户需要的文件和工具,这样处理文件权限问题时,就知道如何使用它们了。 1.1 /etc ......

一. 概述

  linux安全系统的核心是用户账户。 创建用户时会分配用户id(uid)。 uid是唯一的,但在登录系统时不是用uid,而是用登录名。在讲文件权限之之前,先了解下linux是怎样处理用户账户的。以及用户账户需要的文件和工具,这样处理文件权限问题时,就知道如何使用它们了。

  1.1  /etc/passwd用户文件
    /etc/passwd 是用来将用户的登录名,匹配到对应的uid上。它包含了一些与用户有关的信息。下面截取二个片断。如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    root用户账户是linux系统管理员,固定分配给它的uid是0。 上面linux系统会为各种各样的功能创建不同的用户账户,而这些账户并不是真正的用户。它们叫作系统账户,是系统上运行各种服务进程访问资源用的特殊账户。root用户uid是0,mysql用户的uid是998。如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    linux系统账户预留了500以下的uid值。有些服务甚至要用特定的uid才能正常工作。在/etc/passwd文件中冒号分隔的字段包含以下信息:

            mysql:x:998:1000::/home/mysql:/bin/bash

登录用户名

例如:mysql

用户密码

x (密码字段都被设置成了x)

用户uid

998

用户的组id (gid)

i000

用户的文本描述

mysql 用户描述为空

用户的home目录位置

/home/mysql

用户的默认shell

/bin/bash

  

  1.2  /etc/shadow 用户文件

    /etc/shadow文件对linux系统密码管理提供了更多的控制。只有root用户才能访问/etc/shadow文件。比起/etc/passwd安全许多,文件内容如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    比如让mysql 用户来查看该文件,是没有这个权限的。
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    下是copy出来的root用户账户信息:

root:$6$bsexl2xuinyldwko$x4dfd8a97xhro9s.9knql/brx4b33tiazou1dwipvlds42yqway8jrwyaexgpuvc42yhnmmo28vrmp.qvjydy1::0:99999:7:::

    每条记录都有9个字段,字符串以冒号分隔的字段信息如下:第一个字段:登录名。 第二个字段:加密后的密码。其它字段以后在解读。使用/etc/shadow,可以控制用户多久更改一次密码,以及什么时候禁用该用户账户(在其它字段上设置这些功能)。

 

二. 用户工具管理

  2.1 useradd 模板介绍

    在linux系统中添加新用户的工具是useradd, 可以一次性创建新用户账户及设置用户home目录结构。useradd命令使用系统的默认值以及命令行参数来设置用户账户。系统默认值被设置在/etc/default/useradd文件中,可以定位到/etc/default/useradd文件,修改默认值。使用useradd       -d 选项查看这些默认值。如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    如果用户不指定具体的值,使用useradd添加用户时就会使用这些默认值。默认值解释如下:

group=100

新用户会添加到gid为100的公共组中

home=/home

新用户的home目录将位于/home/loginname下

inactive=-1

新用户密码在过期后不会被禁用

expire=

新用户未设置过期日期

shell=/bin/bash

新用户将bash shell作为默认shell

skel=/etc/skel

系统会将/etc/skel目录下的内容复制到用户的home目录下

create_mail_spool=yes

系统为用户账户在mail目录下创建一个用于接收邮件的文件

    skel参数是指:useradd命令允许管理员创建一份默认的home目录配置,然后把它作为创建新用户home目录的模板。这样就能自动在每个新用户的home目录里放置默认的系统文件(上篇讲到的系统环境变量位置)。新用户home目录下的系统文件模板。如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    在上篇中,知道了.bashrc, .bash_profile这些文件都是bash shell的标准启动文件。系统会自动将这些默认文件复制到你创建的每个用户home目录下。我的linux系统在很久前创建了一个mysql用户,下面去/home/mysql下检查有没有这些标准启动文件。
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    上图告诉我们,mysql目录不存在,这是因为创建用户默认情况下,useradd命令不会创建home目录,需要使用useradd -m 命令来创建home目录。我推测当mysql用户没有这些bash shell标准启动文件时,会去继承root用户下的标识启动文件。

   2.2  useradd -m
    上面mysql用户没有指定home目录,下面是创建一个新test用户,并使用参数m来创建home目录,并将/etc/skel目录中的文件复制了过来,/home/test 下面就有了标准启动文件。如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    再次查看passwd用户列表,多出来一个test用户,创建的这个test除了指定了home目录,其它参数都是使用的默认值(没有指定组,密码,过期时间)。如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)
    下面是切换到test用户下,如下图所示:
        Linux编程 14 文件权限(用户列表passwd,用户控制shadow,useradd模板与useradd命令参数介绍)

   2.3 useradd 命令参数
    要想在创建用户时改变默认值或默认行为,可以使用命令参数,下面列出一些常用参数

参数

描述

-c comment

给新用户添加备注

-d home_dir

为主目录指定一个名字(如果不想用登录名作为主目录名)

-e expire_date

用yyyy-mm-dd格式指定一个账户过期日期

-f inactive_days

指定这个账户密码过期后多少天,这个账户被禁用;0表示密码一过期就立即禁用, 1表示禁用这个功能

-g initial_group

指定用户登录组gid

-m

创建用户home目录

-r

创建系统账户

-p passwd

指定默认密码

    当创建用户账户时,如果总需要修改某个值的话,最好还是修改一下系统的默认值,修改(useradd模板),也可以使用"useradd -d 默认参数"来修改模板,这里就不再介绍useradd默认值参数。