linux 文件基本属性

本文介绍了Linux系统中的文件权限管理命令,包括chown用于改变文件所属用户与组,chmod用于修改权限,以及如何通过数字和符号设置权限。实例演示了如何更改install.log文件的所有权和权限,以及chmod命令的用法和权限分数对应关系。
摘要由CSDN通过智能技术生成

三、文件相关指令

        chown (change owner):修改所属用户与组;

        chmod (change mode):修改用户的权限;

        ll或者ls命令来显示一个文件的属性以及文件所属的用户和组;

      更改文件属性

        1、chgrp:更改文件属性       

        chgrp [ -R ] 属性名 文件名

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

        2、chowm:更改文件属主,也可以同时更改文件属性

        语法:

        chown [–R] 属主名 文件名

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

        进入/root 目录(~) 将install.log的拥有者改为bin这个账号:

        [root@www ~] cd ~

        [root@www ~]# chown bin install.log

        [root@www ~]# ls -l

        -rw-r--r-- 1 bin users 68495 Jun 25 08:53 install.log

        将install.log的拥有者与群组改为root

        [root@www ~]# chown root:root install.log

        [root@www ~]# ls -l       

        -rw-r--r-- 1 root root 68495 Jun 25 08:53 install.log

        3、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)的持续变更,以及连同次目录下的所有文件都会变更

        举例来说,如果要将 .bashrc 这个文件所有的权限都设定启用,那么命令如下:

        [root@www ~]# ls -al .bashrc

        -rw-r--r-- 1 root root 395 Jul 4 11:45 .bashrc

        [root@www ~]# chmod 777 .bashrc

        [root@www ~]# ls -al .bashrc

        -rwxrwxrwx 1 root root 395 Jul 4 11:45 .bashrc

        那如果要将权限变成 -rwxr-xr-- 呢?那么权限的分数就成为 [4+2+1][4+0+1][4+0+0]=754。

      符号类型改变文件权限

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

  • user:用户
  • group:组
  • 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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值