Linux 中 Sticky Bit 的用途
粘性位是文件或目录上的权限位,仅允许文件/目录所有者或 root 用户删除或重命名文件。其他用户不能删除其他用户生成的文件。
Linux 中的 Sticky Bit 简介
粘性位是类 Unix 系统自己的访问权限标志,可以赋予文件和目录。
有两种不同的定义:一种用于文件,另一种用于目录。
超级用户可以将文件(尤其是可执行文件)标记为保留在主内存中,即使它们的使用已经结束,以避免发生其他需求时发生的交换。
该文件必须从相对较慢的辅助内存中重新加载。由于 swap 优化,这个功能已经没用了。
当设置了目录的粘性位时,文件系统会以不同的方式处理该目录中的文件,只允许文件的所有者、目录的所有者或 root 用户重命名或删除文件。
如果没有设置粘性位,任何用户写入和执行对目录的访问都可以重命名或删除其内容,而不管文件的所有者如何。
这通常放在 /tmp
目录中,以防止普通用户删除或传输属于其他用户的文件。
Linux 中 Sticky Bit 的历史
在 Unix 第五版(1974 年)中,引入了粘性位以用于纯可执行文件。设置后,它告诉操作系统在操作完成后将程序的文本段保留在交换空间中。
这通过允许内核在单个操作中将应用程序从交换内存移动到实际内存来加速后续执行。
因此,常用程序(例如编辑器)的加载速度会大大提高。
更改 stickied
程序中的可执行文件需要从可执行文件中删除粘性位,运行程序并退出以清除缓存,替换二进制可执行文件并恢复粘性位。
Linux 中的粘滞位示例
使用一些示例,我们将在本节中介绍如何设置和取消设置 sticky bits
。
创建一个目录并授予所有用户读
、写
和执行权限
:
$ mkdir thanos
结果,创建了一个名为 thanos
的目录。
$ mkdir chmod 777 thanos/
使用 chmod
命令为所有用户授予 read-write-execute
访问权限。
在此目录中创建多个具有不同用户的文件,以读取、写入和执行文件。
$ ls -ld thanos/
输出:
drwxrwxrwx 2 user user 4096 Feb 2 14:05 thanos/
使用 chmod
命令的 +t
标志,启用目录上的粘性位。
$ chmod +t thanos/
$ ls -ld thanos/
输出:
drwxrwxrwt 2 user user 4096 Feb 2 14:05 thanos/
可以看出,权限位 t
添加到目录的权限位。Sticky bits
在每个操作系统中的功能都不同。
相关文章
如何在 CentOS 中获取 IP 地址
发布时间:2023/05/04 浏览次数:108 分类:操作系统
-
这篇简短的文章是对 CentOS 的一个简短介绍,然后简要讨论了我们如何使用命令行界面 (CLI) 在 CentOS 中获取服务器 IP 地址。
在 Linux 中更新 YUM
发布时间:2023/05/04 浏览次数:82 分类:操作系统
-
本文介绍了 Linux 中的 yum update 命令。本文将教我们如何在 Linux 中更新 YUM,以及如何在 Linux 系统上安装、更新、删除、查找和管理包。
在 Linux 中安装 Deb 文件
发布时间:2023/05/04 浏览次数:130 分类:操作系统
-
本文介绍如何在 Linux 中安装 deb 文件。在这篇 Linux 文章中,我们将学习如何在 Linux 系统上安装 .deb(Debian 软件包)文件。 我们还将看到如何在安装后删除 .deb 文件。
Linux 中的 lsof 命令
发布时间:2023/05/04 浏览次数:82 分类:操作系统
-
在这篇 Linux 文章中,我们将了解 Linux 操作系统中的 lsof 命令。 我们将看到如何在 Linux 中将此命令用于不同目的。
Linux 解决不能执行二进制文件问题
发布时间:2023/05/04 浏览次数:187 分类:操作系统
-
在本文中,我们将学习如何在 Linux 中执行二进制文件。 如果 Linux 无法执行二进制文件,我们还将学习如何解决错误。
Linux 中错误 Mesg: Ttyname Failed: Inappropriate Ioctl for Device Error
发布时间:2023/05/04 浏览次数:145 分类:操作系统
-
本文介绍如何在 Linux 中解决 mesg: ttyname failed: inappropriate ioctl for device 错误。在 Linux 中,这个错误是由于默认的 vagrant 配置 config.ssh.shell 与 bash -l 交互导致的。
Linux 中的 ps aux 命令
发布时间:2023/05/04 浏览次数:69 分类:操作系统
-
本篇文章将讨论 Linux 中的 ps aux 命令。如果将 aux 快捷方式与 ps 命令一起使用,它将显示用户需要的最多信息,并可以为您提供系统运行进程的当前状态。
Linux 中的 NTP
发布时间:2023/05/04 浏览次数:137 分类:操作系统
-
本篇文章将讨论 Linux 中的 ntp。NTP 是大多数 IT 基础设施使用的核心协议。 使用它的目的是同步日期和时间信息。
在 Bash 中创建进度条
发布时间:2023/05/04 浏览次数:164 分类:操作系统
-
这是有关在 Bash 中创建进度条以显示正在运行的命令或进程的进度的指南。本文将探讨在 Bash(Linux 和 macOS 的默认 shell)中向 shell 脚本添加进度条的几种方法。使用 pv 命令在 Bash 中创建进度条