Professional Documents
Culture Documents
Contents
In GNU/Linux systems (chattr and lsattr)
File system support
chattr description
lsattr description
Attributes
Notes
In BSD-like systems (chflags)
File system support
chflags description
Displaying
Attributes
See also
Notes
References
The command line tools chattr (to manipulate attributes) and lsattr (to list attributes) were originally
specific to the Second Extended Filesystem family (ext2, ext3, ext4), and are available as part of the e2fsprogs
package.
However, the functionality has since been extended, fully or partially, to many other systems, including XFS,
ReiserFS, JFS and OCFS2. The btrfs file system includes the attribute functionality, including the C flag,
which turns off the built-in copy-on-write (CoW) feature of btrfs due to slower performance associated with
CoW.
chattr description
lsattr description
Attributes
lsattr
Attribute chattr option Semantics and rationale
flag
No atime +A to set When a file with the A attribute set is accessed, its atime
A record is not modified.
updates -A to clear
This avoids a certain amount of disk I/O operations.
+a to set
Append only a A file with the a attribute set can only be open in append mode
-a to clear[note 1] for writing.
+d to set A file with the d attribute set is not candidate for backup when
No dump d
-d to clear the dump program is run.
Extent format e (unavailable) The e attribute indicates that the file is using extents for
mapping the blocks on disk.
Data j +j to set
journaling -j to clear[note 4] A file with the j attribute has all of its data written to the ext3
journal before being written to the file itself, if the filesystem is
mounted with the "data=ordered" or "data=writeback"
options.
When the filesystem is mounted with the "data=journal"
option all file data is already journaled, so this attribute has no
effect.
+s to set
Secure When a file with the s attribute set is deleted, its blocks are
s -s to
deletion zeroed and written back to the disk.
clear[note 2][note 5]
When a file with the S attribute set is modified, the changes are
Synchronous +S to set written synchronously on the disk; this is equivalent to the 'sync'
S mount option applied to a subset of the files.
updates -S to clear
This is equivalent to the sync mount option, applied to a subset
of the files.
+u to set When a file with the u attribute set is deleted, its contents are
Undeletable u saved.
-u to clear[note 2]
This allows the user to ask for its undeletion.
Version /
generation -v -v version File's version/generation number.
number
Notes
1. Only the superuser or a process possessing the CAP_LINUX_IMMUTABLE capability can set
or clear these attributes.
2. These attributes are not honored by the ext2 and ext3 filesystems as implemented in the
current mainline Linux kernels.
3. These attributes only make sense for Copy-on-Write file-systems such as btrfs.
4. Only the superuser or a process possessing the CAP_SYS_RESOURCE capability can set or
clear this attribute.
5. This attribute is not honored by the ext4 filesystem as implemented in the current mainline
Linux kernels as reported in Bug #17872 (https://bugzilla.kernel.org/show_bug.cgi?id=17872).
The chflags command is not specific to particular file systems. UFS on BSD systems, and APFS, HFS+,
SMB, AFP, and FAT on macOS support least some flags.
chflags description
-H If the -R option is specified, symbolic links on the command line are followed. (Symbolic
links encountered in the tree traversal are not followed.)
-L If the -R option is specified, all symbolic links are followed.
-P If the -R option is specified, no symbolic links are followed. This is the default.
-R Change the file flags for the file hierarchies rooted in the files instead of just the files
themselves.
Displaying
BSD-like systems, in general, have no default user-level command specifically meant to display the flags of a
file. The ls command will do with either the -lo, or the -lO, depending on the system, flags passed.
Attributes
All traditional attributes can be set or cleared by the super-user; some can also be set or cleared by the owner
of the file. Some attributes include:
File attributes
chflags Owner- OS
Attribute ls flag Semantics and rationale
flag settable support
arch,
Archived arch No All File is archived
archived
schg,
System File cannot be changed, renamed, moved,
schg schange, No All
immutable or removed
simmutable
uchg,
User File cannot be changed, renamed, moved,
uchg uchange, Yes All
immutable or removed
uimmutable
Tracked tracked tracked Yes macOS File modifications and deletions are tracked
BSD systems offer additional flags like offline, snapshot, sparse,[4] and uarchive; see References.
See also
ATTRIB – analogous command in MS-DOS, OS/2 and Microsoft Windows
chown – change file/directory ownership in a Unix system
chmod – change file access control attributes in a Unix system
cacls – change file access control lists in Microsoft Windows NT
Notes
1. chmod(1) (http://schillix.org/opensolarisman/man1/chmod.1.html) –
illumos and OpenSolaris User Commands Reference Manual from latest Sun based
OpenSolaris
2. ls(1) (http://schillix.org/opensolarisman/man1/ls.1.html) – illumos and
OpenSolaris User Commands Reference Manual from latest Sun based OpenSolaris
3. chflags(1) (https://man.openbsd.org/chflags.1) – OpenBSD General
Commands Manual
4. Different from the APFS sparse files on macOS (https://developer.apple.com/documentation/fo
undation/file_system/about_apple_file_system), which have no special flags.
References
chattr(1) (https://linux.die.net/man/1/chattr) – Linux User Commands
Manual
lsattr(1) (https://linux.die.net/man/1/lsattr) – Linux User Commands
Manual
chflags(1) (https://man.openbsd.org/chflags.1) – OpenBSD General
Commands Manual
chflags(1) (https://www.freebsd.org/cgi/man.cgi?query=chflags&sekti
on=1) – FreeBSD General Commands Manual
chflags(1) (http://netbsd.gw.com/cgi-bin/man-cgi?chflags+1+NetBSD-c
urrent) – NetBSD General Commands Manual
chflags(1) (https://www.unix.com/man-page/mojave/1/chflags) – Darwin
and macOS General Commands Manual (outdated; see newer version (https://www.unix.com/
man-page/osx/1/chflags/))
stat.h (https://github.com/apple/darwin-xnu/blob/master/bsd/sys/stat.h#L466-L519) (flags
section in the BSD system source code of the macOS XNU kernel)
Text is available under the Creative Commons Attribution-ShareAlike License; additional terms may apply. By using this
site, you agree to the Terms of Use and Privacy Policy. Wikipedia® is a registered trademark of the Wikimedia
Foundation, Inc., a non-profit organization.