文件|目录的默认权限与隐藏权限
?
当我们创建一个文件或者目录时即使我们未对其非配权限,其也会存在默认权限
[root@localhost tmp]# mkdir newdir [root@localhost tmp]# ls -dl newdir drwxr-xr-x 2 root root 4096 02-21 11:10 newdir [root@localhost tmp]# touch newfile [root@localhost tmp]# ll newfile -rw-r--r-- 1 root root 0 02-21 11:11 newfile [root@localhost tmp]# [root@localhost tmp]#
?
对于文件来说默认的权限是rw-r--r—
对于目录来说默认的权限是rwxr-xr-x
?
语法:
查看默认权限:umask [-S]
选项与参数:-S 以符号形式显示
?
设置默认权限:umask 权限数
?
说明:对于目录来说最大权限是777(rwxrwxrwx)
???? ?对于文件来说最大权限是666(rw-rw-rw-)
?
当权限数为022时代表:目录权限(777-022)=755(rwxr-xr-x)
当权限数为022时代表:目录权限(666-022)=644(rw-r--r—)
?
举例:查看默认权限
[root@localhost tmp]# umask 0022 [root@localhost tmp]# umask -S u=rwx,g=rx,o=rx
举例:设置默认权限
?
[root@localhost tmp]# umask 011 [root@localhost tmp]# mkdir newdir1 [root@localhost tmp]# ls -dl newdir1 drwxrw-rw- 2 root root 4096 02-21 13:09 newdir1 [root@localhost tmp]# touch newfile1 [root@localhost tmp]# ll newfile1 -rw-rw-rw- 1 root root 0 02-21 13:10 newfile1
?
文件隐藏属性(chattr|lsattr)
?
?
设置文件属性
?
语法:chattr [+-=][ASacdistu]文件或目录名称
选项与参数:
+:增加某一个特殊参数
-:删除某一个特殊参数
=:仅有后面接的参数
?
A:当配置了 A 这个属性时,若你有存取此文件(或目录)时,他的存取时间 atime将不会被修改,可避免I/O较慢的机器过度的存取磁碟。这对速度较慢的计算机有帮助
S:一般文件是非同步写入磁碟的(原理请参考第五章sync的说明),如果加上 S 这个属性时,当你进行任何文件的修改,该更动会[同步]写入磁碟中。
a:当配置 a 之后,这个文件将只能添加数据,而不能删除也不能修改数据,只有root才能配置这个属性。
c:这个属性配置之后,将会自动的将此文件『压缩』,在读取的时候将会自动解压缩, 但是在储存的时候,将会先进行压缩后再储存(看来对於大文件似乎蛮有用的!)
d:当 dump 程序被运行的时候,配置 d 属性将可使该文件(或目录)不会被 dump 备份
i:可以让一个文件[不能被删除、改名、配置连结也无法? 写入或新增数据!]对与系统安全性有相当大的助益!只有 root 能配置此属性
s:当文件配置了 s 属性时,如果这个文件被删除,他将会被完全的移除出这个硬盘空间,所以如果误删了,完全无法救回来了喔!
u:与 s 相反的,当使用 u 来配置文件时,如果该文件被删除了,则数据内容其实还存在磁碟中,可以使用来救援该文件
?
举例:
[root@localhost tmp]# nano [root@localhost tmp]# ll testa -rw-r--r-- 1 root root 5 02-21 13:24 testa [root@localhost tmp]# chattr +a testa [root@localhost tmp]# nano testa //此处修改不允许保存 [root@localhost tmp]# chattr =i testa [root@localhost tmp]# rm testa rm:是否删除有写保护的 一般文件 “testa”? y rm: 无法删除 “testa”: 不允许的操作
查看文件属性
?
语法:lsattr [-adR] 文件或目录
选项与参数:
-a:将隐藏文件列出来
-d:如果接的是目录,仅列出目录本身属性而非目录内的文件名
-R:连同子目录的数据也一并列出来
?
查看文件类型
?
语法:file 文件
[root@localhost tmp]# file ~/.bashrc /root/.bashrc: ASCII text
?