Making Files Immutable
Because the root user can override permissions, file permissions alone are not enough to ensure that a file will not be changed. But when a file is made immutable, it cannot be changed by anyone.
How Do I Do That?
To make a file immutable, use the
chattr (change attribute) command to add the i attribute to the file:
#chattr +i#foodate >>foo#bash: foo: Permission deniedmvmv: cannot move \Qfoo' to \Qbaz': Operation not permitted #foo bazrmrm: cannot remove \Qfoo': Operation not permittedfoo
You can find out if the i attribute has been set by using the
lsattr (list-attribute) command:
#lsattr----i-------- foofoo
The presence of the i in the output indicates that the file foo has been made immutable.
Removing the i attribute causes the file to act normally again:
#chattr -i#foodate#>>foomv#foo bazrm#bazls bazls: baz: No such file or directory
How Does It Work?
The immutable capability is provided by the ext2/ext3 filesystems. Each file has an immutable flag that is part of the ext2/ext3 file attributes; when set, the ext2/ext3 code in the kernel will refuse to change the ownership, group, name, or permissions of the file, and will not permit writing, appending, or truncation of the file.
By making configuration files and programs immutable, you can provide a small measure of protection against change. This can be used to guard against accidental changes to configuration files. It can also prevent a program ...