linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。
为了保护系统的安全性,linux系统对不同的用户访问同一个文件(包括目录文件)的权限做了不同的规定。
在linux中我们通常使用以下2个命令来修改文件或目录的所属用户与权限:
在linux中我们可以使用 ll 或者 ls-l命令来显示一个文件的属性以及文件所属的用户和组。
在linux中第一个字符代表这个文件是目录、文件、或者链接文件等等
接下来的字符中,以三个为一组,且均为 rwx 的三个参数的组合。其中,r代表可读(read)、w代表可写(write)、x代表可执行(execute)。要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号-而已。
上述说了,第一个字符代表类型,后面跟的9个字符,分别是三组权限设置(每组权限是读、写、执行),第一组是用户权限,第二组是用户所在的组的权限,第三组是其他人的权限,例如
drwxr-xr-x 2 root root 4096 Sep 7 20:38 aa
drwxr-xr-x 2 root root 4096 Sep 7 20:30 test
-rw-r--r-- 1 root root 31 Sep 7 19:16 test.py
后面两个root,第一个root代表用户,第二个root代表用户所在的组。加起来也就是root用户的root组。
每个文件的属性由左边第一部分的10个字符来确定(如下图)
从左至右用0-9这些数字来表示
第0位确定文件类型,第1-3位确定属主(该文件的所有者)拥有该文件的权限。
第4-6位确定属组(所有者的同组用户)拥有该文件的权限,第7-9位确定其他用户拥有该文件的权限。
其中,第1、4、7位表示读权限,如果用r字符表示,则有读权限,如果用 - 字符表示,则没有读权限;
第2、5、8位表示写权限,如果w字符表示,则有写权限,如果用 - 字符表示没有写权限;
第3、6、9位表示可执行权限,如果用x字符表示,则有执行权限,如果用 - 字符表示,则没有执行权限。
TODO:修改的是属主文件的权限,一般情况下是改自己的文件的权限。
上文提到文件的权限字符为:rwxrwxrwx,这9个权限是三个三个一组的!其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下
每种身份(owner/group/others) 各自的三个权限(r/w/x)分数是需要累加的,
例如当权限为:rwxrwx--- 分数则是:
所以等一下我们设定权限的变更时,该文件的权限数字就是770.变更权限的指令 chmode的语法是这样子的:
- chmode [-R] xyz 文件或目录
-
- # 选项与参数:
- # xyz:就是刚刚提到的数字类型的权限属性,为rwx属性数值的相加。
- # -R:进行递归(recursive)的持续变更,亦即连同次目录下的所有文件都会变更
-
-
我们来举个栗子~
我们来举个栗子:
chmod u=r test.sh 给test.sh文件的user设置一个读的权限
chmode u+x test.sh 给test.sh文件的user多添加一个执行的权限