Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

Sticky bit

From Wikipedia, the free encyclopedia
UNIX file system permission
This article is about the filesystem concept. For the technique in floating-point arithmetic, seeFloating point § Addition and subtraction.

Incomputing, thesticky bit is a user ownershipaccess rightflag that can be assigned tofiles anddirectories onUnix-like systems.

There are two definitions: one for files, and one for directories.

For files, particularly executables, the superuser could tag these as to be retained in main memory, even when their need ends, to minimize swapping that would occur when another need arises, and the file now has to be reloaded from relatively slow secondary memory.[1] This function has become obsolete due to swapping optimization.

For directories, when a directory's sticky bit is set, the filesystem treats the files in such directories in a special way so only the file's owner, the directory's owner, orroot user can rename or delete the file. Without the sticky bit set, any user with write and execute permissions for the directory can rename or delete contained files, regardless of the file's owner. Typically this is set on the/tmp directory to prevent ordinary users from deleting or moving other users' files.

The modern function of the sticky bit refers to directories, and protects directories and their content from being hijacked by non-owners; this is found in most modern Unix-like systems. Files in a shared directory such as/tmp belong to individual owners, and non-owners may not delete, overwrite or rename them.

History

[edit]

The sticky bit was introduced in the Fifth Edition ofUnix (in 1974) for use with pure executablefiles.[2] When set, it instructed theoperating system to retain thetext segment of the program inswap space after theprocess exited. This speeds up subsequent executions by allowing the kernel to make a single operation of moving the program from swap to real memory. Thus, frequently-used programs like editors would load noticeably faster. One notable problem with "stickied" programs was replacing the executable (for instance, duringpatching); to do so required removing the sticky bit from the executable, executing the program and exiting to flush the cache, replacing the binary executable, and then restoring the sticky bit.

Subsequently, this behavior became operative only inHP-UX andUnixWare.Solaris appears to have abandoned this in 2005.[citation needed] The 4.4-Lite release ofBSD retained the old sticky bit behavior, but it has been subsequently dropped fromOpenBSD (as of release 3.7) andFreeBSD (as of release 2.2.1). No version ofLinux has ever supported this traditional behavior; Linux performs caching of executable files in the same way as all files, so re-executing the program to flush the cache is not necessary.[clarification needed]

Usage

[edit]

The most common modern use of the sticky bit is ondirectories residing within filesystems forUnix-like operating systems. When a directory's sticky bit is set, the filesystem treats the files in such directories in a special way so only the file's owner, the directory's owner, orroot can rename or delete the file. Without the sticky bit set, any user with write and execute permissions for the directory can rename or delete contained files, regardless of the file's owner. Typically, this is set on the/tmp directory to prevent ordinary users from deleting or moving other users' files. This feature was introduced in 4.3BSD in 1986, and today it is found in most modern Unix-like systems.

In addition, Solaris (as of Solaris 2.5) defines special behavior when the sticky bit is set on non-executablefiles: those files, when accessed, will not becached by thekernel. This is usually set onswap files to prevent access on the file from flushing more important data from the system cache. It is also used occasionally forbenchmarking tests.[citation needed]

The sticky bit is also set by theautomounter to indicate that a file has not been mounted yet. This allows programs likels to ignore unmounted remote files.

Excerpts fromman pages about the sticky bit's effect on directories and files
Operating SystemDirectoriesFiles
AIX 5.2[3]indicates that only file owners can link or unlink files in the specified directory.sets the save-text attribute.
Solaris 11[4]If a directory is writable and has S_ISVTX (the sticky bit) set, files within that directory can be removed or renamed only if one or more of the following is true (see unlink(2) and rename(2)): the user owns the file, the user owns the directory, the file is writable by the user, the user is a privileged user.If a regular file is not executable and has S_ISVTX set, the file is assumed to be a swap file. In this case, the system's page cache will not be used to hold the file's data. If [...] set on any other file, the results are unspecified.
HP-UX[5]If [...] set on a directory, an unprivileged user cannot delete or rename others' files in that directory.[...] prevents the system from abandoning the swap-space image of the program-text portion of the file when its last user terminates. Then, when the next user of the file executes it, the text need not be read from the file system but can simply be swapped in, thus saving time.
Linux[6][7]When [...] set on a directory, files in that directory may only be unlinked or renamed by root or the directory owner or the file owner. The fs.protected_fifos, fs.protected_regular, and fs.protected_symlinkssysctls further restrict the creation of FIFOs, creation of regular files, and the following of symlinks respectively within directories with the sticky bit set.the Linux kernel ignores the sticky bit on files.
FreeBSD[8]If [...] set on a directory, an unprivileged user may not delete or rename files of other users in that directory.The FreeBSD VM system totally ignores the sticky bit (S_ISVTX) for executables.
IRIX[9]If [...] set on a directory, then any files created in that directory will take on the group ID of the directory rather than the group ID of the calling process. mount(1M) may be used to enable this feature regardless of the mode of the directory.If the sticky bit, S_ISVTX, is set on a file that is a dynamic loader for an ELF executable, then when the executable is exec'ed the old process's read only address spaces will be made available to the dynamic loader in the new process. This can improve program start up time considerably. The setting of the sticky bit on any other file has no effect.
Mac OS X (Leopard)[10]A directory whose 'sticky bit' is set becomes an append-only directory [...] in which the deletion of files is restricted. A file in a sticky directory may only be removed or renamed by a user if the user has write permission for the directory and the user is the owner of the file, the owner of the directory, or the super-user. This feature is usefully applied to directories such as /tmp which must be publicly writable but should deny users the license to arbitrarily delete or rename each other's files. Any user may create a sticky directory.The sticky bit has no effect on executable files. All optimisation on whether text images remain resident in memory is handled by the kernel's virtual memory system.
NetBSD[11]A directory whose "sticky bit" is set becomes a directory in which the deletion of files is restricted. A file in a sticky directory may only be removed or renamed by a user if the user has write permission for the directory and the user is the owner of the file, the owner of the directory, or the super-user. This feature is usefully applied to directories such as /tmp which must be publicly writable but should deny users the license to arbitrarily delete or rename each other's files.NetBSD does not currently treat regular files that have the sticky bit set specially, but this behavior might change in the future.
OpenBSD[12]A directory with the "sticky bit" set places restrictions on file deletion: a file in a sticky directory may only be removed or renamed by a user if the user has write permission for the directory and the user is the owner of the file, the owner of the directory, or the superuser. This feature is usefully applied to directories such as /tmp which must be publicly writable but should deny users the license to arbitrarily delete or rename each other's files.

Any user may create a sticky directory. See chmod(1) for details about modifying file modes.

Historically, an executable shareable file which had the sticky bit set was not immediately discarded from swap space after execution. The kernel hoarded the text segment of the file for future reuse, thus avoiding having to reload the program. This is no longer true on modern systems; the current virtual memory system keeps track of recently used executables, making the sticky bit for files redundant. The sticky bit can still be set on files, but without any effect.

Only the superuser can set the sticky bit on a file, though the owner of the file may clear the sticky bit.

SCO UnixWare[13]If a directory is writable and the sticky bit,S_ISVTX, is set on the directory, a process may remove or rename files within that directory only if one or more of the following is true:
  • the effective user ID of the process is the same as that of the owner ID of the file
  • the effective user ID of the process is the same as that of the owner ID of the directory
  • the process has write permission for the file
  • the process has theP_OWNER privilege
If a 0410a.out executable file has the sticky bit (mode bit 01000) set, the operating system will not delete the program text from the swap area when the last user process terminates. If a 0413 a.out or ELF executable file has the sticky bit set, the operating system will not delete the program text from memory when the last user process terminates. In either case, if the sticky bit is set the text will already be available (either in a swap area or in memory) when the next user of the file executes it, thus making execution faster.

Examples

[edit]

The sticky bit can be set using thechmod command and can be set using its octal mode 1000 or by its symbolt (s is already used by thesetuid bit). For example, to add the bit on the directory/usr/local/tmp, one would typechmod +t /usr/local/tmp. Or, to make sure that directory has standardtmp permissions, one could also typechmod 1777 /usr/local/tmp.

To clear it, usechmod -t /usr/local/tmp orchmod 0777 /usr/local/tmp (the latter will also reset thetmp directory to standard permissions).

In Unixsymbolic file system permission notation, the sticky bit is represented either by the lettert orT in the final character-place depending on whether the execution bit for theothers category is set or unset, respectively. For instance, on Solaris 8, the/tmp directory, which by default has both theothers execute bit and the sticky-bit set, shows up as:

$ls-ld/tmpdrwxrwxrwt   4 root     sys          485 Nov 10 06:01 /tmp

If the sticky-bit is set on a file or directory without the execution bit set for theothers category (non-user-owner and non-group-owner), it is indicated with a capitalT (replacing what would otherwise be-):

#ls-ltest-rw-r--r--   1 root     anygroup          0 Nov 10 12:57 test#chmod+ttest;ls-ltest-rw-r--r-T   1 root     anygroup          0 Nov 10 12:57 test

See also

[edit]

References

[edit]
  1. ^Zintz, Walter (February 1984). "The Unix Connection: What is a sticky bit?".HARDCOPY. p. 130.
  2. ^Steinhauser, Martin Oliver (2012).Computer Simulation in Physics and Engineering. De Gruyter.ISBN 978-3-1102-5590-4.
  3. ^"Archived copy of chmod man page under AIX 5.2". Retrieved2009-01-19.{{cite web}}:|archive-url= is malformed: timestamp (help)CS1 maint: url-status (link)
  4. ^"Synopsis - man pages section 2: System Calls". Docs.oracle.com. 2011-11-01. Retrieved2014-04-10.
  5. ^"HPUX chmod[2]". Archived from the original on November 20, 2007. RetrievedFebruary 29, 2008.{{cite web}}: CS1 maint: bot: original URL status unknown (link)
  6. ^"chmod(1) - Linux manual page". Man7.org. Retrieved2014-04-10.
  7. ^"proc(5) - Linux manual page". Man7.org. Retrieved2022-03-04.
  8. ^"chmod - FreeBSD". Nixdoc.net. 1993-06-04. Retrieved2014-04-10.
  9. ^"chmod - IRIX/standard/". Nixdoc.net. Retrieved2014-04-10.
  10. ^"Mac Developer Library". Developer.apple.com. Retrieved2014-04-10.
  11. ^"sticky.7 - NetBSD Manual Pages". Netbsd.gw.com. 2021-05-16. Retrieved2021-05-16.
  12. ^"Manual Pages: sticky". Openbsd.org. 2014-02-14. Retrieved2018-02-04.
  13. ^"chmod(2)". Uw714doc.sco.com. 2004-04-25. Retrieved2014-04-10.

External links

[edit]
Retrieved from "https://en.wikipedia.org/w/index.php?title=Sticky_bit&oldid=1295145605"
Categories:
Hidden categories:

[8]ページ先頭

©2009-2026 Movatter.jp