Restrict file access to append only
Solution 1
The chattr
utility is written for ext2/ext3/ext4 filesystems. It emits ioctls on the files, so it's up to the underlying filesystem to decide what to do with them. The XFS driver in newer Linux kernels supports the same FS_IOC_SETFLAGS
ioctl as ext[234] to control flags such as append-only, but you may be running an older kernel where it doesn't (CentOS?). Try using the xfs_io
utility instead:
echo chattr +a | xfs_io test.log
Note that, for XFS like for ext[234], only root can change the append-only flag (more precisely, you need the CAP_LINUX_IMMUTABLE
capability).
Solution 2
Do you have permissions to do that? From man 1 chattr
:
A file with the `a' attribute set can only be open in append mode for writing. Only the superuser or a process possessing the CAP_LINUX_IMMUTABLE capability can set or clear this attribute.
Related videos on Youtube
metalhead
Updated on September 18, 2022Comments
-
metalhead over 1 year
I have a directory with log files and I'm putting logs from script launched by users into them. Logging with syslog doesn't seem possible in this case. (non-daemon rsync)
I want the users to have only write permissions on log files. The problem is, that write permissions must be further restricted, so that users (script) can only append to that files. The underlying filesystem is XFS.
The following doesn't work:
# chattr +a test.log chattr: Inappropriate ioctl for device while reading flags on test.log
Is there any other solution for this? Thank you for your hints.
-
Stéphane Chazelas over 11 yearsAre you sure it's XFS?
chattr +a
works for me here (3.2 kernel). Note that you need to be root to usechattr
(a$
prompt suggests non-superuser), though you'd get a different error message ifchattr +a
was supported and you were not root. -
Gilles 'SO- stop being evil' over 11 years
-
Gert van den Berg over 11 yearsWhat is the mount options on the partition? It might possibly store it using xattr, which might need the relevant mount option? (The socumentation for XFS don't mention much about it either...)
-
Michael Mrozek over 11 yearsThis closed on SF, so I'm leaving it open here
-