Linux下的chattr和lsattr命令

今天移植web程序时,发现的命令。记录

Linux下的chattr和lsattr命令

文件的隐藏属性

在Linux下我们可以用stat命令查看文件的相关属性信息,除了这些属性之外,Linux下的文件还有一些隐藏的属性,我们可以用lsattr命令来查看:

[root@VM_117_84_centos test]# lsattr 1.txt 
-----a--------- 1.txt

上面这条命令的输出表示1.txt文件具有扩展属性  a ,即append,设定该参数后,只能向文件中添加数据,而不能删除,多用于服务器日志文件安全,只有root才能设定这个属性。显然,将那些只允许增长但不允许修改和删除的文件设置为这样的隐藏属性是非常有利于保护数据安全的。

chattr

chattr命令可以改变一个文件的隐藏属性。其语法格式为:

chattr [ -RVf ] [ -v version ] [ mode ] files…

下面给出几个选项的含义:

选项含义
-R递归更改目录下所有子目录和文件的属性
-V显示详细信息
-f忽略大部分错误信息
-v version设置文件的档案号码
mode设置文件的隐藏属性,其格式为+-=[acdeijstuACDST]

最关键的是在[mode]部分,[mode]部分的格式是+-=[acdeijstuACDST],这部分是用来设置文件的属性。其中+表示在原有参数设定基础上追加参数;-表示在原有参数设定基础上移除参数;=表示更新为指定参数。下面列出几个常用的属性参数的含义:

属性含义
A文件的atime(access time)不可被修改,这样可以减少磁盘I/O数量,对于笔记本电脑有利于提高续航能力
S硬盘I/O同步选项,功能类似sync
a即append,设定该参数后,只能向文件中添加数据,而不能删除,多用于服务器日志文件安全,只有root才能设定这个属性
i文件不能被删除、改名、设定链接关系,同时不能写入或新增内容(即使是root用户)。只有root才能设定这个属性
c即compresse,文件会自动的经压缩后再存储,读取时会自动的解压
d即no dump,设定文件不能成为dump程序的备份目标
j即journal,设定此参数使得当通过mount参数”data=ordered”或”data=writeback”挂载的文件系统,文件在写入时会先被记录(在journal中)。如果filesystem被设定参数为data=journal,则该参数自动失效
s即secure,保密选项。设置了s属性的文件在被删除时,其所有数据块会被写入0
u即undelete,反删除选项。与s相反,文件在被删除时,其所有的数据块都保留着,用户今后可以恢复该文件
例如这条命令,可以将1.txt文件设置为不允许任何人修改:
chattr =a 1.txt

lsattr

lsattr命令列出文件的隐藏属性。其语法格式为:

lsattr [ -RVadv ] [ files… ]

选项含义
-R递归显示目录下所有子目录和文件的属性
-V显示lsattr程序的版本信息
-a显示所有文件的属性信息,包括以.开头的文件
-d显示目录的属性,而不是目录下的文件的属性
-v显示文件的档案号码

例如,下面这条命令显示MySecretDir目录的隐藏属性:

[root@VM_117_84_centos test]# lsattr 1.txt 
-----a--------- 1.txt

转载地址:https://blog.csdn.net/sailor201211/article/details/53215060



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章