HJT的博客

记录精彩的程序人生

目录
Linux系统文件基本属性与操作
/  

Linux系统文件基本属性与操作

文件基本属性

image.png

更改文件属性

chgrp:更改文件属组语法:

chgrp [-R]  属组名  文件名

参数选项

  • -R:递归更改文件属组,就是在更改某个目录文件的属组时,如果加上-R的参数,那么该目录下的所有文件的属组都会更改。

chown:更改文件属主,也可以同时更改文件属组

语法:

chown [–R]  属主名  文件名 
chown [-R]  属主名:属组名  文件名

chmod:更改文件9个属性

Linux文件属性有两种设置方法,一种是数字,一种是符号。

Linux文件的基本权限就有九个,分别是owner/group/others三种身份各有自己的read/write/execute权限。

先复习一下刚刚上面提到的数据:文件的权限字符为:
『-rwxrwxrwx』, 这九个权限是三个三个一组的!
其中,我们可以使用数字来代表各个权限,各权限的分数对照表如下:

  • r:4
  • w:2
  • x:1

每种身份(owner/group/others)各自的三个权限(r/w/x)分数是需要累加的,例如当权限为: [-rwxrwx---] 分数则是:

  • owner = rwx = 4+2+1 = 7
  • group = rwx = 4+2+1 = 7
  • others= --- = 0+0+0 = 0

所以等一下我们设定权限的变更时,该文件的权限数字就是770啦!变更权限的指令chmod的语法是这样的:

 chmod [-R] xyz 文件或目录

选项与参数:

  • xyz : 就是刚刚提到的数字类型的权限属性,为 rwx 属性数值的相加。
  • -R : 进行递归(recursive)的持续变更,亦即连同次目录下的所有文件都会变更

符号类型改变文件权限

还有一个改变权限的方法,从之前的介绍中我们可以发现,基本上就九个权限分别是:

  • (1)user
  • (2)group
  • (3)others

那么我们就可以使用 u, g, o 来代表三种身份的权限!

此外, a 则代表 all,即全部的身份。读写的权限可以写成 r, w, x,也就是可以使用下表的方式来看:

chmodu+(加入)r文件或目录
g-(除去)w
o=(设定)x
a

如果我们需要将文件权限设置为 -rwxr-xr-- ,可以使用 chmod u=rwx,g=rx,o=r文件名 来设定:

# touch test1    // 创建 test1 文件  
# ls -al test1    // 查看 test1 默认权限  
-rw-r--r--  1 root root 0  Nov  15  10:32 test1 
# chmod u=rwx,g=rx,o=r  test1    // 修改 test1 权限  
# ls -al test1  -rwxr-xr--  1 root root 0  Nov  15  10:32 test1

而如果是要将权限去掉而不改变其他已存在的权限呢?例如要拿掉全部人的可执行权限,则:

# chmod  a-x test1  
# ls -al test1  
-rw-r--r--  1 root root 0  Nov  15  10:32 test1

参考


标题:Linux系统文件基本属性与操作
作者:HJTGit
地址:https://blog.huojt.top/articles/2019/08/27/1566889129316.html

评论