Linux文件和目录权限

在Linux中的每一个文件或目录都包含有访问权限,这些访问权限决定了谁能访问和如何访问这些文件和目录。

通过设定权限可以从以下三种访问方式限制访问权限:只允许用户自己访问;允许一个预先指定的用户组中的用户访问;允许系统中的任何用户访问。

Linux中一切皆文件,关于文件的权限所有者分为用户,用户组,其他三类,权限的类别分为r(可读)、w(可写)、x(可执行)三种,其分别对应的权限数值为4、2、1

修改权限的命令为chmod,修改所属者的命令为chown

模拟环境:

创建用户组abc

创建用户a并指定用户组abc

创建用户b并指定用户组abc

创建其他用户test,不指定用户组

查看创建的用户

[root@localhost ~]# groupadd abc

[root@localhost ~]# useradd -g abc a

[root@localhost ~]# useradd -g abc b

[root@localhost ~]# useradd test

[root@localhost ~]# tail -3 /etc/passwd

a:x:500:500::/home/a:/bin/bash

b:x:501:500::/home/b:/bin/bash

test:x:502:502::/home/test:/bin/bash

 

  1. 文件的权限

1.1使用root用户创建文件,并修改文件的属主和属组

[root@localhost ~]# mkdir /data

[root@localhost ~]# touch /data/ceshi.txt

[root@localhost ~]# chown a.abc /data/ceshi.txt

[root@localhost ~]# ll /data/ceshi.txt

-rw-r--r-- 1 a abc 0 Apr 9 21:02 /data/ceshi.txt

1.2可以发现文件默认的权限位为644,分别修改权限位为754、731,文件变为可执行(颜色变绿)

[root@localhost ~]# mkdir /data

[root@localhost ~]# touch /data/ceshi.txt

[root@localhost ~]# chown a.abc /data/ceshi.txt

[root@localhost ~]# ll /data/ceshi.txt

-rw-r--r-- 1 a abc 0 Apr 9 21:02 /data/ceshi.txt

1.3小结:

对于普通用户来说,文件具有执行权限的前提是需要具有读的权限

root用户拥有绝对的权限

root用户对所有文件都有读写的权限    

UGO中任何一个有执行权限就等于root用户有执行权限

 

  1. 目录的权限

2.1使用root用户创建目录,并修改文件的属主和属组

[root@localhost ~]# mkdir /data/ceshi

[root@localhost ~]# chown a.abc /data/ceshi

[root@localhost ~]# touch /data/ceshi/{1..5}

[root@localhost ~]# ls -ld /data/ceshi

drwxr-xr-x 2 a abc 4096 Apr 9 21:11 /data/ceshi

2.2分别切换到不同用户下执行ls命令(检验读权限)、mkdir命令(检验写权限)、cd命令(检验执行权限)

[root@localhost ~]# su - a

[a@localhost ~]$ ls /data/ceshi

1 2 3 4 5

[a@localhost ~]$ mkdir -p /data/ceshi/6

[a@localhost ~]$ cd /data/ceshi

[a@localhost ceshi]$ cd

[a@localhost ~]$ su

Password:

[root@localhost a]# su - b

[b@localhost ~]$ ls /d

ls: cannot access /d: No such file or directory

[b@localhost ~]$ ls /data/ceshi

1 2 3 4 5 6

[b@localhost ~]$ mkdir -p /data/ceshi/7

mkdir: cannot create directory `/data/ceshi/7': Permission denied

[b@localhost ~]$ cd /data/ceshi

[b@localhost ceshi]$ cd

[b@localhost ~]$ su

Password:

[root@localhost b]# su - test

[test@localhost ~]$ ls /data/ceshi

1 2 3 4 5 6

[test@localhost ~]$ mkdir -p /data/ceshi/7

mkdir: cannot create directory `/data/ceshi/7': Permission denied

[test@localhost ~]$ cd /data/ceshi

[test@localhost ceshi]$ cd

[test@localhost ~]$ su

Password:

[root@localhost test]# cd

[root@localhost ~]#

2.3可以发现

a        用户具有读写执行权限

b        用户具有读和执行权限,没有写权限

test        用户具有读和执行权限,没有写权限

2.4修改权限位为731,执行同样的命令检验结果,此时

drwx-wx--x 3 a abc 4096 Apr 9 21:11

a            用户具有写执行权限,没有读权限

b            用户具有执行和写权限,没有读权限

test            用户具有执行权限,没有读和写权限

2.5修改权限位为754,执行同样的命令检验结果,此时

drwxr-xr-- 3 a abc 4096 Apr 9 21:11

a            用户具有写执行权限,没有读权限

b            用户具有读和执行权限,没有写权限

test            用户具有读权限,没有写和执行权限

2.6小结:

对于普通用户来说,目录的读权限(ls)需要具有执行权限

 

  1. 文件和目录的关系

目录也是一种文件,目录的block里面存放的就是目录下的文件名和目录名

block的默认大小为4096字节=4k

 

  1. 读取文件内容的原理

读取/data/ceshi.txt,会先找到根目录/的inode,通过inode找到根目录的block,在根目录的block中,找到/data目录,通过目录名找到/data目录的inode号,根据inode号,找到/data目录的block,读取/data目录的block,找到文件名为/data/ceshi.txt的文件,找到/data/ceshi.txt的inode号之后,最后再读取/data/ceshi.txt的block,将结果输出到屏幕上。

  1. 权限的掩码

5.1查看系统掩码配置文件cat /etc/bashrc|sed -n '65,69p'

相关内容如下

if [ $UID -gt 199 ] && [ "`/usr/bin/id -gn`" = "`/usr/bin/id -un`" ]; then

umask 002

else

umask 022

fi

umask 通过控制权限掩码就可以控制默认权限

umask 查看权限掩码

umask 0002 修改权限掩码

5.2基于文件的权限掩码

umask默认为0022

    0666

-     0022

=    0644

当把umask设置为奇数的时候,系统会自动把算出的奇数位数值加一

5.3基于目录的权限掩码

umask默认为0022

    0777

-     0022

=    0755

当把umask设置为奇数的时候,与文件不同的是,系统不会自动加一

 

博主原创文章,转载请务必注明出处

Linux学习之十四-Linux文件和目录权限的更多相关文章

  1. Linux学习之十四、管线命令

    Linux学习之十四.管线命令 地址:http://vbird.dic.ksu.edu.tw/linux_basic/0320bash_6.php

  2. linux 学习3 第四讲 文件常用命令

    好几天没有在网上总结了.我把ppt先誊写在本子上,这样听的时候记录就方便很多,添些东西就可以. 我想先看shell那部分,但是没有之前几章的准备,是没法跟着视频动手操作的.所以还是按部就班得学习. 虽 ...

  3. Linux学习(十四)磁盘格式化、磁盘挂载、手动增加swap空间

    一.磁盘格式化 分好去的磁盘需要格式化之后才可以使用.磁盘分区一般用mke2fs命令或者mkfs.filesystemtype.这个filesystemtype分为ext4,ext3,xfs等等.xf ...

  4. Linux学习之CentOS(四)----Linux文件属性、所有者、群组、其他组及文件权限操作简要总结

    Linux文件属性.所有者.群组.其他组及文件权限操作简要总结 首先介绍一个重要的知识点:文件属性控制权限 [root@www ~]# ls -al total 156 drwxr-x--- 4 ro ...

  5. Linux命令(十四) 查看工作目录文件 ls

    目录 1.命令简介 2.常用参数介绍 3.实例 4.直达底部 命令简介 ls 命令是 Linux 下最常用的命令. ls 就是 list 的缩写.默认情况下 ls 命令用来打印出当前目录的清单, 如果 ...

  6. Linux学习之十五-Linux文件特殊权限和附加权限

    Linux文件特殊权限和附加权限 1.特殊权限suid 范围:只能针对二进制命令文件 作用:让普通用户拥有二进制命令文件所有者的权限 举例1:普通用户使用passwd命令修改密码 cat /etc/s ...

  7. Linux学习之十六、文件的格式化与相关处理

    原文地址:http://vbird.dic.ksu.edu.tw/linux_basic/0330regularex_4.php 文件的格式化与相关处理 接下来让我们来将文件进行一些简单的编排吧!底下 ...

  8. linux学习(十)linux安装MySQL

    一.前言 由于我使用的是阿里云的服务器,后面会加入配置阿里云的部分,非阿里云的linux系统可以省略后面的步骤,根据自己系统的情况进行配置~ PS:我安装的是mysql5.7.24的版本,其他版本的M ...

  9. [Linux] Linux学习笔记(5)-文件与目录管理

    1.Linux目录结构为树状结构,最顶层的目录为跟目录"/",其它目录通过挂载可以将它添加到目录树中,通过解除挂载移除它们. 2.绝对路径与相对路径 绝对路径写法:由根目录&quo ...

随机推荐

  1. linux/mac下的配置自定义命令alias

    linux/mac下的自定义命令alias,并保存别名使其永久生效(重启不会失效) 在做开发每次提交代码的命令都是一长串参数,不想去记,于是可以使用alias命令来解决这个问题:alias aComm ...

  2. pythonic编程示例及简析

    1.列表 list[起始:结尾:增量] 值传递与地址传递 a = [2,1] b = a #地址传递 b = a[:] 值传递 a.sort() print a #[1,2] print b #[1, ...

  3. Python-伪私有属性

    原文:http://blog.itpub.net/26250550/viewspace-1411768/ 通常在 Python 中,我们都被告知可以使用双下划线开头的方法名定义方法来达到私有函数的目标 ...

  4. 冒泡排序(Bubble Sort)及优化

    原理介绍 冒泡排序算法的原理如下: 比较相邻的元素.如果第一个比第二个大,就交换他们两个. 对每一对相邻元素做同样的工作,从开始第一对到结尾的最后一对.在这一点,最后的元素应该会是最大的数. 针对所有 ...

  5. oracle中用rownum分页并排序的查询SQL语句

    oracle的sql语句中没有limit,limit是mysql中特有的,在oracle中可用rownum来表示,用于查询结果中的前N行数据. 如要查询emp表中的前5行数据,可用如下语句: sele ...

  6. BZOJ2657 [Zjoi2012]旅游(journey) 【树的直径】

    题目 到了难得的暑假,为了庆祝小白在数学考试中取得的优异成绩,小蓝决定带小白出去旅游~~ 经过一番抉择,两人决定将T国作为他们的目的地.T国的国土可以用一个凸N边形来表示,N个顶点表示N个入境/出境口 ...

  7. xtrabackup安装使用说明

    软件介绍: Percona XtraBackup是一块开源且免费的对MySQL Innodb存储引擎备份数据的工具,使用此工具的时候不需停止MySQL,而且支持压缩备份,支持对Innodb存储引擎做增 ...

  8. Javascript&Html-延迟调用和间歇调用

    Javascript&Html-延迟调用和间歇调用 Javascript 是一种单线程语言,所有的javascript任务都会放到一个任务列表中,这些javascript任务会按照插入到列表中 ...

  9. ToolTip特效 JavaScript 盗取厦门人才网的特效

    原文发布时间为:2009-05-17 -- 来源于本人的百度文章 [由搬家工具导入] 源代码:http://www.xmaspx.com/Services/FileAttachment.ashx?At ...

  10. linux 共享内存 信号量 同步

    这篇文章将讲述别一种进程间通信的机制——信号量.注意请不要把它与之前所说的信号混淆起来,信号与信号量是不同的两种事物.有关信号的更多内容,可以阅读我的另一篇文章:Linux进程间通信——使用信号.下面 ...