为了防止在 Linux 系统中意外删除一些重要文件或目录,除了必要的备份之外,还有一个好方法,就是使用
在类 Unix 等发行版中,该命令能够有效防止文件和目录被意外的删除或修改。file 文件在 Linux 中被描述为一个数据结构,chattr 命令在大多数现代 Linux 操作系统中是可用的,可以修改file属性,一旦定义文件的隐藏属性,那么该文件的拥有者和 root 用户也无权操作该文件,只能解除文件的隐藏属性。
chattr [operator] [switch] [file]
operator 具有如下操作符:
a:让文件或目录仅供附加用途;
b:不更新文件或目录的最后存取时间;
c:将文件或目录压缩后存放;
d:将文件或目录排除在倾倒操作之外;
i:不得任意更动文件或目录;
s:保密性删除文件或目录;
S:即时更新文件或目录;
u:预防意外删除。
> lsattr rumenz.txt
---------------- rumenz.txt
> chattr +i rumenz.txt
> lsattr rumenz.txt
----i----------- rumenz.txt
> echo "rumenz.com" > rumenz.txt
-bash: rumenz.txt: Permission denied
提示没有权限
> chattr -i rumenz.txt
> mkdir rumenz && touch rumenz/1.txt
> tree
.
└── rumenz
└── 1.txt
> lsattr rumenz/
---------------- rumenz/1.txt
> chattr +i -R rumenz/
> lsattr rumenz/
----i----------- rumenz/1.txt
> mkdir rumenz/one
mkdir: cannot create directory ‘rumenz/one’: Permission denied
提示权限不足
> echo "rumenz.com" > rumenz/1.txt
-bash: rumenz/1.txt: Permission denied
> chattr -i -R rumenz
> lsattr rumenz.txt
---------------- rumenz.txt
> chattr +a rumenz.txt
> lsattr rumenz.txt
-----a---------- rumenz.txt
> echo "rumenz.com" > rumenz.txt
-bash: rumenz.txt: Operation not permitted
> echo "rumenz.com" >> rumenz.txt
修改覆盖rumenz.txt文件内容不行,向后追加可以。
> mv rumenz.txt one.txt
mv: cannot move ‘rumenz.txt’ to ‘one.txt’: Operation not permitted
提示权限不足
> chattr +a -R rumenz
> lsattr rumenz/
-----a---------- rumenz/1.txt
> mkdir rumenz/one
> mv rumenz/one rumenz/tow
mv: cannot move ‘rumenz/one’ to ‘rumenz/tow’: Operation not permitted
> touch rumenz/3.txt
> ls rumenz/
1.txt 3.txt one
> rm -rf rumenz/3.txt
rm: cannot remove ‘rumenz/3.txt’: Operation not permitted
不能被删除
> echo "rumenz.com" > rumenz/3.txt
> cat rumenz/3.txt
rumenz.com
原文链接:https://rumenz.com/rumenbiji/linux-chattr-lsattr.html
页面更新:2024-05-26
本站资料均由网友自行发布提供,仅用于学习交流。如有版权问题,请与我联系,QQ:4156828
© CopyRight 2020-2024 All Rights Reserved. Powered By 71396.com 闽ICP备11008920号-4
闽公网安备35020302034903号