查看文件的权限以及文件所属的用户和组
使用ls -l
或者 ll
命令
dr-xr-xr-x 4 root root 4096 Apr 19 2012 boot
文件权限说明
dr-xr-xr-x
进行如下拆分:
文件类型 | 属主权限 user | 属组权限 group | 其他用户权限 others |
---|---|---|---|
d | r-x | r-x | r-x |
第一个字符代表文件是目录,文件或者链接文件:
- 当为[ d ]则是目录
- 当为[ - ]则是文件
- 当是[ l ]则表示为链接文档(link file)
- 当是[ b ]则表示为装置文件里面的可供储存的接口设备(可随机存取装置)
- 当是[ c ]则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)
接下来的字符中,以三个为一组,且均为『rwx』 的三个参数的组合。其中,[ r ]代表可读(read)、[ w ]代表可写(write)、[ x ]代表可执行(execute)。要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号[ - ]而已。
文件属主和属组
drwxr-xr-x 2 root root 4096 Feb 15 14:46 cron
drwxr-xr-x 3 mysql mysql 4096 Apr 21 2014 mysql
对于文件来说,它都有一个文件所有者,也就是对该文件具有所有权的用户。同时,在Linux系统中,用户是按组分类的,一个用户属于一个或多个组。文件所有者以外的用户又可以分为文件所有者的同组用户和其他用户。
因此,Linux系统按文件所有者、文件所有者同组用户和其他用户来规定了不同的文件访问权限。
在以上实例中,mysql 文件是一个目录文件,属主和属组都为 mysql,属主有可读、可写、可执行的权限;与属主同组的其他用户有可读和可执行的权限;其他用户也有可读和可执行的权限。
对于 root 用户来说,一般情况下,文件的权限对其不起作用。
更改文件属性
1、 chgrp:更改文件属组
chgrp [-R] 属组名 文件名
2、chown:更改文件属主,也可以同时更改文件属组
chown [–R] 属主名 文件名
chown [-R] 属主名:属组名 文件名
3、chmod:更改文件9个属性
Linux文件属性有两种设置方法,一种是数字,一种是符号。
Linux文件的基本权限就有九个字符,分别是user /group/others三种身份,各有自己的r(4)w(2)x(1)权限。
# 数字更改权限
chmod [-R] 777 文件或目录
# 字符更改权限
chmod [-R] u=rwx,g=rx,o=r 文件或目录
chmod [-R] a=rwx 文件或目录
#去掉权限
chmod [-R] a-x 文件或目录