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. 精通CSS高级Web标准解决方案(7、布局)

    7.1 让设计居中 7.1.1 使用自动空白边让设计居中 <body> <div id="wrapper"> </div> </body& ...

  2. sqlserver 操作access数据库

    exec sp_configure 'show advanced options',1  reconfigure  exec sp_configure 'Ad Hoc Distributed Quer ...

  3. HDU5862 Counting Intersections

    Given some segments which are paralleled to the coordinate axis. You need to count the number of the ...

  4. nodejs、yarn编译安装

    yarn和npm一样,是nodejs的一个依赖管理工具 1.安装nodejs 如果缺少c++ compiler 会报错 yum install -y gcc gcc-c++ 安装nodejs V8   ...

  5. Linux系统——机制策略(一)

    机制策略(一) 形而上谓之道:形而下谓之器: ————易经 LinuxUnix设计理念提供的一种机制不是策略:1.如果说机制是一种框架,那么,策略就是填充框架的一个个具体实施.机制提供的就是一种开放而 ...

  6. python 读取文件夹下的图片进行处理

    python的os模块中有一个listdir函数可以遍历读取文件夹下的文件. import os for filename in os.listdir(r"./file"): #l ...

  7. 预编译scss以及scss和less px 转rem

    预编译scss步骤: 1 搜索ruby并安装,点击 2 安装sass: 3 在hubuilder工具中设置预编译: 触发命令地址为ruby安装地址 命令参数为 %FileName% %FileBase ...

  8. 更新yum 源

    CentOS系统自带的更新源的速度实在是慢,为了让CentOS6使用速度更快的YUM更新源,可以选择163(网易)的更新源. 1.下载repo文件 wget http://mirrors.163.co ...

  9. c#.net前台调用JS文件中的函数[.net与JavaScript的应用]

    原文发布时间为:2008-10-10 -- 来源于本人的百度文章 [由搬家工具导入] <%@ Page Language="C#" AutoEventWireup=" ...

  10. Berkely DB Java Edition学习笔记

    Berkely DB对于高并发.要求速度快的应用来说是个不错的选择,mysql就是用BDB实现的(mysql的后台) ,mysql快,BDB比mysql还要快N倍.BDB是一种嵌入式的.非关系数据库, ...