0

0

Linux sticky bit 文件安全应用

冰川箭仙

冰川箭仙

发布时间:2026-02-24 18:21:41

|

788人浏览过

|

来源于php中文网

原创

sticky bit 是目录权限位(1000),启用后仅文件所有者、目录所有者或root可删除或重命名目录内文件,防止多用户共享时误删他人文件,需配合o+x才生效(显示为小写t),对nfs和容器挂载无效。

linux sticky bit 文件安全应用

sticky bit 是什么,为什么普通用户删不掉别人在共享目录里建的文件

Linux 的 sticky bit 本质是个权限位(1000),加在目录上后,只允许文件所有者、目录所有者或 root 删除或重命名该目录下的文件——哪怕别人对目录有 w 权限也不行。这不是“防误删”的装饰功能,而是解决多用户协作时最基础的信任问题。

常见错误现象:rm: cannot remove 'xxx': Operation not permitted,但 ls -ld /shared 显示目录权限是 drwxrwxrwx,让人误以为“明明全开了写权限”。其实缺的就是那个末尾的 t(如 drwxrwxrwt)。

  • 使用场景:/tmp、团队项目共享构建目录、CI 输出物暂存区这类多人可写但不可互删的路径
  • 设置命令必须用八进制:chmod 1777 /shared1 是 sticky bit,777 是常规权限);用符号法容易漏:chmod +t /shared 可以,但 chmod o+t /shared 才精准,避免意外改了其他位
  • 注意:对文件设 sticky bit 没有效果(内核忽略),只对目录有意义

如何确认 sticky bit 是否生效,以及它和 chmod o+t 的关系

别信 ls -l 看到的 t 就万事大吉——那个 t 出现在权限串最后,前提是其他权限已满足“others 可执行”(即 o+x)。如果目录被设成 chmod 1776 /sharedls 显示的是 T(大写),代表 sticky bit 已设但 o+x 缺失,此时它不生效。

Zen Cart
Zen Cart

Zen Cart是一款开源购物车系统,用于建立网上商店,源代码完全开放自由修改;功能强大,上千个免费插件;界面漂亮,大量免费模板;安全,十几万家在线商店应用。 Zen Cart v1.5.1 中文插件版包含以下内容预装15个免费模板图像管理模块 Image Handler多栏列表模块 Column Layout内置编辑器 CKEditor数据库备份模块 DB Backup快速更新模块 Quick

下载
  • 正确检查方式:stat /shared | grep "Access:.*[0-9]t$" 或直接看 ls -ld /shared 输出末位是否为小写 t
  • chmod o+tchmod 1777 效果等价,但前者更安全:它只翻转 sticky bit 位,不碰已有权限;后者会强制覆盖整个权限字,可能误关 x
  • 兼容性无坑:从 2.4 内核至今,所有主流发行版行为一致,无需考虑 glibc 版本

sticky bit 在 NFS 或容器挂载目录中是否还起作用

不起作用——这是最容易被忽略的硬限制。NFS 服务端若没配 nohide 或导出选项含 insecure,客户端挂载后 sticky bit 位会被丢弃;容器场景更典型:宿主机目录加了 sticky bit,但用 docker run -v /host/shared:/container/shared 挂进去后,ls -ld /container/shared 显示的是 drwxrwxrwx(无 t),且删除权限完全由容器内 UID/GID 决定。

  • NFS 方案:服务端 /etc/exports 中对应路径必须显式加 no_root_squash(不推荐)或确保客户端 UID 映射一致,否则 sticky bit 元数据根本传不过去
  • 容器方案:sticky bit 必须在容器内设置,例如启动时用 docker run --init -v /host/shared:/shared alpine chmod 1777 /shared;或者用 initContainer 在 k8s 中预处理
  • 性能影响:零。sticky bit 是 inode 层标记,不增加任何磁盘 I/O 或内存开销

为什么 /tmp 默认有 sticky bit,但你自己建的共享目录不能直接抄它的权限

/tmp 的 1777 是系统初始化脚本写的,但关键不在权限数字,而在它的属主和属组:root:root。如果你新建目录 chown nobody:nogroup /shared && chmod 1777 /shared,普通用户仍可能因 umask 或创建时继承问题绕过限制——比如用户用 touch /shared/file 创建文件后,文件属主是自己,但属组可能是 nogroup,这时同组其他人若对目录有 w 权限,就能删掉它(sticky bit 不拦组内删)。

  • 真正安全的共享目录要满足三个条件:目录属主为可信管理员(如 root 或专用服务账号)、属组为协作组(如 devteam)、权限为 1775(即 drwxrwsr-x + sticky)
  • 必须配合 setgid 位(2):chmod 2775 /shared 让新文件自动继承目录属组,再加 sticky bit 才形成闭环
  • 别依赖 umask:用户 shell 的 umask 002 只影响新建文件权限,不影响 sticky bit 生效逻辑

sticky bit 不是银弹。它只管“删/重命名”这一动作,对文件内容修改、读取、硬链接创建完全不管。真要防数据越界,得靠 SELinux 或 user namespaces 配合——但那是另一个问题了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

268

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

514

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

412

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

447

2024.04.08

Docker容器化部署与DevOps实践
Docker容器化部署与DevOps实践

本专题面向后端与运维开发者,系统讲解 Docker 容器化技术在实际项目中的应用。内容涵盖 Docker 镜像构建、容器运行机制、Docker Compose 多服务编排,以及在 DevOps 流程中的持续集成与持续部署实践。通过真实场景演示,帮助开发者实现应用的快速部署、环境一致性与运维自动化。

24

2026.02.11

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1541

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

715

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

300

2023.06.30

Golang 生态工具与框架:扩展开发能力
Golang 生态工具与框架:扩展开发能力

《Golang 生态工具与框架》系统梳理 Go 语言在实际工程中的主流工具链与框架选型思路,涵盖 Web 框架、RPC 通信、依赖管理、测试工具、代码生成与项目结构设计等内容。通过真实项目场景解析不同工具的适用边界与组合方式,帮助开发者构建高效、可维护的 Go 工程体系,并提升团队协作与交付效率。

1

2026.02.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 9.6万人学习

Git 教程
Git 教程

共21课时 | 3.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号