docker逃逸漏洞复现(docker tz)

文章前言

在Docker中Privileged是一种特殊的权限模式,它允许Docker容器在启动时获取到与宿主机相同的权限级别。具体来说,Privileged权限可以让容器拥有以下能力:

1、访问宿主机的所有设备文件
2、在容器内部运行与宿主机上相同的内核模块
3、能够修改容器内部的网络配置
4、可以使用mount命令挂载宿主机上任意文件系统

需要注意的是使用Privileged权限可以给容器带来更高的权限,但同时也会带来安全风险。因此,在使用Privileged权限时应该非常谨慎,并且只应该在特定场景下使用,例如需要进行底层系统调试或者测试等需要访问宿主机资源的场景。

漏洞概述

操作者使用特权模式启动的容器时,Docker管理员可以通过mount命令将外部宿主机磁盘设备挂载进容器内部,获取对整个宿主机的文件读写权限,此外还可以通过写入计划任务等方式在宿主机执行命令

环境搭建

docker run -v /home/ubuntu/cdk:/cdk --rm -it --privileged ubuntu bash

特权检测

在容器中时可以通过如下参数检测当前容器是否是以特权模式启动:

cat /proc/self/status | grep CapEff

如果是以特权模式启动的话,CapEff对应的掩码值为0000003fffffffff

docker逃逸漏洞复现(docker tz)

通过capsh命令可以解码出具体的Capabilitie

docker逃逸漏洞复现(docker tz)

漏洞利用

Step 1:容器内部执行以下命令

./cdk run mount-disk

Step 2:在容器内部进入挂载目录,直接管理宿主机磁盘文件

cd /tmp/cdk_dyyopls -al

Step  3:之后写入计划任务或者通过写入SSH公钥并进行远程连接获取主机权限即可(ubuntu中计划任务总是有问题很迷)

原创文章,作者:七芒星实验室,如若转载,请注明出处:https://www.sudun.com/ask/34221.html

(0)
七芒星实验室's avatar七芒星实验室
上一篇 2024年4月8日 下午6:57
下一篇 2024年4月8日 下午6:59

相关推荐

  • 编程的VD是什么

    编程中的VD是指虚拟目录(Virtual Directory),一个在服务器上非实际存在但对用户而言像是存在的目录。这允许您将位于完全不同的物理位置的服务器上的文件夹作为独立目录进…

    2024年5月9日
    0
  • 黑客必须知道的CHM钓鱼操作你了解吗?

    1、CHM钓鱼进行钓鱼选择合适的payload非常重要,使用一些容易让人放松警惕的文件格式可以大大提高钓鱼的成功率。CHM是微软推出的基于HTML的帮助文件系统

    2024年9月25日
    0
  • 7ps和4ps在营销上的联系与区别

    我们知道4ps营销组合是营销学的经典理论之一,随着市场经济的发展,服务营销理论应运而生,7ps便是服务营销理论的实践表现,脱胎于4ps组合,更加符合服务经济时代

    2024年9月18日
    0
  • 基础学编程用什么书

    学习编程的基础书籍可以分为几大类:1、《计算机程序的构造和解释》;2、 《C程序设计语言》 ;3、 《Python编程:从入门到实践》 。第一本书,通常简称SCIP不仅教授编程技能…

    网站运维 2024年5月12日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注