资源,用户和用户组的相关概念:
资源:计算机的计算能力,内存空间等等都可以统称为计算机的资源。
用户:用来标识是否有使用计算机资源的权限
用户组:相当于容器的概念,方便分配权限。
权限:
r w x
文件的权限分为三部分:属主的权限,属组的权限,其他人的权限。
当用户访问某个文件的时候,系统会先对比用户是否是属主,不是的话会对比用户是否在文件的属组里面,不是的话则使用其他人的权限。
普通文件:
r:可读、可以使用cat等命令查看文件内容
w:可写、可以使用命令修改文件里面的内容,也可以删除文件
x:可执行、exacutable、可以在命令提示符下当做命令提交给内核运行
目录:
r:可以显示目录里面的文件
w:可以在目录里面创建文件
x:可以使用cd切换进此目录,也可以使用ls -l查看内部文件的详细信息。
0 --- 无权限
1 --x 可执行
2 -w- 可写
3 -wx 可写、可执行
4 r-- 可读
5 r-x 可读、可执行
6 rw- 可读写
7 rwx 可读写执行
用户:UID, /etc/passwd
用户组:GID,/etc/group
影子口令:
用户:/etc/shadow
组:/etc/gshadow
用户类别:
管理员用户:0
普通用户:1-65535
系统用户:1-499
一般用户:500-63535
用户组类别:
管理组:root
普通组:
系统组:
一般组:
用户组类别的另一种分法:(这种比较常用)
基本组:用户的默认组
私有组:系统创建用户时,如果用户没有指定默认组,此时会创建一个与用户同名的私有组
附加组:用户可以同时拥有多个组,除了基本组之外的组就叫附加组。
示例:
假设一个用户tom,它的属组也是tom,当它使用命令ls 显示/tmp 这个目录,系统的权限对比过程。
首先系统会查看ls这个命令的权限属性: -rwxr-xr-x root root /bin/ls ,然后用对比tom不是root,所以不是属主,然后对比tom是否在用户组root里面(注意:这里并不是对比tom组是否和root组相同,而是对比tom用户是否在root组里面),发现不是,于是查找其他人权限r-x,可读可执行,于是拥有ls的使用权限。 接着显示/tmp的时候,并不是对比/tmp和ls的权限,而是仍然对比tom和/tmp的权限,也就是说当tom取得ls的使用权的时候,它的权限并不会因为ls是root属主而切换。/tmp/的权限为:drwxrwxrwt root root,逐个对比后拥有其他人权限,权限中包含r,给予显示:
[root@logstach ~]# ls -al /bin/ls
-rwxr-xr-x 1 root root 112664 Oct 15 2014 /bin/ls
[root@logstach ~]# ls /tmp
14ahhs1 25 534 71233bbc a a b kkll568 sadsa*787sdd
[root@logstach ~]# ls -d /tmp
/tmp
[root@logstach ~]# ls -dl /tmp
drwxrwxrwt. 3 root root 4096 Dec 25 14:45 /tmp
passwd配置文件格式:
account:登录名
passwd:mima
UID:用户id
GID:组id
comment:注释信息
home dir:家目录
shell:默认shell
/etc/shadow配置文件格式:
account:登录名
encrypted password:加密后的密码
date of last password change:最近一次更改密码的时间
minimum password age:最小密码使用期限
maximum password age:最大密码使用期限
password warning period:密码过期前警告时间
password inactivity period:密码过期后仍能使用时间
account expiration date:用户过期时间
reserved field:保留区域
加密算法:
对称加密:加密和解密都是统一密码
公钥加密:加密和解密成对出现,公钥加密,私钥解密
单向加密:散列加密,提取数据特征码,用于校验数据的完整性
雪崩效应:一个字符不同,生成的密码大部分字符不一样
定长输出:
md5:Message Digest 128位定长输出
sha1:Secure Hash Algorithm 160位
单向加密的一个例子:
linux中保存用户的密码的文件叫shadow,如果我们cat /etc/shadow 我们会发现密文中的前几位格式都类似这样:$8位密文$定长密文
这么做的原因就是linux使用单向加密对用户的密码进行加密,当用户登录时,系统把用户输入的密码用加密算法进行加密,然后和/etc/shadow文件里面的密码片段进行对比,从而判断密码是否正确。 但是由于shadow文件对一些用户是可读的,相同的密码加密后的密文是一样的,也就是说,如果碰巧shadow有人的密码片段跟你的一样,那么就可以推断出其密码,这是不符合linux的安全标准的,于是系统在加密密码时随机加入了一些字符,这些字符就是所谓的‘salt’,因为单向加密的雪崩效应,所以即使你们的密码一模一样,只要salt中有一个字符不一样,那么保存在shadow里面的密文也是大部分不一样。根据算法,$$里面那8位就是用来参与加密的‘salt’字符。
用户管理相关命令:
useradd:
useradd [option] USERNAME
-u UID
-g GID(基本组)
-G GID,...(附加组)
-c “COMMENT”
-d /path/to/homedir
-s shell
-m -k -m代表创建家目录,-k代表把/etc/skel目录下的文件(.bashrc..)拷贝到家目录
-M 不创建家目录
/etc/login.defs:对用户管理命令指定一些默认值,比如是否useradd时默认是否创建家目录等
注意:用户在指定组之前,被指定的组必须存在,否则命令执行失败,当命令执行失败用户也不会生成
/etc/shells:指定了当前系统可用的安全shell
userdel:
userdel [option] USERNAME
-r:同时删除用户的家目录
id:查看用户的账号属性信息
-u UID
-g
-G
-n
finger:查看用户账号信息
finger USERNAME
usermod:
-u uid
-g gid
-a -G GID:不使用-a选项会覆盖此前的附加组
-c
-d -m:-d代表指定新的家目录,-m表示把原来家目录里面的东西拷贝到新的家目录(这是因为指定新的家目录后,用户对原来的家目录下的文件失去了权限)
-l:改变用户的登录名
-L:锁定账号
-U:解锁账号
chsh:修改用户的默认shell
chfn:修改注释信息
密码管理
passwd [USERNAME]
--stdin:从标准输入中读取密码
-l:锁定账号
-u:解锁账号
-d:删除用户密码
示例:
[root@logstach html]# echo '123456'|passwd root --stdin
Changing password for user root.
passwd: all authentication tokens updated successfully.
pwck:检查用户账号完整性
组管理:
创建组:groupadd
groupadd
-g GID
-r:添加为系统组
groupmod
-g GID
-n GROUPNAME
groupdel GROUPNAME
gpasswd:为组设定密码
newgrp GRPNAME <--> exit
注意:newgrp命令是临时切换基本组,可以使用exit退出,当newgrp切换到任何自己的附加组是不需要密码的,当切换到一个新组的时候,如果新组没有设定密码则无法加入,此时用root身份使用gpasswd给用户创建组密码后,用户就可以使用newgrp GRPNEME 输入密码后切换
示例:
[root@logstach linzb]# su linzb
[linzb@logstach ~]$ touch a
[linzb@logstach ~]$ ls -l a
-rw-rw-r-- 1 linzb linzb 0 Dec 25 16:50 a
[linzb@logstach ~]$ newgrp root
Password:
Invalid password.
[linzb@logstach ~]$ exit
exit
[root@logstach linzb]# gpasswd root
Changing the password for group root
New Password:
Re-enter new password:
[root@logstach linzb]# su linzb
[linzb@logstach ~]$ newgrp root
Password:
[linzb@logstach ~]$ touch b
[linzb@logstach ~]$ ls -alh b
-rw-r--r-- 1 linzb root 0 Dec 25 16:51 b