『学了就忘』Linux基础命令 — 25、文件基本权限的管理
Linux系统的权限有6种。
- 读写执行为基本权限。
umask
为默认权限。- 后边还有4种权限,会在之后的权限管理部分详细讲解。
1、文件和目录的默认权限
我们先创建一个文件abc
,然后查看abc
文件的长信息。
[root@192 ~]# touch abc
[root@192 ~]# ls -l abc
-rw-r--r--. 1 root root 0 12月 30 05:32 abc
可以看到上边新创建的文件,直接就有一定的权限,我们把这种权限叫默认权限。
Linux系统是如何得到文件和目录的默认权限?
是通过umask
值来获得文件和目录的默认权限。
2、umask默认权限
(这个值基本上不用我们自己修改,但是我们一定要知道这个,并且能看懂就可以了。)
(1)查看系统的umask权限
[root@localhost ~ ] # umask
0022
注意:我们之前学的权限只有三位,我们现在忽略第一位,第一位的作用在以后文章中会详细说明。
(2)用八进制数值显示umask权限
#用字母表示文件和目录的初始权限
[root@localhost ~ ] # umask -S
u=rwx,g=rx,O=rx
(3)umask权限的计算方法
我们需要先了解一下新建文件和目录的默认最大权限。
- 对文件来讲,新建文件的默认最大权限是666,没有执行(x)权限。这是因为执行权限对文件来讲比较危险,不能在新建文件的时候默认赋予,而必须通过用户手工赋予。
- 对目录来讲,新建目录的默认最大权限是777。这是因为对目录而言,执行(x)权限仅仅代表进入目录,所以即使建立新文件时直接默认赋予,也没有什么危险。
按照官方的标准算法,umask
默认权限需要使用二进制进行逻辑与和逻辑非联合运算才可以得到正确的新建文件和目录的默认权限。这种方法对计算机来说很好计算,但是对人来说既不好计算,也不好理解,不推荐。
我们在这里还是按照权限字母来讲解
umask
权限的计算方法。(推荐算法)我们就按照默认的
umask
值是022来分别计算一下新建文件和目录的默认权限吧。提示:022,表示三位算一个权限,第一位表示文件类型。
- 文件的默认权限最大只能是666,而
umask
的值是022,如下:
-rw-rw-rw-
减去-----w--w-
等于-rw-r--r--
- 目录的默认权限最大可以是777,而
umask
的值是022
drwxrwxrwx
减去d----w--w-
等于drwx-r-xr-x
(4)注意:umask默认权限的计算绝不是数字直接相减。
例如umask
是033呢?
修改umask
值命令为:[root@192 ~]# umask 033
注意:(临时修改,如果需要永久修改,就要修改配置文件)
文件的默认权限最大只能是666,而umask
的值是033,如下:
-rw-rw-rw-
减去---wx-wx
等于-rw-r-r-
r
--
=r
w
-w
=-
-
-x
=-x
(所有负的都为-
)
例如umask
是033用数字相减呢?
666-033=633
翻译成权限为-rw--rx-rx
,这就不对了。
提示:
修改
umask
值的配置文件在/etc/profile
文件,/etc/profile
文件是环境变量配置文件。什么是环境变量配置文件?
修改该文件内容,会影响当前系统的操作环境。
环境变量配置文件并不是只有这一个,默认是有4个环境变量配置文件,另加一个目录(目录中有很多配置文件,以后用到哪个说哪个。)。
说明:
我们进入到上边所提到的/etc/profile
环境变量配置文件,可以找到关于umask
值的代码块,如下所示:
[user1@192 ~]$ cat /etc/profile
if [ $UID -gt 199 ] && [ "`id -gn`" = "`id -un`" ]; then
umask 002
else
umask 022
fi
#在Linux系统中root用户的UID=0,而普通用户的UID>500,500以内是留给系统用户的。
#[ "`id -gn`" = "`id -un`" ]判断的是用户的UID和GID是相等的,暂时可以忽略不看。
root用户的umask值
[root@192 ~]# umask
0022
普通用户的umask值
[user1@192 ~]$ umask
0002
总结:
umask
值重要度很高,默认自动赋值并生效。但是不需要用户介入(修改),能看懂,知道他就可以了。
『学了就忘』Linux基础命令 — 25、文件基本权限的管理的更多相关文章
- 『学了就忘』Linux基础命令 — 20、文件操作的相关命令
目录 1.touch 命令 2.stat命令 3.cat命令 4.more命令 5.less命令 6.head命令 7.tail命令 1.touch 命令 touch命令用于创建空文件或修改文件时间, ...
- 『学了就忘』Linux基础命令 — 22、Linux中的硬链接和软链接
目录 1.文件和目录的基本存储 2.In命令介绍 (1)我们来看看ln命令的基本信息 (2)ln命令的基本格式 3.创建硬链接 (1)如何创建硬链接 (2)硬链接特征 (3)硬连接原理 4.创建软链接 ...
- 『学了就忘』Linux基础命令 — 23、文件基本权限的介绍和作用
目录 1.基本权限的介绍 (1)权限位的含义 (2)权限的优先级 2.权限的基本作用 (1)权限含义的解释 (2)目录权限说明 1.基本权限的介绍 (1)权限位的含义 前面讲解ls命令时,我们已经知道 ...
- 『学了就忘』Linux基础命令 — 24、文件基本权限的相关命令
目录 1.chmod命令 2.权限模式 (1)用户身份. (2)赋予方式. (3)权限. 3.数字权限 4.文件常用权限 5.chown命令 6.chgrp命令 7.总结 常用基本权限操作命令: ch ...
- 『学了就忘』Linux基础命令 — 26、帮助命令
目录 1.man命令 (1)man命令的快捷键 (2)man命令的帮助级别(了解即可) (3)man命令的使用 2.info命令 3.help命令 4.--help选项 1.man命令 man是最常见 ...
- 『学了就忘』Linux基础命令 — 28、别名和常用快捷键
目录 1.别名 2.常用快捷键 1.别名 别名也是Shell中的命令. 命令的别名,就是命令的小名,主要是用于照顾管理员使用习惯的. 命令格式: # 查询系统中命令别名 [root@localhost ...
- 『学了就忘』Linux基础命令 — 30、find命令详细说明
目录 1.find命令的基本信息 2.find命令基本使用 3.按照文件大小搜索 4.按照修改时间搜索 5.按照权限搜索 6.按照所有者和所属组搜索 7.按照文件类型搜索 8.逻辑运算符 (1)-a: ...
- 『学了就忘』Linux基础命令 — 32、压缩和解压缩相关命令
目录 1.".zip"格式压缩 2.".gz"格式压缩 3.".bz2"格式压缩 4.".tar"格式打包 5.打包和压 ...
- 『学了就忘』Linux基础命令 — 18、Linux命令的基本格式
目录 1.命令提示符说明 2.命令的基本格式 (1)举例ls命令 (2)说明ls -l命令的 输出内容 1.命令提示符说明 [root@localhost ~] # []:这是提示符的分隔符号,没有特 ...
随机推荐
- Java基础系列(14)- JavaDoc生成文档
JavaDoc JavaDoc是一种将注释生成HTML文档的技术,生成的HTML文档类似于Java的API,易读且清晰明了 参数信息 @author 作者名 @version 版本号 @since 指 ...
- linux 服务器资源 监控工具
工具一:vmstat(服务端) 一.vmstat选项参数解释 -V:显示vmstat版本信息 -n:只在开始时显示一次各字段名称 -a:显示活跃和非活跃内存 -d:显示各个磁盘相关统计信息 -D:显示 ...
- 网站优化之mysql优化
一,网站优化之mysql优化:1.前缀索引,可以通过前缀去识别唯一性,把这个前缀作为索引内容,可以节省存储索引的空间,从而提高索引的查询速度.distinct 排重操作2,2.in条件索引使用同时查询 ...
- Navicat连接数据库成功,新建查询时提示错误“Cannot create file ……”
Navicat连接数据库成功,新建查询时提示错误"Cannot create file --" 原因:编辑连接{高级}<设置位置>被修改,该oci.dll不正确 解决方 ...
- NWERC2020J-Joint Excavation【构造,贪心】
正题 题目链接:https://codeforces.com/gym/103049/problem/J 题目大意 \(n\)个点\(m\)条边的一张无向图,选出一条路径后去掉路径上的点,然后将剩下的点 ...
- .NET 5 WPF 调用OCX 经验分享
在.Net 5.0 WPF中调用OCX步骤如下: 1,用工具先把ocx转换成AxInterop.EloamViewLib.dll和Interop.EloamViewLib.dll.(这里是我用到的oc ...
- openlayer 4326与3857坐标互转之Java版
public class Transform { private static final double PI = Math.PI; private static final double merca ...
- 记一次Kafka服务器宕机的真实经历!!
大家好,我是冰河~~ 估计节前前祭拜服务器不灵了,年后服务器总是或多或少的出现点问题.不知是人的问题,还是风水问题.昨天下班时,跟运维小伙伴交代了好几遍:如果使用Docker安装Kafka集群的话,也 ...
- electron-builder进行DEBUG输出的正确方式
前言 使用Electron进行打包通常会用到electron-builder或者electron-packager两种工具.在使用electron-builder的时候,由于对机制的不熟悉,我们在打包 ...
- Serverless 架构下的服务优雅下线实践
作者 | 行松 阿里巴巴云原生团队 应用发布.服务升级一直是一个让开发和运维同学既兴奋又担心的事情. 兴奋的是有新功能上线,自己的产品可以对用户提供更多的能力和价值:担心的是上线的过程会不会出现意外情 ...