先来熟悉下权限,以上一个例子comm下的文档为例
$ls -l-rw-rw-r-- 1 yjplxq yjplxq 36 7月 30 22:40 A.txt
-rw-rw-r-- 1 yjplxq yjplxq 27 7月 30 22:41 B.txt
-rw-rw-r-- 1 yjplxq yjplxq 1231 7月 30 22:45 comm.txt
-rwxrwxr-x 1 yjplxq yjplxq 0 7月 31 11:22 comm.sh
drw-rw-r-- 1 yjplxq yjplxq 1231 7月 30 22:45 subcomm
第一列讲解:
"-" 指普通文件 "d" 指目录 "c" 指字符设备 "b" 块设备 "l" 字符连接 "s" 套接字 "p" 管道 |
权限简述:
r 指read 读权限
w 指write 写权限
x 指execute 执行
S 只用于替换“x”权限位 setuid or setgid
T 只用于替换“x”权限位 粘滞位 目录设置了粘滞位,只有创建该目录的用户才能删除目录文件
下面一起熟悉下chmod
chmod 用来改变你的操作权限,全称:change modle. 非常好记。
熟悉下--help:
用法:chmod [选项]... 模式[,模式]... 文件...
或:chmod [选项]... 八进制模式 文件...
或:chmod [选项]... --reference=参考文件 文件...
将每个文件的模式更改为指定值。
-c, --changes 类似 --verbose,但只在有更改时才显示结果
--no-preserve-root 不特殊对待根目录(默认)
--preserve-root 禁止对根目录进行递归操作
-f, --silent, --quiet 去除大部份的错误信息
-v, --verbose 为处理的所有文件显示诊断信息
--reference=参考文件 使用指定参考文件的模式,而非自行指定权限模式
-R, --recursive 以递归方式更改所有的文件及子目录
--help 显示此帮助信息并退出
--version 显示版本信息并退出
每种 MODE 都应属于这类形式"[ugoa]*([-+=]([rwxXst]*|[ugo]))+"。
解读:
1. 八进制模式文件
听着名词有点大,其实很简单。
r=4 w=2 x=1 所以如果你看到这个表达式:
rwxrw-r-- 实际上可表示为764
那么你可以这样 chmod 764 ${filename} 此时filename用户有了读写执行权限,而用户组有了读写权限,其他用户只有读的权限。
2. --reference=参考文件
你可以设置一个文件的权限作为模板,然后
chmod --reference=${参考文件} ${被修改文件}
3. 每种mode都应该属于"[ugoa]*([-+=]([rwxXst]*|[ugo]))+"。
举例:
3.1.chmod o=u filename #filename其他用户有和用户同样的权限
3.2.a指的是all chmod a+x filename #filaname所有用户增加执行权限
实战技巧:
1. 递归修改当前目录下所有权限
$chmod 777 . –R
2. 制定权限模板 如u7.tl为 用户读写执行权限模板
$chmod --reference=参考文件 的方式
3. 设置粘滞位
$chmod a+t directory_name
chmod算是必须掌握,经常用到,次数不算频繁的一个操作(感觉矛盾是吧),呵呵。
相关命令:chown, w, who