当前位置:首页 » Linux技术知识

centos7用户,组及文件权限管理

2017-08-10 21:01 本站整理 浏览(6)

centos7安装过程中如果没有创建用户的话,默认只有ROOT用户,这个用户是具有最高权限的帐户,可以做任何事情,但实际生产环境中我们一般不会使用这个用户,因为权限太大了,很危险。

所以在生产环境中就要创建一个或多个用户帐户,分配合适的权限来使用,用过windows的都知道,windows也是多用户,多任务的操作系统,每个用户也都有配置文件,用来定义和保存用户的环境变量,包括用户的家目录,桌面等的配置。那么linux同样也是多用户,多任务操作系统,同样可以创建多个用户,定义每个用户的所属组,家目录,登录的shell,邮件等等环境变量。

在centos7中和用户相关的配置文件主要包括以下这么几个

/etc/passwd

此文件保存着:用户名:密码:UID:GID:用户描述:主目录:登录shell

/etc/shadow

此文件记录的行与passwd中的行一一对应,保存着:用户名:密码:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

/etc/group

此文件保存着:用户组名称:用户组密码:GID:用户列表(多个用户之间用,分隔)

/etc/gshadow

此文件与/etc/group文件中的行对应,保存着:用户组名:加密码后的密码:组管理员(多个用,分隔):组成员(多个用,分隔)

/etc/default/useradd

这个文件主要保存着 创建账户时的默认值,使用useradd –D查看到的内容就是这个文件中的内容。

/etc/skel

这是个一个目录,相当于windows中公用的账号环境设置,比如,可以在这个目录里放一个文本文件,当创建用户时,在每个用户的家目录里都可以看到这个文件,当然也可以放置公共的配置文件,创建用户时就可以延用这个配置。

/etc/login.defs

这个是用来设置用户帐号限制的配置文件,比如密码的最大过期天数,长度等,但优先级小于/etc/shadow

/etc/profile

这个文件主要用来保存环境变量的,是全局的,由系统管理员管理

~/.bashrc .bash_history .bash_profile .bash_logout 等

这些文件主要用来定义用户的环境变量的。

一.用户管理

1.创建用户

命令用法:useradd 或 adduser [option] 用户名

useradd 或 adduser –D                    用来查看创建账户时的默认值

useradd 或 adduser –D [option]        用来指定或修改创建账户时的默认值

一般可以修改默认值的参数有:-b –e –f –g –s)

我们用 useradd –help来看一下都有哪些参数

[root@ha1 ~]# useradd --help
Usage: useradd [options] LOGIN
       useradd –D                      
       useradd -D [options]     
Options:
  -b, --base-dir BASE_DIR       指定创建用户HOME目录的位置,一般结合 –D 使用                                
  -c, --comment COMMENT         给新用户添加备注
  -d, --home-dir HOME_DIR       指定用户家目录的文件名
  -D, --defaults                用来查看创建账户时的默认值,也就是/etc/default/useradd文件中的内容
  -e, --expiredate EXPIRE_DATE  用YYYY-MM-DD格式指定一个账户过期的日期
  -f, --inactive INACTIVE       指定这个账户密码过期后多少天这个账户被禁用;0表示密码一过期就被禁用,-1表示禁用这
                                个功能
  -g, --gid GROUP               指定用户所属组的GID或组名
  -G, --groups GROUPS           指定用户除所属组外的一个或多个附加组
  -h, --help                    display this help message and exit
  -k, --skel SKEL_DIR           必须和-m一起使用,将/etc/skel目录的内容复制到用户的HOME目录
  -K, --key KEY=VALUE           主要用来改写/etc/login.defs文件中的默认值,如:-K UID_MIN=100 –K UID_MAX=499
  -l, --no-log-init             do not add the user to the lastlog and
                                faillog databases
  -m, --create-home             创建用户的HOME目录
  -M, --no-create-home          不创建用户的HOME目录
  -N, --no-user-group           不创建与用户同名的用户组
  -o, --non-unique              仅与-u选项结合使用,允许创建一个用户ID不唯一的用户
  -p, --password PASSWORD       为用户指定默认密码
  -r, --system                  创建系统账户
  -R, --root CHROOT_DIR         允许用户根据配置文件来切换家目录
  -s, --shell SHELL             指定用户登录的shell
  -u, --uid UID                 指定用户的UID
  -U, --user-group              创建与用户同名的组
  -Z, --selinux-user SEUSER     此选项不常用

举例说明:

创建名为jerry的用户,指定HOME目录:/home/h_jerry,指定UID 1022,不创建同名用户组,指定密码:jerry,指定shell:/bin/sh,指定账户过期时间:2017-08-09,允许密码过期后使用,添加用户描述:first user

[root@ha1 ~]# useradd -m -d /home/h_jerry -u 1022 -N -p jerry -s /bin/sh -e 2017-08-09 -f -1 -c "first user" jerry

用户创建完成没报错说明命令成功执行,那就一步一步来验证一下:

验证用户的UID

[root@ha1 ~]# id jerry
uid=1022(jerry) gid=100(users) groups=100(users)

看到用户ID 1022没错是我们指定的数字,由于没有创建指定的同名组,所以就用/etc/default/useradd中的默认值的组ID100,默认加入到users组中,都有哪些默认值呢,我们来看一下/etc/default/useradd这个文件

[root@ha1 ~]# cat /etc/default/useradd 
# useradd defaults file
GROUP=100
HOME=/home
INACTIVE=-1
EXPIRE=
SHELL=/bin/bash
SKEL=/etc/skel
CREATE_MAIL_SPOOL=yes

看下/etc/passwd文件对应的jerry行的信息

[root@ha1 ~]# cat /etc/passwd |grep jerry
jerry:x:1022:100:first user:/home/h_jerry:/bin/sh

此文件由7段冒号隔开的字段

第一字段  jerry表是用户名

第二字段  X表示加密码后的密码

第三字段  1022表示UID

第四字段  100表示组ID

第五字段  first user表示描述信息

第六字段  /home/h_jerry表示家目录

第七字段  /bin/sh表示登录的sehll

再来看一下/etc/shadow文件中的内容

[root@ha1 ~]# cat /etc/shadow |grep jerry
jerry:jerry:17386:0:99999:7::17387:

/etc/shadow文件由9个字段组成,用:分隔

第一字段  jerry:表示用户名

第二字段  jerry:表示密码,这里看到是明文的,并没有被加密码,但是passwd jerry来修改密码后就会是加密的。

第三字段  17386:表示上次修改密码的时间,这个时间是从1970年1月1号到最近一次修改密码的时间间隔天数

第四字段  0:表示2次修改密码间隔的天数,0表示禁用此功能

第五字段  99999:表示2次修改密码间隔最多的天数,也有默认值,是通过/etc/login.defs中PASS_MAX_DAYS定义

第六字段  7:表示提前7天警告用户密码过期,也有默认值,是通过/etc/login.defs中PASS_WARN_AGE定义

第七字段  在密码过期之后多少天禁用此用户,也就是过期多少天后系统禁用此用户,不能登录,不会提示过期,完全禁用,

空:表示密码过期后账号仍然可用(-f –1)

第八字段  17387:用户过期日期(从19700101开始的天数)和创建用户指定过期日期正好相符(-e 2017-08-09)

第九字段  保留字段 留空

看一下用户的HOME目录

[root@ha1 ~]# ll /home
total 0
drwx------. 2 jerry users 62 Aug  8 21:37 h_jerry
[root@ha1 ~]# ll -a /home/h_jerry/
total 16
drwx------. 2 jerry users  83 Aug  9 18:45 .
drwxr-xr-x. 4 root  root   33 Aug  9 18:39 ..
-rw-------. 1 jerry users  11 Aug  9 18:45 .bash_history
-rw-r--r--. 1 jerry users  18 Aug  3  2016 .bash_logout
-rw-r--r--. 1 jerry users 193 Aug  3  2016 .bash_profile
-rw-r--r--. 1 jerry users 231 Aug  3  2016 .bashrc

OK,到这里用户创建已经成功,简单梳理一下创建用户时系统做了哪些事:

如果创建用户不带参数,系统会根据默认值(/etc/default/useradd,/etc/login.defs)创建用户及同名用户组,并在HOME目录里创建同名家目录,默认的登录shell为/bin/bash。

如果创建用户时带了参数,那么系统会根据参数来创建指定用户信息。

用户创建完成后,/etc/passwd,/etc/shadow这2个文件都会有相应的用户信息。

在用户家目录里都会产生.bash_history .bash_logou .bash_profile .bashrc4个隐藏文件。

开篇提到了/etc/skel这个目录,到底是干什么用的呢,试一下就知道了,在这个目录里创建一个a.txt的文件,接着再创建一个tcl的新用户,再看看用户的家目录。

[root@ha1 ~]# vi /etc/skel/a.txt
[root@ha1 ~]# useradd tcl
[root@ha1 ~]# ll /home/tcl/
total 4
-rw-r--r--. 1 tcl tcl 28 Aug  9 18:58 a.txt

看到了吧,在/etc/skel目录里的文件被复制到了新创建的用户的家目录里,注意,已经创建好的用户家目录里是没有的,只对新创建的用户有效。

2.为用户设置密码

使用passwd 用户名 即可修改相应用户的密码

[root@ha1 ~]# passwd jerry
Changing password for user jerry.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@ha1 ~]# echo "jerry" | passwd --stdin jerry
Changing password for user jerry.
passwd: all authentication tokens updated successfully.

3.删除用户

userdel 选项 用户名

userdel –r 用户名 删除用户及家目录

[root@ha1 ~]# userdel -r tcl
[root@ha1 ~]# ll /home
total 0
drwx------. 2 jerry users 83 Aug  9 18:45 h_jerry
drwx------. 2 test  test  83 Aug  9 18:45 test

4.修改用户

usermod 选项 用户名

选项参数   和useradd命令参数大致相同

-d  --home HOME_DIR     指定新的家目录

-a  --append                   将用户追加到附加组中而不移出其它组

-l   --login NEW_LOGIN    指定新的用户名

-L  --lock                        锁定用户

-m  --move-home            和-d选项结合使用,移动家目录中的内容到新的位置

举例说明:

将jerry用户改名为natasha,移动家目录的内容到/home/natasha,指定新的UID为1010,登录shell改为/bin/bash,并锁定用户

[root@ha1 ~]# usermod -l natasha -d /home/natasha -m -u 1010 -s /bin/bash jerry
[root@ha1 ~]# ll /home
total 0
drwx------. 2 natasha users 83 Aug  9 18:45 natasha
drwx------. 2 test    test  83 Aug  9 18:45 test
[root@ha1 ~]# id natasha
uid=1010(natasha) gid=100(users) groups=100(users)
[root@ha1 ~]# cat /etc/passwd |grep natasha
natasha:x:1010:100:first user:/home/natasha:/bin/bash

二.用户组管理

1.创建组

groupadd 选项 组名

选项

-f    --force     强制创建组即使组已存在,如果GID已存在将取消-g选项

-g   --gid GID 指定组GID号

举例说明:

创建一个名为natasha的组,并将用户natasha和test分别加入natasha和test组中

[root@ha1 ~]# groupadd -g 1010 natasha
[root@ha1 ~]# usermod -a -G test test
[root@ha1 ~]# cat /etc/group |grep -E "natasha|test"
test:x:1023:test
natasha:x:1010:test,natasha
[root@ha1 ~]# usermod -a -G test natasha
[root@ha1 ~]# cat /etc/group |grep -E "natasha|test"
test:x:1023:test,natasha
natasha:x:1010:test,natasha

2.删除组

groupdel 组名

3.修改组

groupmod 选项  组名

选项

-g  --gid GID      改变组的ID号

-n  --new-name  改变组名

用法和usermod类似

总结一下,创建组后会在/etc/group,/etc/gshadow文件中产生相应的组信息

/etc/group文件格式说明:分为4个字段,用冒号隔开

natasha:x:1010:test,natasha

第一字段:表示组名

第二字段:表示组密码,存放在/etc/gshadow文件中

第三字段:表示组ID号

第四字段:表示组成员,多个组成员用逗号隔开

/etc/gshadow文件格式说明:分为4个字段,用冒号隔开

natasha:!::test,natasha

第一字段:组名

第二字段:加密码后的密码

第三字段:组管理员(多个用,分隔)

第四字段:组成员(多个用,分隔)

三.文件,目录权限管理

在linux中设置文件权限非常重要,也是最基本的。linux文件的权限分为读(r-4)写(w-2)执行(x-1),和windows一样设置权限需要针对用户,用户所属的组,还有其它用户。只有设置了正确的权限,相应的用户才能根据权限执行相应的操作,很多时候我们配置WEB服务,FTP服务等都需要对相应的文件或文件夹赋与相应的权限才能正常跑起来,有时遇到问题通过查看错误日志会发现很多情况下是由于权限不当引起的。

文件权限分一般权限和特殊权限

一般权限主要指的是:文件所有者的权限,所属组的权限,其它用户权限

特殊权限主要指的是:权限中带s或S(SUID,SGID),t或T标志位

和文件权限有关的工具命令

ls –l    查看文件或目录的权限

umask   查看或设置权限遮罩(即实际权限=最大权限-遮罩值)

chmod   改变文件或目录的权限

chown   更改文件或目录的所有者

chgrp    更改文件或目录的所属组

getfacl   获取文件或目录权限访问控制列表

setfacl   设置文件或目录权限访问控制列表

先来看一下文件权限的查看方式,使用ll命令就可以查看长格式的文件权限等信息

[root@ha1 test]# ll
 -rw-r--r--. 1 root root 67 Mar 29 20:07 README.md
 drwxr-xr-x. 3 root root 36 Mar 29 20:15 shell
[root@ha1 test]# ll /bin/passwd 
-rwsr-xr-x. 1 root root 27832 Jun 10  2014 /bin/passwd

权限有3段组成,rwxrwxrwx代表最高权限,修改权限时也可以用777表示,-表示没有此项权限,本该出现x的位置出现s表示拥有SUID权限。

SUID对应4,SGID对应2,SBIT对应1

SUID只对二进制程序有效,执行者对于程序需要有X权限,在程序运行过程中,执行者(普通用户)将临时拥有程序所有者的权限

SGID对于文件来说只对二进制程序有效,普通用户将会临时拥有所属组的权限,对于目录来说,用户对此目录有RX权限可以进入目录,用户进入目录后,有效用户组会变成该目录的用户组,若用户在此目录有w权限,则用户创建的文件用户组与该目录用户组相同

umask说明

umask共4位:uid/gid,属主,组,其它权限。可以使用umask命令查看 默认是0022,不过一般用到的是后3位。

默认情况下,创建文件的权限是644(6-0,6-2,6-2),创建目录的权限是755(7-0,7-2,7-2)

[root@ha1 test]# touch a
[root@ha1 test]# umask
0022
[root@ha1 test]# mkdir b
[root@ha1 test]# ll
total 8
-rw-r--r--. 1 root root  0 Aug 10 19:01 a
drwxr-xr-x. 2 root root  6 Aug 10 19:05 b
-rwSr--r-T. 1 root root 65 Mar 29 21:02 index.html
-rw-r--r--. 1 root root 67 Mar 29 20:07 README.md
drwxr-xr-x. 3 root root 36 Mar 29 20:15 shell

修改文件权限 chmod

例:将 a 文件权限修改为:所有者有rwx,所属组:rx,其它用户:无权限

[root@ha1 test]# chmod u+x,g+x,o-r a
[root@ha1 test]# ll
total 8
-rwxr-x---. 1 root root  0 Aug 10 19:01 a

修改文件所有者或所有组 chown chgrp

例:将a文件所属组改为natasha,将b目录的所有者改为natasha

[root@ha1 test]# chgrp natasha a
[root@ha1 test]# chown -R natasha:root b
[root@ha1 test]# ll
total 8
-rwxr-x---. 1 root    natasha  0 Aug 10 19:01 a
drwxr-xr-x. 2 natasha root     6 Aug 10 19:05 b

设置更详细的权限 getfacl setfacl

例:查看a文件的详细权限信息

[root@ha1 test]# getfacl a
# file: a
# owner: root
# group: natasha
user::rwx
group::r-x
other::---

setfacl用法:

setfacl [-bkndRLPvh] [{-m|-x} acl_spec] [{-M|-X} acl_file] file ...

setfacl –-restore=file

参数:

-b,--remove-all:删除所有扩展的acl规则,基本的acl规则(所有者,群组,其他)将被保留。

-k,--remove-default:删除缺省的acl规则。如果没有缺省规则,将不提示。

-n,--no-mask:不要重新计算有效权限。setfacl默认会重新计算ACL mask,除非mask被明确的制定。 --mask:重新计算有效权限,即使ACL mask被明确指定。

-d,--default:设定默认的acl规则。

--restore=file:从文件恢复备份的acl规则(这些文件可由getfacl -R产生)。通过这种机制可以恢复整个目录树的acl规则。此参数不能和除--test以外的任何参数一同执行。

--test:测试模式,不会改变任何文件的acl规则,操作后的acl规格将被列出。

-R,--recursive:递归的对所有文件及目录进行操作。

-L,--logical:跟踪符号链接,默认情况下只跟踪符号链接文件,跳过符号链接目录。

-P,--physical:跳过所有符号链接,包括符号链接文件。

--version:输出setfacl的版本号并退出。

--help:输出帮助信息。

--:标识命令行参数结束,其后的所有参数都将被认为是文件名 -:如果文件名是-,则setfacl将从标准输入读取文件名。

例:将a文件权限设置为,test1用户拥有rw权限,test2用户拥有x权限,其它用户拥有rx权限

[root@ha1 test]# setfacl -m u:test1:rw,u:test2:x,o::rx a
[root@ha1 test]# getfacl a
# file: a
# owner: root
# group: natasha
user::rwx
user:test1:rw-
user:test2:--x
group::r-x
mask::rwx
other::r-x