gpt4 book ai didi

docker - 是否可以从主机os文件系统访问Kubernetes中已安装的卷

转载 作者:行者123 更新时间:2023-12-02 11:35:39 24 4
gpt4 key购买 nike

我真正的问题是,是否将 secret 作为卷安装在Pod中-如果有人获得对主机OS的根访问权限,则可以读取 secret 。

例如,通过访问/ var / lib / docker并向下钻取该卷。

最佳答案

如果某人可以使用容器对您的主机进行root访问,那么他可以做任何他想做的事...不要忘记pod只是一堆容器,实际上是带有pid的进程。因此,例如,如果我有一个叫做sleeper的 pods :

kubectl get pods sleeper-546494588f-tx6pp -o wide
NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE
sleeper-546494588f-tx6pp 1/1 Running 1 21h 10.200.1.14 k8s-node-2 <none>

运行在节点k8s-node-2上。通过根访问该节点,我可以检查此Pod及其容器具有的pid(我将容器用作容器引擎,但是以下几点对于docker或任何其他容器引擎非常相似):
[root@k8s-node-2 /]# crictl -r  unix:///var/run/containerd/containerd.sock pods -name sleeper-546494588f-tx6pp -q
ec27f502f4edd42b85a93503ea77b6062a3504cbb7ac6d696f44e2849135c24e
[root@k8s-node-2 /]# crictl -r unix:///var/run/containerd/containerd.sock ps -p ec27f502f4edd42b85a93503ea77b6062a3504cbb7ac6d696f44e2849135c24e
CONTAINER ID IMAGE CREATED STATE NAME ATTEMPT POD ID
70ca6950de10b 8ac48589692a5 2 hours ago Running sleeper 1 ec27f502f4edd
[root@k8s-node-2 /]# crictl -r unix:///var/run/containerd/containerd.sock# inspect 70ca6950de10b | grep pid | head -n 1
"pid": 24180,

最后,使用这些信息(pid号),我可以访问此过程的“/”挂载点并检查其内容(包括 secret 信息):
[root@k8s-node-2 /]# ll  /proc/24180/root/var/run/secrets/kubernetes.io/serviceaccount/
total 0
lrwxrwxrwx. 1 root root 13 Nov 14 13:57 ca.crt -> ..data/ca.crt
lrwxrwxrwx. 1 root root 16 Nov 14 13:57 namespace -> ..data/namespace
lrwxrwxrwx. 1 root root 12 Nov 14 13:57 token -> ..data/token
[root@k8s-node-2 serviceaccount]# cat /proc/24180/root/var/run/secrets/kubernetes.io/serviceaccount/namespace ; echo
default
[root@k8s-node-2 serviceaccount]# cat /proc/24180/root/var/run/secrets/kubernetes.io/serviceaccount/token | cut -d'.' -f 1 | base64 -d ;echo
{"alg":"RS256","kid":""}
[root@k8s-node-2 serviceaccount]# cat /proc/24180/root/var/run/secrets/kubernetes.io/serviceaccount/token | cut -d'.' -f 2 | base64 -d 2>/dev/null ;echo
{"iss":"kubernetes/serviceaccount","kubernetes.io/serviceaccount/namespace":"default","kubernetes.io/serviceaccount/secret.name":"default-token-6sbz9","kubernetes.io/serviceaccount/service-account.name":"default","kubernetes.io/serviceaccount/service-account.uid":"42e7f596-e74e-11e8-af81-525400e6d25d","sub":"system:serviceaccount:default:default"}

这是正确保护对kubernetes基础结构的访问至关重要的原因之一。

关于docker - 是否可以从主机os文件系统访问Kubernetes中已安装的卷,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53317465/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com