企业有时候出于项目的需要,会临时组成一个Unix操作系统项目小组来完成某个特定的项目。此时项目小组要求各个项目小组成员多某个目录具有读写的权限,可以往这个目录中建立文件,可以阅读他人创建的文件。但是有一个限制,即不能够删除他人建立的文件。现在Unix操作系统工程师为某个项目专门建立了一个item的目录。
在这个Unix操作系统目录下有两个文件,分别为urr001与tgt001,分别是用户SA01与用户SA02创建的。现在企业的要求是,无论是用户SA01还是用户SA02,都可以在这个目录中创建文件;SA01也可阅读文件tgt001(所有权是SA02)的文件;但是SA01不能够删除文件tgt001。
也许有Unix操作系统工程师会对这个需求感到怀疑,这可以实现吗?答案是肯定的。通过Unix操作系统提供的粘着位功能,就可以轻松实现这个功能。
Unix操作系统粘着位与文件的关系
粘着位,又称保存文本位,其实就是一个权限控制属性。通常情况下,粘着位即可以用在普通文件上,也可以用在目录文件上。当用在普通文件上时,粘着位可以把某个程序文件的SUID置位。并且它的文本映像将***保存在交换区里。如此的话,当Unix操作系统程序获得了CPU使用权时,就可以快速的装载到内存中。故粘着位可以提高系统程序的运行效率。
如有些版本的Unix系统,就把vi等常用的程序文件的粘着位设置为1,就明显提高了这些应用程序的运行效率。不过现在很少用到这个特性。因为现在磁盘读写速度已经达到***;而且内存的价格也便宜。
也就是说,现在磁盘速度与内存往往已经不是系统的瓶颈资源,故为普通文件设置粘着位已经没有特殊的必要了。为此笔者现在在系统设置中,基本上不会为普通文件设置粘着位。
那么粘着位不是无用武之地了吗?其实不然。虽然在普通文件上设置粘着位没有实际的应用价值,但是在目录文件上设置粘着位还是很有用的。如文章一开头笔者所阐述的内容,就需要通过粘着位来实现。简单的说,当粘着位与目录文件结合时,能够实现一些让人想都想不到的安全措施。
这样,我们就知道了Unix操作系统中粘着位与文件的关系的知识了。这只是一部分知识,希望大家能够更多的知识。
【编辑推荐】