当前位置: 首页 > news >正文

set_uid、set_gid、stick_bit、软链接和硬连接文件

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

9月17日任务

2.18 特殊权限set_uid

2.19 特殊权限set_gid

2.20 特殊权限stick_bit

2.21 软链接文件

2.22 硬连接文件

 

特殊权限

set_uid

设置了set_uid的二进制文件,其他用户执行时,将临时拥有该文件所有者的权限,以此执行!最常用的命令passwd的二进制文件就被赋予了set_uid特殊权限!

设置set_uid的前提:必须是 二进制可执行文件目录无效

在u的权限组内没有x权限时,设置set_uid后s位将变为大写(S)。

#未设置set_uid,普通用户查看/root目录
[castiel@centos7 ~]$ /usr/bin/ls /root
/usr/bin/ls: 无法打开目录/root: 权限不够

#设置set_uid后,可以以root权限查看/root
[root@centos7 ~]# chmod u+s /usr/bin/ls
[root@centos7 ~]# ls -l /usr/bin/ls
-rwsr-xr-x. 1 root root 117656 ... /usr/bin/ls
[root@centos7 ~]# su - castiel
[castiel@centos7 ~]$ /usr/bin/ls /root
111  anaconda-ks.cfg
[root@centos7 ~]# ls -l /usr/bin/ls
-rwSr-xr-x. 1 root root 117656 ... /usr/bin/ls

set_gid

设置了set_gid的文件执行时将拥有文件所属组(group)的权限。

此外对目录设置set_gid后,执行时当前命令的用户的所属组将会成为在该目录下新创建的文件、目录的所属组(group),

没有设置的其内文件的所属组是当前用户的所属组。

[root@centos7 tmp]# mkdir test
[root@centos7 tmp]# ls -ld test/
drwxr-xr-x. 2 root root 6 ... test/
[root@centos7 tmp]# chown :castiel test/
[root@centos7 tmp]# ls -ld test/
drwxr-xr-x. 2 root castiel 6 ... test/

# 未设置前创建目录和文件,与后续进行对比
[root@centos7 tmp]# mkdir test/111
[root@centos7 tmp]# touch test/222.txt

#设置set_gid,随后创建新目录和文件
[root@centos7 tmp]# chmod g+s test/
[root@centos7 tmp]# mkdir test/333/
[root@centos7 tmp]# touch  test/444.txt

[root@centos7 tmp]# ls -l test/
总用量 0
drwxr-xr-x. 2 root root    6 ... 111
-rw-r--r--. 1 root root    0 ... 222.txt
drwxr-sr-x. 2 root castiel 6 ... 333
-rw-r--r--. 1 root castiel 0 ... 444.txt

# 同样的去除掉group内的x权限,set_gid位显示为S.
[root@localhost system]# chmod g-x /test
[root@localhost system]# chmod g+s /test
[root@localhost system]# ls -ld /test
drwxr-Sr-x. 2 root root 6 ... /test

sticky_bit

防删除位,对一个目录设置sticky_bit后,一个用户将无法删除目录内其他用户创建的文件!(root用户除外)

正常情况下,只要用户对该父目录拥有x权限,就可以删除目录下的文件、子目录,不需要关心用户对文件、子目录是否拥有x权限!

添加了sticky_bit权限后,可以防止其他用户误删。

[root@centos7 test]# ls -ld /test/
drwxr-xr-x. 2 root root 16 ... /test/

# 添加sticky_bit位
[root@centos7 test]# chmod o+t /test/
[root@centos7 test]# ls -ld /test/
drwxr-xr-t. 2 root root 16 ... /test/

# 同样的当没有x权限,sticky_bit显示为T
[root@localhost system]# chmod o-x /test
[root@localhost system]# chmod o+t /test
[root@localhost system]# ls -ld /test
drwxr-xr-T. 2 root root 6 ... /test

软链接

软链接文件相当于Windows下的快捷方式,文件类型为l。 系统目录/bin/目录就是/usr/bin/目录的软连接

使用方法:ln -s 目标文件/目录 软链接

优缺点

  • 好处:占用内存小

  • 缺点:源文件/目录被删除或移动,软链接将失效

修改软链接文件的内容的实质为修改源文件,软链接是对其的引用!创建软链接最好使用绝对路径,不易出错!

实用场景

对于一个空间不多的分区,如果有一个文件被进程所使用导致所占空间不断变大,这时如果不想该分区被数据写满,

可以先将该文件拷贝到其他大空间分区,并在原分区内创建软链接!!然后删除原处文件,原进程不受影响

[root@centos7 test]# ls -l /bin
lrwxrwxrwx. 1 root root 7 ... /bin -> usr/bin

硬链接

使用方法: ln 源文件 硬连接文件

硬链接是对同一个文件所在内存地址的引用(inode号相等),硬链接和原文件互为硬链接!

  • 删除其中一个文件,另外的文件不受影响!

  • 修改其中一个文件,另外的文件内容也变化!

硬链接无法跨分区创建(多个分区有相同inode号,任意弄混)

关于目录

!!不能对目录设置硬链接

新创建的硬链接不会占用额外的空间!!因为其空间在创建源文件的时候就已经占用了,

对应于系统内的特定内存地址,硬链接只是是对该内存地址的引用

[root@centos7 ~]# ls -ld .
dr-xr-x---. 3 root root 173 ... .

[root@centos7 ~]# ls -ild . /root/ /root/.ssh/..
16797761 dr-xr-x---. 3 root root 173 ... .
16797761 dr-xr-x---. 3 root root 173 ... /root/
16797761 dr-xr-x---. 3 root root 173 ... /root/.ssh/..

对于一个目录而言,其内包含的3个子目录都可以表示该目录,
对目录设置硬链接会产生循环创建,陷入死循环!
[root@centos7 test]# ls -li
总用量 8
8812615 -rw-r--r--. 2 root root 8 ... 1.txt
8812615 -rw-r--r--. 2 root root 8 ... 2.txt
[root@centos7 test]# du -sh /test/
4.0K    /test/
[root@centos7 test]# du -sh 1.txt
4.0K    1.txt
[root@centos7 test]# du -sh 2.txt
4.0K    2.txt

 

转载于:https://my.oschina.net/u/3964535/blog/2052031

相关文章:

  • 0006-20180422-自动化第七章-python基础学习笔记
  • 【计算机网络】OSI七层模型图解
  • Java多线程全揭秘
  • 特殊权限set_uid/ set_gid /stick_bit,软链接、硬链接
  • 源码分析----Mybatis数据源与连接池
  • const 有什么用途
  • 架构师的工作都干些什么?!想做架构师必看!
  • 解决 PHPStorm 打开项目一直 indexing 的问题
  • 学以致用十二-----YouCompeteMe巨坑
  • nginx 80端口重定向到443端口
  • [Poetize6] IncDec Sequence
  • Springboot+mybatis整合
  • Django中引入Highcharts
  • 洛谷 P2152 [SDOI2009]SuperGCD (高精度)
  • Linux 基本概念 命令
  • 【译】理解JavaScript:new 关键字
  • Apache Pulsar 2.1 重磅发布
  • FastReport在线报表设计器工作原理
  • IDEA 插件开发入门教程
  • JavaScript 是如何工作的:WebRTC 和对等网络的机制!
  • js 实现textarea输入字数提示
  • Js基础——数据类型之Null和Undefined
  • miniui datagrid 的客户端分页解决方案 - CS结合
  • node.js
  • SQLServer之创建数据库快照
  • Xmanager 远程桌面 CentOS 7
  • 不发不行!Netty集成文字图片聊天室外加TCP/IP软硬件通信
  • 复杂数据处理
  • 基于Volley网络库实现加载多种网络图片(包括GIF动态图片、圆形图片、普通图片)...
  • 记录一下第一次使用npm
  • 力扣(LeetCode)21
  • 译有关态射的一切
  • ​iOS实时查看App运行日志
  • ​二进制运算符:(与运算)、|(或运算)、~(取反运算)、^(异或运算)、位移运算符​
  • ​水经微图Web1.5.0版即将上线
  • #HarmonyOS:软件安装window和mac预览Hello World
  • #绘制圆心_R语言——绘制一个诚意满满的圆 祝你2021圆圆满满
  • (Forward) Music Player: From UI Proposal to Code
  • (iPhone/iPad开发)在UIWebView中自定义菜单栏
  • (转)视频码率,帧率和分辨率的联系与区别
  • .dwp和.webpart的区别
  • .net wcf memory gates checking failed
  • .NET WebClient 类下载部分文件会错误?可能是解压缩的锅
  • .NET 依赖注入和配置系统
  • .NET/C# 使用反射调用含 ref 或 out 参数的方法
  • .Net8 Blazor 尝鲜
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • :not(:first-child)和:not(:last-child)的用法
  • @ConditionalOnProperty注解使用说明
  • @RequestParam @RequestBody @PathVariable 等参数绑定注解详解
  • [ 网络基础篇 ] MAP 迈普交换机常用命令详解
  • [Android 13]Input系列--获取触摸窗口
  • [AUTOSAR][诊断管理][ECU][$37] 请求退出传输。终止数据传输的(上传/下载)
  • [C++]STL之map
  • [C++11 多线程同步] --- 条件变量的那些坑【条件变量信号丢失和条件变量虚假唤醒(spurious wakeup)】