Linux特殊权限set_uid、set_gid、stick_bit命令和软链接文件、硬连接文件

简介:

特殊权限set_uid

ls -l查看 passwd命令文件的路径可以看到这个文件和之前所看到的文件有些不同,有红色的标记,而且有个s权限:

wKioL1ngbr2BX5z9AAGf48SbhZI912.png

这个s就是set_uid的权限,这个权限可以让普通用户修改自己的密码,这个权限的原理是:当普通用户执行passwd命令的一瞬间给它赋予root的身份权限,相当于临时使用了root权限,所以才能够修改得了密码文件,这就是set_uid的权限的作用。

  注意:能够有set_uid权限的文件,这个文件一定得是二进制的可执行文件。



普通用户使用ls命令想要查看root目录是权限不够的,所以想要普通用户也能使用ls命令查看root目录或者查看需要root权限的文件、目录的时候,我们可以给ls命令授予set_uid权限:

wKiom1ngcXOAyYQNAAFCjN5zMMo698.png


ls命令授予set_uid权限:

wKioL1ngbr7yZWkaAAGoSVQtdxE079.png


这时候用普通用户就可以查看root目录了:

wKiom1ngcXWjeXzSAAQnWQsYN-Q055.png


去掉set_uid权限:

wKioL1ngbr-iNrbtAAI2FNiFFLs723.png


另一种设置set_uid权限的方法:

wKiom1ngcXfSEXdjAAId_CxJq-Q879.png


想要将s变成小写加个x权限即可:

wKioL1ngbsCD-TKTAAG0-naw794282.png

目录也是可以设置set_uid权限的,但是也因为目录不是命令文件,没有实际的执行意义,所以设置set_uid权限也是没有意义的。


特殊权限set_gid

set_gid和 set_uid挺像的,只不过这个set_gid权限是作用在所属组上面的,给ls命令设置一个set_gid权限:

wKioL1ngbsLy0fFrAAJ94UaJhx4166.png


所以set_gid权限的作用是临时给普通用户拥有此文件所属组的身份权限,目录也是可以设置这个权限的:

wKiom1ngcXiwDdGEAAG8X_-Lauk570.png


上面我们把Test1目录设置了set_gid权限,这时候把Test1目录的所属组改为user1后,在此目录下所创建的子目录或文件的所属组都会和父目录保持一致,也就是说它们的所属组都会是user1

wKiom1ngcXnjiWwzAAFULbveqV4435.png

wKioL1ngbsOxFvApAAJ-CELQeCc741.png


特殊权限stick_bit

    tmp目录有stick_bit权限,这个权限的表示字符是t

wKiom1ngcXrDRZkoAAE56JX6QZs227.png


这个stick_bit权限是用于防止自己的文件被其他用户删除的,设置了权限后除了这文件的所有者和所属组之外的用户是不能删除的:

wKioL1ngbsTx56waAAEoXnyAIRE161.png


软链接文件:

  软链接文件类似于windows的快捷方式:

wKiom1ngcXuDXCD3AAIIhK7Qagc151.png

软链接文件相当于是存储了一个路径,所以这个软链接文件的大小就取决于路径的长度。


lib64目录下软链接文件比较多:

wKioL1ngbsmSp0p4AApihqTo-2Q061.png

wKioL1ngbs-wDo1gAA0xN4z4r5U688.png

  软链接文件的作用主要是节省存储空间,因为当需要复制一个文件的时候只需要复制那个文件的软链接文件即可,如果复制文件本身的话占用空间会大得多。


制作软链接:

ln -s命令可以制作软链接:

wKiom1ngcYegf9FmAANZvR6mjNk056.png

wKiom1ngcYnxmw_TAARQD1zdhlU445.png


   目录也可以做一个软链接:

wKiom1ngcYzyNIYAAATtfodbL8Q865.png


制作相对路径的软链接:

相对路径的软链接有弊端,如果把这个目录拷贝到别的计算机或者这个目录的名称发生改变的话,这个相对路径的软链接就会失效,所以制作软链接尽量使用绝对路径。

  例如我将123.txt移动到Test1目录下:

wKioL1ngbtjR5Cn8AAShAoYvqlI942.png


如果是使用的绝对路径就不会有这种问题:

wKioL1ngbtnBCrlBAAOc1ohpzNU585.png

所以尽量使用绝对路径。


软链接还可以解决磁盘存储空间不够的问题,例如tmp目录的快存储满了,但是这个目录下有一个日志文件需要一直被写入数据,这个时候就可以将这个日志文件先移动到一个磁盘空间大的目录下,然后将这个日志文件做一个软链接,接着将这个软链接文件放在tmp目录下,这样的话写入的数据是写入到原文件的,而不会写入到软链接文件,所以遇到这问题的时候可以用这种方式解决。


 硬链接文件:

     ln命令可以制作硬链接,硬链接有点类似于复制了原文件但又不完全是因为这个复制不会占用磁盘空间因为原文件和硬链接文件的inode号是一样的,使用的是同一个inode号。

所以原文件和硬链接文件实际上是同一个文件,当原文件的内容改动时,硬链接的文件也会跟着改动,同样的硬链接的文件内容改动时,原文件的内容也会跟着改动。硬链接只支持对文件进行制作,不能对目录进行制作:

wKiom1ngca2xlJJoAAFYlLBFY-U152.png

wKiom1ngca-yFFF1AAXMON1sDes968.png

wKioL1ngbvnRUs_qAAIh5nEtDAU442.png


硬链接的特性:两个文件相互为硬链接,并且信息一模一样,使用的inode号也是同一个,硬链接的原文件即便被删除了也不会影响到硬链接文件,因为原文件的inode还在被硬链接文件指向着。

这个inode号就像一个多个包装盒包装着的气体,这些包装盒就是原文件和硬链接文件,不管你有多少个包装盒,只要最后一个包装盒没有被撕掉那么这个气体就不会消失,如果最后一个包装盒都被撕掉了这个气体自然就会流走了。所以不管删除的是原文件还是硬链接文件,只要还剩最后一个文件指向着那个inode,那么这个文件就还存在,如果最后一个指向那个inode的文件都被删除了,那么这个文件就是被彻底删除了。

硬链接文件不会占用磁盘空间,因为它和原文件指向的是同一个inode,而且硬链接不允许跨目录分区,因为每个目录分区都有自己的inode体系:

wKioL1ngbvrTuyz5AAEeGuqr2UY641.png






本文转自 ZeroOne01 51CTO博客,原文链接:http://blog.51cto.com/zero01/1972113,如需转载请自行联系原作者

相关文章
|
6天前
|
Linux 开发工具 Perl
在Linux中,有一个文件,如何删除包含“www“字样的字符?
在Linux中,如果你想删除一个文件中包含特定字样(如“www”)的所有字符或行,你可以使用多种文本处理工具来实现。以下是一些常见的方法:
30 5
|
6天前
|
安全 Linux 数据安全/隐私保护
在 Linux 系统中,查找文件所有者是系统管理和安全审计的重要技能。
在 Linux 系统中,查找文件所有者是系统管理和安全审计的重要技能。本文介绍了使用 `ls -l` 和 `stat` 命令查找文件所有者的基本方法,以及通过文件路径、通配符和结合其他命令的高级技巧。还提供了实际案例分析和注意事项,帮助读者更好地掌握这一操作。
23 6
|
6天前
|
Linux
在 Linux 系统中,`find` 命令是一个强大的文件查找工具
在 Linux 系统中,`find` 命令是一个强大的文件查找工具。本文详细介绍了 `find` 命令的基本语法、常用选项和具体应用示例,帮助用户快速掌握如何根据文件名、类型、大小、修改时间等条件查找文件,并展示了如何结合逻辑运算符、正则表达式和排除特定目录等高级用法。
30 6
|
7天前
|
监控 Linux Perl
Linux 命令小技巧:显示文件指定行的内容
在 Linux 系统中,处理文本文件是一项常见任务。本文介绍了如何使用 head、tail、sed 和 awk 等命令快速显示文件中的指定行内容,帮助你高效处理文本文件。通过实际应用场景和案例分析,展示了这些命令在代码审查、日志分析和文本处理中的具体用途。同时,还提供了注意事项和技巧,帮助你更好地掌握这些命令。
21 4
|
13天前
|
网络协议 Linux
linux系统重要文件目录
本文介绍了Linux系统中的重要目录及其历史背景,包括根目录、/usr、/etc、/var/log和/proc等目录的结构和功能。其中,/etc目录下包含了许多关键配置文件,如网卡配置、DNS解析、主机名设置等。文章还详细解释了各目录和文件的作用,帮助读者更好地理解和管理Linux系统。
35 2
|
12天前
|
缓存 监控 Linux
|
15天前
|
Linux Shell 数据库
文件查找是Linux用户日常工作的重要技能介绍了几种不常见的文件查找方法
文件查找是Linux用户日常工作的重要技能。本文介绍了几种不常见的文件查找方法,包括使用`find`和`column`组合、`locate`和`mlocate`快速查找、编写Shell脚本、使用现代工具`fd`、结合`grep`搜索文件内容,以及图形界面工具如`Gnome Search Tool`和`Albert`。这些方法能显著提升文件查找的效率和准确性。
35 2
|
4月前
|
Linux
Linux部署04-ls命令的参数和选项,主体,参数,选项,ls / 查看根目录下的文件夹,-a的意思是列出全部选项 ls -a home全部文件,.代表着隐藏的文件夹,-l 选项,以列表竖向的形式展
Linux部署04-ls命令的参数和选项,主体,参数,选项,ls / 查看根目录下的文件夹,-a的意思是列出全部选项 ls -a home全部文件,.代表着隐藏的文件夹,-l 选项,以列表竖向的形式展
|
4月前
|
Linux
Linux部署 cd-pwd命令,cd 不写参数 就直接回到用户的HOME目录,pwd 查看当前的工作目录,pwd是常看当前目录的路径,无参数
Linux部署 cd-pwd命令,cd 不写参数 就直接回到用户的HOME目录,pwd 查看当前的工作目录,pwd是常看当前目录的路径,无参数
|
4月前
|
Linux
Linux02---命令基础 Linux命令基础, ls命令入门,ls命令参数和选项,命令行是一种以纯字符操作系统的方式,command命令本身,options命令的细节行为,parameter命令的
Linux02---命令基础 Linux命令基础, ls命令入门,ls命令参数和选项,命令行是一种以纯字符操作系统的方式,command命令本身,options命令的细节行为,parameter命令的