Python Docker Kubernetes 中的 SDK

Python Docker SDK Inside Kubernetes

我遵循了这个 link - https://docs.docker.com/engine/api/sdk/examples/ 并且 docker SDK 在我使用 Docker 容器时工作正常。现在我已经转移到 K8s,当我 运行 代码时,我得到类似“Container Not Found”的错误。有没有办法在 Kubernetes PODS 中使用 Python Docker SDK? 错误:

docker.errors.NotFound: 404 Client Error for http+docker://localhost/v1.41/containers/taskmanager-son/json: Not Found ("No such container: taskmanager-son")

注意:当 运行ning 为普通 Docker 容器时,我没有遇到此错误。仅当 k8s PODS.

中的代码 运行s 时才会发生这种情况

注意: 另外 docker ps returns 什么都没有,因为所有容器都 运行ning 在 K8s 中 PODS

import docker
docker_client = docker.from_env()
print(docker_client.containers.list())
# Returns none since since all containers are running inside K8s PODS

关于Python Docker SDK可以参考这里: https://docker-py.readthedocs.io/en/stable/

您不能在 Kubernetes 内部使用 Docker API;您需要改用 Kubernetes API 。您可以使用 Kubernetes API 执行许多与 Docker API 相同的操作(启动新作业、查询现有 Pods、...)。但是,你不能构建新的镜像,你执行的操作集会受到 Kubernetes RBAC 系统的限制,并且很难接管主机。

Docker API 有一些重要的安全考虑,并且 Kubernetes 不能保证 运行ning Docker 正确。还值得注意的是 Docker API 只能检查或操作同一节点上的容器,其中 Kubernetes API 可以看到集群中的所有内容。

(如果可以避免,这两种环境之间的差异是避免需要直接访问任何一个 API 的一个很好的理由。例如,像 RabbitMQ 这样的作业队列系统加上一个 long-运行ning worker 可以 运行 在任何环境中,并且比为每个作业启动一个单独的容器更容易扩展和控制。)