文件/目录权限chmod

#查看目录/文件的权限
[root@linux1~]#ls-l/tmp/a/
总用量0
drwxr-xr-x.2rootroot610月2409:282
#drwxr-xr-x一共有十位数,其中:最前面第一位表示类型
#前三个代表所有者(user)拥有的权限
#中间三个代表组群(group)拥有的权限
#最后三个代表其他人(other)拥有的权限

#r表示文件可以被读(read)
#w表示文件可以被写(write)
#x表示文件可以被执行
#-表示相应的权限还没有被授予

需要注意的是:查看文件权限的目录问题:如果有文件夹 /a/b/c


那么执行ls -l /a/b查看权限的文件并不是b,而是查看的c的权限。


ls -l /a查看的是b文件的权限

ls -l /a/b查看的是cls -l /a/b/c查看的是文件的权限

#修改权限
drwxr-xr-x.4rootroot2410月2520:25a
#user=rwx
#group=r-x
#other=r-x

语法:
#chmodu=[选项],g=[选项],o=[选项]文件/目录
#实例如下:
[root@centos7tmp]#chmodu=rwx,g=r,o=ra
[root@centos7tmp]#ls-l
drwxr--r--.4rootroot2410月2520:25a

#取消权限
#chmoda-x,u-x,g-x文件/目录
#实例如下:
[root@centos7tmp]#chmodu-r,g-r,o-ra
[root@centos7tmp]#ls-l
d-wx------.4rootroot2410月2520:25a
#rwx:可以用数字来代替
r----------4
w----------2
x----------1
---------0
#实例
-rw-r--r--.1rootroot33410月2521:34a/1.txt
#---------(600)所有者有读和写的权限
#------(400)群组(用户组)有读的权限
#---(400)其他人只有读的权限

#所以,可以标记为644如果每位加1即755如下设置
[root@centos7tmp]#chmod755a/1.txt
[root@centos7tmp]#ls-la/1.txt
-rwxr-xr-x.1rootroot33410月2521:34a/1.txt
#这样子,就把简单的把执行权限都加上了

#chomd-R的用法如下,更改当前目录或子目录的权限
[root@centos7tmp]#chmod-R777a
[root@centos7tmp]#ls-l/tmp/a
总用量4
-rwxrwxrwx.1rootroot33410月2521:341.txt
drwxrwxrwx.3rootroot1510月2521:32b

更改所有者和所属组chown,chgrp

#chown即changeowner的缩写改变文件所有者属性

#chown所有者:所属组1.txt修改所属组
[root@centos7a]#chownuser:user1.txt
[root@centos7a]#ls-l1.txt
-rw-r--r--.1useruser33910月2522:001.txt

#chown可以加R选项,用来修改目录及以下的所有文件的权限
[root@centos7tmp]#ls-la/
总用量4
-rw-r--r--.1useruser34610月2522:011.txt
drwxrwxrwx.3useruser1510月2521:32b

#chgrp(changegroup)
#chgrp命令:chgrp命令用来改变文件或目录所属的用户组。该命令用来改变指定文件所属的用户组。
格式:chgrp[选项]组名文件名
[root@centos7tmp]#ls-la
-rw-r--r--.1useruser34610月2522:011.txt
[root@centos7a]#chgrproot1.txt
[root@centos7a]#ls-l1.txt
-rw-r--r--.1userroot34610月2522:011.txt

umask

umask 每个用户都有一个默认的umask值,是用来确认用户的默认权限。

#查看umask值
[root@centos7a]#umask
0022

默认文件权限计算方法
1)假设umask值为:022(所有位为偶数)
666==>文件的起始权限值
022-==>umask的值
---------
644
2)假设umask值为:045(其他用户组位为奇数)
666==>文件的起始权限值
045-==>umask的值
---------
621==>计算出来的权限。由于umask的最后一位数字是5,所以,在其他用户组位再加1。
001+
---------
622==>真实文件权限

默认目录权限计算方法
777==>目录的起始权限值
022-==>umask的值
---------
755

#实例一:umask所有位全为偶数时,多数读者对这个例子无疑问
[root@oldboyoldboy]#umask
0022#→umask当前数值
[root@oldboyoldboy]#umask044#→更改为044
[root@oldboyoldboy]#umask
0044
[root@oldboyoldboy]#mkdirumask_test#→建目录测试
[root@oldboyoldboy]#ls-ldumask_test
drwx-wx-wx2rootroot4096Nov1219:21umask_test#→对应数字权限为733,是不是符合上面的计算方法?
[root@oldboyoldboy]#touchumask_test.txt
[root@oldboyoldboy]#ls-lumask_test.txt
-rw--w--w-1rootroot0Nov1219:21umask_test.txt#→对应数字权限为622,是不是符合上面的计算方法?
#实例二:umask值的部分或全部位为奇数时,这个是读者疑问最大的
#当umask值的其他属组位为奇数时
[root@oldboyoldboy]#umask0023
[root@oldboyoldboy]#mkdirdir
[root@oldboyoldboy]#touchfile
[root@oldboyoldboy]#ls-l
总计4
drwxr-xr--2rootroot409611-1501:04dir#→对应数字权限为754
-rw-r--r--1rootroot011-1501:04file#→对应数字权限为644
#提示:根据前面的计算方法,当umask为0023时,dir的权限应该是754,而file的权限应该为643,但是由于umask的其他组位为奇数,因此最终权限为其他组位加1,即643加001(对应实践结果644)。注意:umask为偶数的位不要加1。
#实例三:umask值的所有位为奇数时
[root@oldboyoldboy]#umask0551
[root@oldboyoldboy]#umask
0551
umask为0551根据掩码方法计算:目录权限为226,文件权限115,而实际文件权限为226(umask的三个权限位都是奇数,所以,每个位分别加1就是正确的权限)
[root@oldboyoldboy]#mkdirdir5
[root@oldboyoldboy]#touchfile5
[root@oldboyoldboy]#ls-l
总计4
d-w--w-rw-2rootroot409611-1501:27dir5#→目录对应数字权限为226
--w--w-rw-1rootroot011-1501:27file5#→目录对应数字权限为226
再来一例验证下:
[root@oldboyoldboy]#umask0333
[root@oldboyoldboy]#umask
0333
umask为0333根据掩码方法计算:目录权限为444,文件权限333,而实际文件权限为444(umask的三个位都是奇数,所以,每个位分别加1就是正确的权限)
[root@oldboyoldboy]#mkdirdir3
[root@oldboyoldboy]#touchfile3
[root@oldboyoldboy]#ls-l|grep3
dr--r--r--2rootroot409611-1501:30dir3#→目录对应数字权限为444
-r--r--r--1rootroot011-1501:30file3#→目录对应数字权限为444

隐藏权限lsattr_chattr

除了设置文件或目录的读(r)、写(w)、执行(x)权限外,对于某些有特殊要求的档案(如服务器日志)还可以追加隐藏权限的设定。

chattr 设置隐藏权限 选项参数有

i:设定文件不能被删除、改名、设定链接关系,同时不能写入或新增内容。

a:即append,设定该参数后,只能向文件中添加数据,而不能删除,多用于服务器日志文件安全,只有root才能设定这个属性。

+ :在原有参数设定基础上,追加参数。
- :在原有参数设定基础上,移除参数。


lsattr 查看隐藏权限 选项有

-a:显示所有文件属性,包括隐藏文件(.)、当时目录(./)及上层目录(../)。

-d:仅列示目录属性。

-R:递归列示目录及文件属性。

#实例:
#给目录添加隐藏权限
[root@centos7a]#chattr+ic#添加权限
[root@centos7a]#lsattr-dc#查看权限
----i-----------c
#给文件添加隐藏权限
[root@centos7a]#chattr+i1.txt
[root@centos7a]#lsattr-d1.txt
----i-----------1.txt

3a60216e627f55920a86d460d1c48b00.png-wh_

上图显示无法修改

[root@centos7a]#chattr-i1.txt
[root@centos7a]#lsattr-d1.txt
----------------1.txt

关于其他用法,详情请参阅在线帮助man

centos 7的文件/目录权限介绍的更多相关文章

  1. ios – Xcode警告:“没有处理文件的规则”和“找不到目录”

    重命名我的项目文件夹后,我收到以下错误消息:什么可能出错?解决方法关于第一个警告,您可以在项目设置中的“构建阶段”中检查XCode,即头文件不会出现在“编译源”列表中.

  2. 你如何将xcode项目转换为cocoapod?

    我有一段代码,我发现我在多个不同的项目中重复使用,所以我想把它变成一个cocoapod并使用私人cocoapod仓库.我的问题是如何将xcode项目设置为cocoapod?它应该是一个静态库还是一个带有appdelegate的空“项目”?

  3. ios – 如何将文件添加到主包的/ Library / Sounds目录中?

    根据Apple’sdocumentation,/Library/Sounds中的声音文件将在尝试播放声音时由系统搜索.如何将声音文件添加到此文件夹?适用于iOS的正确文档应为here总之,您只需将声音文件作为应用程序包的非本地化资源添加到项目中.

  4. ios – 资产目录与文件夹参考:何时使用其中一个?

    我可以将文件放入Assets.xcassets,或者我可以将文件放入文件夹引用.我何时会选择一个而不是另一个?

  5. ios – 从icloud备份中限制sqlite-wal和sqlite-shm

    我是第一次使用coredata,我必须从文档目录中的iCloud备份限制sqlitedb文件,我使用下面的代码完成了它//阻止iCloud备份文档目录文件夹现在我不明白的是,我们还需要从icloud备份中限制sqlite-wal和sqlite-shm文件,如果是,那么如何从icloud备份限制sqlite-wal和sqlite-shm文件我想要一个解决方案,而无需从文档目录文件夹中更改sqlitedb位置…

  6. iOS:如何从文档目录中删除具有特定扩展名的所有现有文件?

    当我更新我的iOS应用程序时,我想删除Documents目录中的任何现有sqlite数据库.现在,在应用程序更新时,我将数据库从软件包复制到文档目录,并通过附加软件包版本来命名它.因此,在更新时,我还想删除可能存在的任何旧版本.我只是希望能够删除所有sqlite文件,而无需循环浏览并查找以前版本的文件.是否有任何方法可以对removeFileAtPath:方法进行通配符?解决方法那么,你想要删除所有*.sqlite文件?

  7. .dylib在Debug中链接,在XCode中找不到适用于iPhone的版本

    所以我已经将libxml2.2.dylib库包含在我的iPhoneXCode项目中,以创建一些Xml和XPath解析实用程序.当我编译并运行在模拟器和设备的调试模式时,我没有问题,但是,当我切换到发布模式我得到…

  8. ios – 从文件目录加载UIImage

    我正在尝试从文件目录加载一个UIImage,并将其设置为UIImageView,如下所示:但是,每当我尝试以上,图像从不加载.该图像在Documents/MyAppCustomDirectory/school.png中.以上是否正确从该目录加载?我也尝试了其他几个:UIImageimageWithContentsOfFile,以及基于SO响应的其他方法.解决方法要获取您应该使用的文档目录:我不太清

  9. Xcode 6 / iOS 8模拟器数据和软件包文件夹脚本

    随着xcode6的最新更改,它看起来像.app文件和文档文件夹不再驻留在iPhone模拟器目录中的同一个文件夹中.以前,我们可以访问目录和.app文件但在Xcode6中,模拟器目录是完全不同的:和其中CryptNumber1,2和3都不同.有没有办法找到包含.app文件的文件夹后,我可以得到相应的文件夹?我有这个麻烦.为什么…?

  10. ios – 上传符号文件

    我该如何解决?

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部