chattr和lasttr命令

一、chattr命令

1.命令介绍

他可以用来设置/取消,文件或者目录的一些特殊属性,比如不可修改、不可删除、不可压缩等。

这些属性可以增加文件或目录的安全性和稳定性,也可以节省磁盘空间和提高性能。

chattr命令用于改变文件或目录的扩展属性。它允许用户设置或清除文件的隐藏属性,这些属性在标准的ls -l命令中是不可见的。

通常情况下,不要使用 chattr 命令修改 /、/dev/、/tmp/、/var/ 等目录的隐藏属性,很容易导致系统无法启动。

另外,chatrr 命令常与 lsattr 命令合用,前者修改文件或目录的隐藏属性,后者用于查看是否修改成功

2.常用的参数

+:添加指定的属性

-:移除指定的属性

=:设置指定的属性,其他的属性会清除掉

3.属性选项

a:只能追加内容,不能删除或修改

i:文件不能被删除、重命名、修改或链接

b:不更新文件或目录的最后存取时间

c:自动压缩文件,读取时解压缩,写入时压缩

u:删除文件时,文件内容会被保存,便于恢复

e:文件会被完全从磁盘上删除

s:文件被删除时,其内容会被完全覆盖,以提高安全性

S:文件写入时,数据会同步写入磁盘,以确保数据完整性

d:文件或目录被删除时,不会放入回收站,而是直接删除

4.使用案例

4.1 设置文件不可修改

假设我们有一个重要的配置文件/etc/config.conf,我们希望防止任何修改和删除,可以使用chattr命令添加i属性:

chattr +i /etc/config.conf

此时,文件config.conf将无法被修改或删除。

image-20250821171711725

4.2 允许文件追加内容

对于日志文件,我们可能希望只允许追加内容,而不允许修改或删除。例如,对/var/log/syslog设置a属性:

chattr +a /var/log/syslog

这样,任何人都不能删除或修改syslog文件,但可以追加新的日志条目。

image-20250821172434145

【例 1】 给文件赋予 i 属性。

#建立测试文件
[root@localhost ~]# touch ftest
[root@localhost ~]# chattr +i ftest
#被赋予i属性后,root不能删除
[root@localhost ~]# rm -rf ftest
rm:cannot remove 'ftest':Operation not permitted
#无法删除"ftesr",操作不允许

[root@localhost ~]# echo 111>>ftest
bash:ftest:Permission denied
#权限不够,不能修改文件中的数据

#可以看到,设置有 i 属性的文件,即便是 root 用户,也无法删除和修改数据。

【例 2】为目录赋予 i 属性。

#建立测试目录
[root@localhost ~]# mkdir dtest
#再建立一个测试文件abc
[root@localhost dtest]# touch dtest/abc
#给目录赋予i属性
[root@localhost ~]# chattr +i dtest

[root@localhost ~]# cd dtest
[root@localhost dtest]# touch bed
touch: cannot touch 'bed':Permission denied
#无法创建"bcd",权限不够,dtest目录不能新建文件


[root@localhost dtest]# echo 11>>abc
[root@localhost dtest]# cat abc
11
#可以修改文件内容
[root@localhost dtest]# rm -rf abc
rm: cannot remove 'abc': Permission denied
#无法删除"abc",权限不够


# 一旦给目录设置 i 属性,即使是 root 用户,也无法在目录内部新建或删除文件,但可以修改文件内容。
# 给设置有 i 属性的文件删除此属性也很简单,只需将 chattr 命令中 + 改为 - 即可。

【例 3】演示 a 属性的作用。


# 假设有这样一种应用,每天自动实现把服务器的日志备份到指定目录,备份目录可设置 a 属性,变为只可创建文件而不可删除。
#建立备份目录
[root@localhost ~]# mkdir -p /back/log
#赋予a属性
[root@localhost ~]# chattr +a /back/log

[root@localhost ~]# cp /var/log/messages /back/log
#可以复制文件和新建文件到指定目录中
[root@localhost ~]# rm -rf /back/log/messages
rm: cannot remove '/back/log/messages': Permission denied
#无法删除 /back/log/messages,操作不允许

二、lsattr命令

1.命令介绍

lsattr命令主要用于列出Linux系统文件的属性。这个命令可以帮助我们了解文件的各种属性,比如是否可以被修改、删除等。

2.lsattr命令的基本语法

语法格式如下:

lsattr [选项] [文件]

选项 说明
-a 列出所有文件和目录,包括以.开头的隐藏文件
-d 只列出目录的属性,而不是其下的文件
-R 递归处理,将指定目录下的所有文件及子目录一并处理
-v 显示文件的版本/生成号

3.命令实例详解

实例1:查看文件属性

lsattr file.txt

这个命令会显示file.txt文件的属性。

image-20250821174356138

实例2:查看目录属性

lsattr -d directory

这个命令会显示directory目录的属性,而不是其下的文件。

实例3:递归查看目录属性

lsattr -R directory

这个命令会递归显示directory目录及其子目录下所有文件的属性。

实例4:查看文件系统中所有文件的属性

lsattr -a /

这个命令会显示文件系统中所有文件和目录的属性,包括以.开头的隐藏文件。

实例5:查看并修改隐藏文件的属性

lsattr .hidden_file

chattr +i .hidden_file

lsattr .hidden_file

这个实例首先查看.hidden_file隐藏文件的属性,然后使用chattr命令添加不可修改(i)属性,最后再次查看文件的属性,可以看到属性已经被修改。

实例6:递归查看并修改隐藏目录的属性

lsattr -R .hidden_directory

chattr -R +i .hidden_directory

lsattr -R .hidden_directory

这个实例首先递归查看.hidden_directory隐藏目录及其子目录下所有文件的属性,然后使用chattr命令递归添加不可修改(i)属性,最后再次查看目录的属性,可以看到属性已经被修改。这对于保护重要的配置文件非常有用。

实例7:查看并修改链接文件的属性

lsattr symlink

chattr +i symlink

lsattr symlink

这个实例首先查看symlink链接文件的属性,然后使用chattr命令添加不可修改(i)属性,最后再次查看文件的属性,可以看到属性已经被修改。这对于保护重要的链接文件非常有用。

实例8:查看并修改目录下所有文件的属性

lsattr directory/*

chattr +i directory/*

lsattr directory/*

这个实例首先查看directory目录下所有文件的属性,然后使用chattr命令添加不可修改(i)属性,最后再次查看文件的属性,可以看到属性已经被修改。这对于保护重要的文件非常有用。

实例9:查看并修改特定类型文件的属性

lsattr directory/.txt

chattr +i directory/.txt

lsattr directory/*.txt

这个实例首先查看directory目录下所有.txt文件的属性,然后使用chattr命令添加不可修改(i)属性,最后再次查看文件的属性,可以看到属性已经被修改。这对于保护重要的文本文件非常有用。

实例10:查看并修改特定权限文件的属性

lsattr -R | grep 'i'

chattr +i $(ls -l | awk '/^-r--r--r--/ {print $NF}')

lsattr -R | grep 'i'

这个实例首先查看所有具有不可修改(i)属性的文件,然后使用chattr命令添加不可修改(i)属性到所有只读文件,最后再次查看所有具有不可修改(i)属性的文件,可以看到属性已经被修改。这对于保护重要的只读文件非常有用。

实例11:查看并修改特定用户文件的属性

lsattr -R | grep 'i'

chattr +i $(ls -l | awk '/^root/ {print $NF}')

lsattr -R | grep 'i'

这个实例首先查看所有具有不可修改(i)属性的文件,然后使用chattr命令添加不可修改(i)属性到所有root用户的文件,最后再次查看所有具有不可修改(i)属性的文件,可以看到属性已经被修改。这对于保护重要的root用户文件非常有用。

posted @ 2025-08-22 11:01  月映冷香如你  阅读(5)  评论(0)    收藏  举报