本文主要是介绍什么是Linux下的粘滞位,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
一、Linux下的文件权限
在linux下每一个文件和目录都有自己的访问权限,访问权限确定了用户能否访问文件或者目录和怎样进行访问。最为我们熟知的一个文件或目录可能拥有三种权限,分别是读、写、和执行操作。
一个文件具有的三种权限,在Linux下有一种一切皆文件的思想,所以,这里的文件包含普通文件和目录了:
1、文件权限:
r :可以读这个文件的内容;
w :可以编辑这个文件的内容,包括增加和删除文件的具体内容;
x :可执行权限。(需注意:在windows下,文件的可执行权限是通过文件的扩展名表示出来的,而在Linux下是由这个X权限所决定的)。
2、目录权限:
r:可以查看此目录的完整信息;
w:可以对此目录下的所有文件及子目录进行相关的更改;
例如:可以在此目录下创建新的文件及目录,也可以删除此目录下的所有子目录或者文件,不管该文件的权限是什么。
x:目录没有可执行的权限,目录中的x的功能就是允许别的用户可以进入该目录。
在这里需注意,一般情况下需要给other的权限为r-x,因为有x权限其他用户才可以进入此目录,并读取该目录下的信息。
我们创建一个文件后系统会默认地赋予所有者读和写权限。当然我们也可以自己修改它,添加自己需要的权限,那么我们就要引入粘滞位的概念。
粘滞位
粘滞位(Stickybit),又称粘着位,是Unix文件系统权限的一个旗标。最常见的用法在目录上设置粘滞位,也只能针对⽬录设置,对于⽂件⽆效。设置了粘滞位后,只有目录内文件的所有者或者root才可以删除或移动该文件。实际应用中,粘滞位一般用于/tmp目录,以防止普通用户删除或移动其他用户的文件。
二、设置粘滞位
1、在root下创建目录aa,并修改其权限
2、在aa目录新建两个文件f.1和f.2
3、切换到一般用户可以轻易地删除文件f.1
4、进入root给aa目录设置粘滞位,原来的r变为t
切换到一般用户发现删除不了文件f.2
5、进入root给aa目录移除粘滞位
切换到一般用户删除文件f.2成功
当⽬录被设置了粘滞位权限以后,即便⽤户对该⽬录有写⼊权限,也不能删除该⽬录中其他⽤户的⽂件数据,⽽是只有该⽂件的所有者和root⽤户才有权将其删除。设置了粘滞位之后,正好可以保持⼀种动态的平衡:允许各⽤户在⽬录中任意写⼊、删除数据,但是禁⽌随意删除其他⽤户的数据。
粘滞位权限都是针对其他⽤户( other)设置,使⽤chmod命令设置⽬录权限时:
“o+t”、 “o-t”权限模式可分别⽤于添加、移除粘滞位权限。
注意事项
粘滞位权限是针对目录的,对文件无效 。
总结
设置粘滞位权限就是为了防止其他人对于你自己不允许other删除的文件进行删除。
感谢您的光临,欢迎提出宝贵意见。
这篇关于什么是Linux下的粘滞位的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!