发现这俩指令是在修改.user.ini,无权修改,root账户都不行,当时就觉得奇怪,是什么限制了写入权限?
经过查询,发现通过
lsattr .user.ini
查看属性,有一个i属性,查了下就是它导致无法修改的。
于是用
chattr -i .user.ini
移除i属性后即可写入。
改完再用
chattr +i .user.ini
将i属性加进去即可。
下为两个指令的说明:
lsattr
语法: #lsattr [-aR]
参数说明:
-a :将隐藏文件的属性也列出来;
-R :连同子目录的数据也一并列出来!
示例:
# chattr +i .bash_logout ——>添加一个隐藏的“i”属性,后面再细讲
#lsattr -a ——>将当前目录的文件或目录下的文件所有属性(包括隐藏属性)列出
-------------- .
-------------- ..
---i---------- .bash_logout
-------------- .bash_profile
-------------- .bashrc
chattr
语法:#chattr [+-=][ASacdistu] [档案或目录名称]
参数说明:
+-= :分别为 [+ 增加] [- 减少] [= 设定] 属性的意思
A:当设定了 A 这个属性时,这个档案(或目录)的存取时间
atime (access) 将不可被修改, 可避免例如手提式计算机容易有磁盘 I/O 错误的情况发生!
S:这个功能有点类似 sync 的功能!就是会将数据同步写入磁盘当中!可以有效的避免数据流失!
a:当设定 a 之后,这个档案将只能增加数据,而不能删除,只有 root 才能设定这个属性。
c:这个属性设定之后,将会自动的将此档案『压缩』,在读取的时候将会自动解压缩出来,但是在储存的时候,将会先进行压缩之后再储存(看来对于大档案似乎蛮有用的!)
d:当 dump (备份)程序被执行的时候,设定 d 属性将可使该档案(或目录)具有 dump 功效!
i:这个 i 可就很厉害了!他可以让一个档案『不能被删除、改名、设定连结也无法写入或新增数据!对于系统安全性有相当大的帮助!
j:当使用 ext3 这个档案系统格式时,设定 j 属性将会使档案在写入时先记录在 journal 中! 但是当 filesystem 设定参数为 data=journalled 时,由于已经设定了日志了,所以这个属性无效!
s:当档案设定了 s 参数时,他将会被完全的移除出这个硬盘空间。
u:与 s 相反的,当使用 u 来设定档案时,则数据内容其实还存在磁盘中,可以使用来 undeletion.
示例:
#chattr +i /etc/shadow ——>添加“i”隐藏属性后,就无法更动这个文件了
#chattr -i /etc/shadow ——>解除"i"这个隐藏属性
函数示例整理自:https://www.cnblogs.com/sbaicl/archive/2012/11/15/2771564.html
如您从本文得到了有价值的信息或帮助,请考虑扫描文末二维码捐赠和鼓励。
如本文对您有用,捐赠和留言 将是对我最好的支持~(捐赠可转为站内积分)
如愿意,请向朋友推荐本站,谢谢。
尊重他人劳动成果。转载请务必附上原文链接,我将感激不尽。
留言