chattr:修改文件的特殊属性

chattr ​命令用于改变文件的特殊属性,也称为"chattr 属性"。这些属性可以提供额外的安全性和控制,如设置文件为不可修改、只允许在文件末尾添加数据等。

一、Linux 文件属性

文件属性是指与文件相关联的元数据,这些属性决定了文件的行为和访问权限。

常见属性

  1. 文件名(Filename) :文件的名称,通常包含字母、数字、下划线和某些特殊字符。
  2. 大小(Size) :文件占用的磁盘空间,通常以字节为单位。
  3. 类型(Type) :文件是普通文件、目录、链接文件、设备文件等。
  4. 权限(Permissions) :定义了用户(所有者)、组和其他用户对文件的访问权限(读、写、执行)。
  5. 所有者(Owner) :文件的所有者,通常是创建该文件的用户。
  6. 所属组(Group) :文件所属的用户组。
  7. 修改时间(Modified Time) :文件内容最后一次被修改的时间。
  8. 访问时间(Access Time) :文件最后一次被访问的时间。
  9. 创建时间(Creation Time) :文件被创建的时间(不是所有文件系统都支持)。

查看、修改属性:

  • ls -l:列出文件的详细信息,包括权限、所有者、大小、修改时间等。
  • chown:更改文件的所有者和/或所属组。
  • chmod:更改文件的权限。
  • touch:更改文件的访问时间和修改时间。
  • chattr:在支持扩展属性的文件系统上,更改文件的特殊属性。

特殊属性(收藏一下,用到再查):

  • a​:⭐Append-only。如果文件设置了这个属性,则只能追加数据到文件末尾,不能更改或删除现有的数据。
  • A​:No atime。设置这个属性后,文件访问时间(atime)不会被更新,即使文件被读取或修改。
  • c​:Compressed。如果文件设置了这个属性,当文件被删除时,文件系统会尝试在文件被完全删除之前对其进行压缩。
  • C​:Compressed when writing。如果文件设置了这个属性,当文件被写入时,文件系统会尝试在写入操作完成之前对其进行压缩。
  • d​:No dump。如果文件设置了这个属性,文件系统在备份操作时不会将文件包含在备份中。
  • i​:⭐Immutable。如果文件设置了这个属性,文件不能被删除、修改或重命名。
  • j​:No journal。如果文件设置了这个属性,文件系统不会在将数据写入磁盘之前将数据写入日志。
  • p​:Project ID。如果文件设置了这个属性,文件将被标记为与特定的项目ID相关联。
  • s​:Sequential access。如果文件设置了这个属性,文件系统会假设文件内容是顺序读取的,并可能优化读取操作。
  • S​:No synchronous updates。如果文件设置了这个属性,文件系统不会立即将数据写入磁盘,而是稍后写入。
  • t​:Set time stamp。如果文件设置了这个属性,文件系统会忽略时间戳的更改。
  • u​:Undeletable。如果文件设置了这个属性,文件不能被删除。
  • F​:No force deletion。如果文件设置了这个属性,文件系统在删除文件时不会强制删除。
  • x​:No execution。如果文件设置了这个属性,文件不能被执行。

请注意,并不是所有的文件系统都支持所有这些属性。例如,ext2和ext3文件系统不支持a​、c​、d​、i​、j​、p​、s​和u​属性,而ext4文件系统支持所有这些属性,除了F​和x​。

二、chattr 命令用法

格式:

chattr [选项] [+/-属性] 文件名

常用选项:

  • -R​:递归地处理目录及其内容。
  • -f​:强制执行操作,即使文件被设置为不可更改。
  • -v​:显示详细信息,指示发生的操作。

添加文件 i 属性

chattr +i file

移除文件 i 属性

chattr -i file

查看文件属性

lsattr filename

递归处理目录及其内容

chattr -R +i directory

强制执行操作

chattr -f +a filename

显示详细信息

chattr -v +s filename

三、chattr 实例

  1. 设置文件不可修改

    chattr +i file.txt
    

    这会使得file.txt​文件不可被修改、删除或重命名,即使是root用户也不例外。

  2. 移除文件的不可修改属性

    chattr -i file.txt
    

    这会移除file.txt​文件的不可修改属性,之后就可以正常编辑、删除或重命名文件了。

  3. 设置目录及其内容不可修改

    chattr -R +i /path/to/directory
    

    使用-R​递归选项,这会使得指定目录及其所有子文件和子目录都不可被修改。

  4. 仅允许添加文件到目录

    chattr +a /path/to/directory
    

    设置+a​属性后,用户只能向该目录添加文件,不能删除或重命名其中的文件。

  5. 防止修改文件内容但允许删除
    虽然没有直接的属性可以设置这个行为,但是可以通过组合使用+i​和+a​来实现。首先设置+a​属性,然后对文件设置+i​属性,这样文件内容不可修改,但可以通过删除文件的方式来移除文件。

  6. 保护系统关键文件

    chattr +i /etc/passwd
    chattr +i /etc/shadow
    

    保护密码文件不被非授权修改,增强系统安全性。

  7. 防止日志文件被意外清除

    chattr +a /var/log/messages
    

    设置+a​属性后,日志文件只能被追加内容,不能被清空或删除。

  8. 批量设置文件属性
    可以结合find​命令来批量设置文件属性,例如,设置所有.txt​文件为不可修改:

    find /path/to/search -type f -name "*.txt" -exec chattr +i {} \;
    
  9. 查看文件属性
    虽然不是chattr​的功能,但常与chattr​配合使用的lsattr​命令可以用来查看文件属性:

    lsattr file.txt
    

使用chattr​时需要注意,这个命令只适用于ext2、ext3和ext4文件系统。对于其他文件系统,如XFS、Btrfs等,chattr​可能不起作用或部分功能不可用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/795766.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

个人项目—论文查重

个人项目———论文查重这个作业属于哪个课程 计科12班这个作业的要求在哪里 作业要求这个作业的目标 实现论文查重,给定原文件和抄袭的文件,输出二者的相似度到答案文件中GitHub链接:github 1.题目要求 题目:论文查重 描述如下: 设计一个论文查重算法,给出一个原文文件和…

一款用于Redis漏洞的利用工具

Hack分享吧声明 该公众号分享的安全工具和项目均来源于网络,仅供安全研究与学习之用,如用于其他用途,由使用者承担全部法律及连带责任,与工具作者和本公众号无关。工具介绍 @yuyan-sec使用golang写的一款Redis漏洞利用工具。 注意:主从复制会清空数据,主从复制会清空数据…

AGC007F Shik and Copying String

涉及知识点:Ad-hoc,贪心 题意 Link 给出两个长度相同的字符串 \(S,T\),定义一次操作为: 从头至尾处理每一位,每位可以变成上一位,或者不变。 求最少对 \(S\) 进行多少次操作使得 \(S=T\)。 思路 引理 可以发现,一次操作其实类似于选择一些点 \(l\),从左到右覆盖它后面的…

全网最适合入门的面向对象编程教程:47 Python函数方法与接口-回调函数Callback

回调函数是编程中一种非常常见的模式,用于将函数作为参数传递给其他函数或方法。这种模式在 Python 中广泛应用于事件处理、异步编程、函数式编程等场景。全网最适合入门的面向对象编程教程:47 Python 函数方法与接口-回调函数 Callback摘要: 回调函数是编程中一种非常常见的…

如何把一个吃灰的 Kindle 设置成一个墨水屏幕的时钟 All In One

如何把一个吃灰的 Kindle 设置成一个墨水屏幕的时钟 All In One Kindle 电子书如何把一个吃灰的 Kindle 设置成一个墨水屏幕的时钟 All In OneKindle 电子书https://www.bilibili.com/video/BV1nY4y1e7gC/?t=375 demosKindle Paperwhite 7 电子书阅读器(4GB)Kindle Paperwhi…

基于小波神经网络的数据分类算法matlab仿真

1.程序功能描述 基于小波神经网络的数据分类算法。输入为5个特征值,输出为判断(是,否)。拿50组数据对本算法作为训练组,后30组数据作为验证组。这里,我们首先调用数据,然后对50组数据进行训练,然后对30组数据进行识别测试。 2.测试软件版本以及运行结果展示MATL…

基于GWO灰狼优化的CNN-LSTM的时间序列回归预测matlab仿真

1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a3.部分核心程序 (完整版代码包含详细中文注释和操作步骤视频)LR = Alpx(1); numHiddenUnits1 = floor(Alpx(2))+1;% 定义隐藏层中LSTM单元的数量 numHiddenUnits2 = floor(Alpx(3)…

代码整洁之道--读书笔记(8)

代码整洁之道简介: 本书是编程大师“Bob 大叔”40余年编程生涯的心得体会的总结,讲解要成为真正专业的程序员需要具备什么样的态度,需要遵循什么样的原则,需要采取什么样的行动。作者以自己以及身边的同事走过的弯路、犯过的错误为例,意在为后来者引路,助其职业生涯迈上更…

java学习9.11

IDEA里导入mybatis,lombok等依赖成功连接好数据库。 并将MYSQL数据库同时用navicat连接便利创建表等操作。设计实体类student并在数据库设计好表接下来就是如何实现在数据库里的增删改查 设计接口类mapper,将操作简化最后能正常运行实现功能。 总的来说这一块内容,刚开始学,…

LOJ4222 「IOI2024」马赛克上色 题解

题目描述 给定长为 \(n\) 、下标从零开始的 \(01\) 序列 \(x,y\) ,保证 \(x_0=y_0\) 。 令 \(col_{0,j}=x_j,col_{i,0}=y_i\) ,对 \(\forall 1\le i\lt n,1\le j\lt n\) , \(col_{i,j}=[col_{i-1,j}=0\and col_{i,j-1}=0]\) 。 \(q\) 次询问,给定 \(u,d,l,r\) ,求 \(\sum_…

2024 必收藏✨免费手机铃声下载网站大公开

最推荐的方式,当然是在线网站了。1.北岛铃声网 https://www.beidaols.cn/优点:免费下载:用户可以免费获取各种手机铃声,无需支付费用。 铃声多样:提供了丰富的铃声选择,满足不同用户的个性化需求。 教程详细:提供了详细的设置苹果铃声的教程,对于不熟悉苹果手机设置的…

原神蒙德-Typora模板

基于Newsprint主题开发的一种Typora模板新建模板 打开Typora - 文件 - 偏好设置 - 外观 - 打开主题文件夹 找到其中的 Newsprint (应该有一个文件夹+一个css,都要) ,拷贝副本,重命名(我命名的是“custom”),一定要这一步,不然后期更新的时候会覆盖 修改 打开其中的 cu…