在Linux文件系统中,文件属性并非仅有ls命令显示的常规信息,chattr与lsattr是管理“扩展文件属性” 的核心工具,前者可设置防删除、只读等特殊权限,后者用于查看这些属性,是保障文件安全、避免误操作的关键手段,接下来通过这篇文章详细介绍一下Linux中lsattr与chattr命令!
chattr:修改文件的扩展属性
chattr 命令用于设置或取消文件和目录的特定属性。这些属性直接影响文件的行为,比如是否可被修改、删除或追加内容。
基本语法:
chattr [选项] [操作符][属性] 文件名
常见属性包括:
a:仅允许以追加模式写入(append only)。常用于日志文件,防止被覆盖或删除。
i:不可变(immutable)。设置了该属性的文件不能被修改、重命名、删除,也不能创建硬链接。
s:安全删除。文件被删除时数据块会被覆写,提高安全性。
A:禁止更新访问时间(atime),有助于减少磁盘I/O。
c:自动压缩存储(需文件系统支持)。
操作符说明:
+:添加指定属性。
-:移除指定属性。
=:设定为指定属性,清除其他属性。
lsattr:查看文件的扩展属性
lsattr 命令用于显示文件或目录的扩展属性,帮助管理员确认某个文件是否设置了特殊保护。
基本语法:
lsattr [选项] 文件名
常用选项:
-a:显示包括隐藏文件在内的所有条目。
-d:显示目录本身,而非其内容。
-R:递归显示子目录中的属性。
-v:显示文件版本信息(较少使用)。
注意事项与限制
使用chattr和lsattr需要注意以下几点:
仅对ext2、ext3、ext4等e2fs系列文件系统有效,其他文件系统(如XFS、Btrfs)支持有限。
即使root用户也无法绕过i或a属性的限制,必须先用chattr -i解除。
误操作可能导致系统故障,例如将/boot或内核模块设为不可变后影响升级。
某些属性需要内核或挂载选项支持。
为了让学员学以致用,老男孩教育不断更新Linux培训教学大纲,与一众讲师精心打造Linux云计算SRE课程体系。老男孩教育Linux云计算SRE运维课程,从零基础开始授课,适合零基础且对Linux感兴趣的学员学习。课程的主要目的就是培养出专业的Linux系统工程师,名师授课全程面授教学,边讲边练帮助学员高效掌握Linux技术。
推荐阅读: