chmod命令
Linux/Unix 的文件调用权限分为三级 : 文件拥有者、群组、其他。利用 chmod 可以控制文件如何被他人所调用。
用于改变 linux 系统文件或目录的访问权限。用它控制文件或目录的访问权限。该命令有两种用法。一种是包含字母和操作符表达式的文字设定法;另一种是包含数字的数字设定法。
每一文件或目录的访问权限都有三组,每组用三位表示,分别为文件属主的读、写和执行权限;与属主同组的用户的读、写和执行权限;系统中其他用户的读、写和执行权限。
可使用 ls -l test.txt 查找。
以文件 log2012.log 为例:
1 -rw-r--r-- 1 root root 296K 11-13 06:03 log2012.log
第一列共有 10 个位置,第一个字符指定了文件类型。在通常意义上,一个目录也是一个文件。如果第一个字符是横线,表示是一个非目录的文件。如果是 d,表示是一个目录。
从第二个字符开始到第十个 9 个字符,3 个字符一组,分别表示了 3 组用户对文件或者目录的权限。权限字符用横线代表空许可,r 代表只读,w 代表写,x 代表可执行。
常用参数:
1 -c 当发生改变时,报告处理信息
2 -R 处理指定目录以及其子目录下所有文件
权限范围:
1 u :目录或者文件的当前的用户
2 g :目录或者文件的当前的群组
3 o :除了目录或者文件的当前用户或群组之外的用户或者群组
4 a :所有的用户及群组
权限代号:
1 r :读权限,用数字4表示
2 w :写权限,用数字2表示
3 x :执行权限,用数字1表示
4 - :删除权限,用数字0表示
5 s :特殊权限
实例:
(1) 增加文件 t.log 所有用户可执行权限
1 chmod a+x t.log
(2) 撤销原来所有的权限,然后使拥有者具有可读权限,并输出处理信息
1 chmod u=r t.log -c
(3) 给 file 的属主分配读、写、执行(7)的权限,给file的所在组分配读、执行
(5)的权限,给其他用户分配执行(1)的权限
1 chmod 751 t.log -c(或者:chmod u=rwx,g=rx,o=x t.log -c)
(4) 将 test 目录及其子目录所有文件添加可读权限
1 chmod u+r,g+r,o+r -R text/ -c