Linux中的SUID、SGID和Sticky Bit详解

SUID、SGID和Sticky Bit是Linux特殊权限,分别用于以文件所有者身份执行、继承组权限及限制删除文件。SUID用4000表示,如chmod 4755;SGID用2000,可作用于文件和目录;Sticky Bit用1000,常用于/tmp等共享目录。三者可通过数字或符号方式设置,组合使用时需谨慎以防安全风险。

linux中的suid、sgid和sticky bit详解

在Linux系统中,文件和目录的权限管理非常关键。除了常见的读(r)、写(w)、执行(x)权限外,还有三种特殊权限位:SUID、SGID 和 Sticky Bit。它们用于实现更精细的安全控制和功能需求。下面详细介绍这三个特殊权限的作用、使用场景及设置方法。

SUID(Set User ID)

作用:SUID 仅对可执行文件有效。当一个文件设置了 SUID 权限时,任何用户在执行该文件时,都会以该文件所有者的身份运行,而不是以执行者自己的身份。

这在需要临时提升权限的场景中非常有用。例如,普通用户需要修改密码,而密码信息保存在 /etc/shadow 文件中,默认只有 root 可写。passwd 命令就设置了 SUID,使得普通用户执行时能以 root 身份写入 shadow 文件。

如何识别与设置:

在 ls -l 输出中,SUID 显示为所有者权限的 x 位变为 s(如果原位置有执行权限)或 S(无执行权限)。 例如:-rwsr-xr-x 1 root root 表示设置了 SUID。 用数字表示时,SUID 是 4000。设置命令:chmod 4755 filenamechmod u+s filename

SGID(Set Group ID)

作用:SGID 可作用于文件和目录。

对于文件:执行该文件时,进程将继承文件所属组的身份。类似于 SUID,但针对的是用户组。 对于目录:在此目录中创建的新文件将自动继承目录的属组,而不是创建者的主组。这对团队协作非常有用,确保多个用户创建的文件属于同一组,便于共享。

如何识别与设置:

ls -l 中,SGID 显示为所属组权限的 x 位变为 s(有执行权限)或 S(无执行权限)。 例如:-rwxr-sr-x 1 user team 表示设置了 SGID。 数字表示为 2000。设置命令:chmod 2755 dirnamechmod g+s dirname

Sticky Bit(粘滞位)

作用:Sticky Bit 主要用于目录。一旦目录设置了粘滞位,只有文件的所有者、目录所有者或 root 用户才能删除或重命名该目录中的文件。

典型应用是 /tmp 目录。所有用户都可以在 /tmp 中创建文件,但不能删除别人创建的文件,防止误删或恶意操作。

如何识别与设置:

ls -l 中,其他用户权限的 x 位变为 t(有执行权限)或 T(无执行权限)。 例如:drwxrwxrwt 2 root root 表示设置了 Sticky Bit。 数字表示为 1000。设置命令:chmod 1777 /tmpchmod +t /tmp

这三个特殊权限可以组合使用,如 4755(SUID)、2755(SGID)、1777(Sticky Bit),甚至同时设置多个,如 7777 表示三项都启用(不推荐生产环境使用)。

基本上就这些。理解 SUID、SGID 和 Sticky Bit 的作用,有助于更好地管理 Linux 系统权限,既满足功能需求,又避免安全风险。注意:滥用这些权限可能带来安全隐患,应只在必要时谨慎使用。

以上就是Linux中的SUID、SGID和Sticky Bit详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/4390.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 00:21:39
下一篇 2025年11月3日 00:48:06

相关推荐

  • linux上安装docker容器和mysql镜像拉取的方法

    docker pull xxxx 拉取镜像 docker run -it xxxx /bin/bash 启动镜像 启动docker服务 docker ps 查询运行中的容器 docker ps -a 查询所有容器,包括未运行的 mysql容器启动:docker run -itd –nam…

    数据库 2025年12月5日
    000
  • linux运维之ftp服务器功能介绍

    ftp作为最古老的协议之一,目前还没广泛使用者,它主要用作服务器与客户机之间文件的传输。ftp协议是使用明文传输协议的,所有具有一定的安全隐患。linux系统上有一个vsftpd软件,这个软件虽然功能不多,但重点是比较安全,建议大家使用该软件来作为ftp文件传输服务器。除此之外,用的也比较多的是pu…

    运维 2025年12月5日
    100
  • 如何查看系统版本号信息(一步步教你轻松获取系统版本号信息)

    你在苦恼如何查看操作系统的版本号吗?了解版本号对于确定系统更新或软件兼容性至关重要。本文将提供分步指南,帮助你轻松获取这些信息。无论你是 windows、macos 还是 linux 用户,都能在这里找到适用于你的方法。跟着 php小编百草的详细说明,你将轻松掌握如何查看系统版本号,从而帮助你管理你…

    2025年12月5日
    000
  • PHP move_uploaded_file 失败:权限问题解析与解决方案

    本文详细解析了PHP中使用move_uploaded_file函数上传文件时,因Permission denied错误导致文件保存失败的常见问题。教程将深入探讨该错误的根本原因——目标目录的写入权限不足,并提供了针对Linux/Unix系统下文件权限配置的实用解决方案,确保PHP文件上传功能稳定运行…

    2025年12月5日
    000
  • 免费网络播放器推荐大全(为你找到最适合的播放器)

    在互联网的时代,海量的娱乐内容唾手可得,但如何畅快欣赏这些内容呢?随着互联网技术的飞速发展,我们可以在网络上轻松找到各种类型的音乐、剧集和视频,甚至电影。这个时候,一个好用且功能强大的网络播放器就变得必不可少了。然而,市面上琳琅满目的播放器让人眼花缭乱,不知如何选择。本篇文章将为你推荐一些免费且功能…

    2025年12月5日
    000
  • Linux怎样查看mysql密码

    相信很多小伙伴都经历过忘记密码,如果在Linux下忘记MySQL密码该怎么办? Linux查看mysql密码具体方法。 查看默认密码 grep ‘temporary password’ /var/log/mysqld.log 或者 cat /var/log/mysqld.log | grep ‘te…

    数据库 2025年12月5日
    000
  • 详解Linux的用户空间与内核空间

    推荐:《linux视频教程》 一. 简介 Linux 操作系统和驱动程序运行在内核空间,应用程序运行在用户空间。两者不能简单地使用指针传递数据,因为Linux使用的虚拟内存机制,用户空间的数据可能被换出,当内核空间使用用户空间指针时,对应的数据可能不在内存中。用户空间的内存映射采用段页式,而内核空间…

    2025年12月5日 运维
    000
  • linux系统下fcntl函数解析与标准IO函数介绍

    —–今天是最后一篇文章关于linux系统下文件io操作了,从明天起开始写文件属性的文章了,欢迎大家来学习,一起进步。(同时也欢迎大家批评指出错误,我会及时纠正过来的)。 一、fcntl函数解析: 1、函数原型:先用man手册来查看fcntl的用法和原型: int fcntl(…

    2025年12月5日 运维
    000
  • linux如何统计文件个数

    linux统计文件个数的方法:1、查看路径下文件的个数,代码为【ls -l |grep “^-“|wc -l】;2、查看路径下文件夹的个数,代码为【ls -l |grep “^d”|wc -l】。 本教程操作环境:windows7系统、linux7.3…

    2025年12月5日
    000
  • linux find命令的用法有哪些

    linux find命令的用法有:1、【find -name】直接根据文件名字来查找;2、【find -perm】根据文件权限来查找;3、【find -mtine -n(+n)】根据文件的更改时间来查找。 相关学习推荐:linux视频教程 linux find命令的用法有: find命令是linux…

    2025年12月5日
    000
  • Firefox 144.0 发布

    firefox 144.0 已正式上线,本次更新带来多项新功能、改进与修复,具体内容如下: 新增功能 专注当前标签页,简化浏览界面现在即使折叠了标签页组,活动标签页仍会保留在视野中。这一改进帮助用户集中注意力于正在使用的页面,有效减少视觉混乱,提升工作效率。 更智能的标签页组操作标签页组功能进一步优…

    2025年12月5日
    000
  • Linux系统下如何运行.sh文件

    Linux系统下运行.sh文件的方法:首先输入该文件的绝对路径【/root/datelog.sh】;然后cd到【datelog.sh】文件的目录下,并执行【./datelog.sh】。 本教程操作环境:windows7系统、Linux7.3版本,Dell G3电脑。 Linux系统下运行.sh文件的…

    2025年12月5日 运维
    000
  • 怎么新建Python文件VSCode_VSCode创建Python文件教程

    答案:在VS Code中新建Python文件需打开软件后创建新文件并保存为.py格式,系统将自动启用Python语言服务。可通过快捷键Ctrl+N(Cmd+N)新建文件,再用Ctrl+S(Cmd+S)保存为.py文件以激活语法高亮和代码补全功能;也可通过菜单栏或资源管理器新建文件。为确保正常运行,需…

    2025年12月5日
    000
  • linux属于什么系统

    linux属于一种类UNIX操作系统。Linux,全称GNU/Linux,是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU的操作系统。 本文操作环境:red hat enterprise linux 7.4系统、thinkpad t4…

    2025年12月5日
    000
  • linux创建文件夹命令是什么

    linux创建文件夹命令是mkdir,语法为【mkdir (选项)(参数)】,其中Z为设置安全上下文,当使用SELinux时有效,version显示版本信息。 本文操作环境:linux2.6.32系统、DELL G3电脑。 Linux中 mkdir 创建文件夹命令 语法 mkdir (选项)(参数)…

    2025年12月5日 运维
    100
  • linux如何完全删除用户

    linux删除用户的方法:首先进入系统创建一个用户;然后对该用户一些信息目录查看;最后正确删除用户,代码为【[root@localhost /]# userdel -r haha】。 本教程操作环境:linux5.9.8,DELL G3电脑。 linux删除用户的方法: 1、首先进入系统创建一个用户…

    2025年12月5日 运维
    000
  • PHP一键环境与Docker容器化有什么区别_技术异同分析

    PHP一键环境与Docker本质区别在于封装与隔离方式:前者将服务直接安装于系统,多项目共用环境易冲突,适合新手和简单项目;后者通过容器镜像打包应用及依赖,实现环境隔离与一致,便于迁移和团队协作;一键环境部署直观但可移植性差,Docker学习成本高却支持自动化部署;资源上前者更轻量,后者虽有损耗但利…

    2025年12月5日
    000
  • 老电脑换Linux系统是否会更快,旧电脑不要装Windows!Bodhi Linux系统,小巧强悍,运行更流畅…

    大家好,又见面了,我是你们的朋友全栈君。 你的旧电脑安装win10还好吗? 随着科技的飞速发展,尤其是电脑硬件的不断更新换代,很多人不会轻易更换仅使用了两三年的电脑。 然而,电脑使用时间长了,性能难免会变慢,尤其是在Windows系统功能越来越多,占用资源越来越大的情况下,更换新电脑似乎是必然的选择…

    2025年12月5日 运维
    000
  • linux修改主机名的方法

    linux修改主机名的方法:1、在network中把HOSTNAME后面的值更改为想要设置的主机名;2、将hosts中的localhost.localdomian改为想要设置的主机名即可。 本教程操作环境:centos7系统、DELL G3电脑。 推荐:linux视频教程 Linux系统下修改主机名…

    2025年12月5日 运维
    000
  • linux下的文件重命名命令是什么

    linux下的文件重命名命令是mv。mv命令用来为文件或目录改名或将文件由一个目录移入另一个目录中,例如【$ mv test.txt wbk.txt】,表示将文件test重命名为webk。 本文操作环境:red hat enterprise linux 6.1系统、thinkpad t480电脑。 …

    2025年12月5日
    000

发表回复

登录后才能评论
关注微信