Linux 上有三种特殊权限,分别是 set uid,set gid,sticky。对应权限的数值分别为4,2,1。对应权限的字母分别为 s,s,t。对应的操作分别为 chmod u+s file,chmod g+s dir,chmod o+t dir,对应的操作也支持将字母替换为数字
set uid:一般作用于二进制文件,二进制文件在设置了该权限后,用户在执行该文件时会临时获得 root 的权限
以 netstat 命令的 “-p” 参数为例,netstat 命令在设置了 set uid 权限后 sysop 用户也可以使用 “-p” 参数
set gid:作用于目录文件,如果一个目录被设置了 set gid 的权限,那么任何用户在这个目录下创建的文件,都会属于该目录的所属组
sticky:作用于目录文件,sticky 特殊权限设置的目的是为了降低目录的权限。如果一个普通用户对一个目录具备了 rwx 权限,那么任何用户在该目录下的文件,都可以被该用户删除,包括 root 的文件(/tmp 目录的默认权限就包含 sticky)
ACL(Access Control List,访问控制列表)在 Linux 系统内用来控制文件权限,提升系统安全和可靠性
ACL 权限可通过 setfacl 和 getfacl 命令设置和查看(红帽系列基本都自带这两个命令,Debian 系列安装 acl 软件包即可)
sudo 权限委派
由于 Linux 系统大部分都是使用 normal user 进行 ssh 远程 login,所以熟练的使用 sudo 以及配置一个用户的提权就非常重要。
主配置文件:/etc/sudoers
子配置文件:/etc/sudoers.d/*
# 大部分情况我们都不会修改主配置文件,会在 /etc/sudoers.d/ 目录下创建一个以“需要提权的用户”命名的文件,如下所示
# “NOPASSWD” 表示普通用户在执行 root 用户命令操作时不需要输入 sudo 密码
root@debian:~# cat /etc/sudoers.d/sysop
sysop ALL=(ALL) NOPASSWD:ALL
Debian 或 Ubuntu 系统在创建普通用户时,默认不创建普通用户的家目录(即使使用“-d”参数指定也不行)并且创建普通用户默认的 shell 是 sh
可通过两种办法解决,一种是通过命令参数,一种是修改配置文件
标签:文件,set,ACL,Linux,普通用户,权限,目录 From: https://www.cnblogs.com/demoduan/p/17534945.html