- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我在连接到 kubernetes python 客户端时遇到问题,即使我正在按照示例操作 here在 api 中。
基本上这一行无法连接到kubernetes客户端:
config.load_kube_config()
我在做什么:
我有一个像这样的 Dockerfile 文件,我正在用它来构建我的图像。这只是一个简单的 python/flask 应用程序。
FROM python:2
RUN mkdir -p /usr/src/app
WORKDIR /usr/src/app
COPY requirements.txt /usr/src/app/
RUN pip install --no-cache-dir -r requirements.txt
COPY . /usr/src/app
EXPOSE 5000
CMD [ "python", "./app.py" ]
这是我的requirements.txt:
Flask==1.0.2
gunicorn==19.8.1
kubernetes==6.0.0
requests # Apache-2.0
构建 Dockerfile 后输出:
Successfully built a2590bae9fd9
Successfully tagged testapp:latest
但是当我执行 docker run a2590bae9fd9
时,我收到一个错误:
Traceback (most recent call last):
File "./app.py", line 10, in <module>
config.load_kube_config()
File "/usr/local/lib/python2.7/site- packages/kubernetes/config/kube_config.py", line 470, in load_kube_config
config_persister=config_persister)
File "/usr/local/lib/python2.7/site- packages/kubernetes/config/kube_config.py", line 427, in _get_kube_config_loader_for_yaml_file
with open(filename) as f:
IOError: [Errno 2] No such file or directory: '/root/.kube/config'
我以为它可能是我的 python 目录,但我检查过它在/usr/local/bin/python 中运行。
我真的很困惑 - 有什么建议/提示吗?谢谢你。
最佳答案
你不需要config.load_kube_config()
,你想要config.load_incluster_config()
如果您需要区分您的设置和它何时在 Pod
中运行,一种机制是 if os.getenv('KUBERNETES_SERVICE_HOST'): config.load_incluster_config()
因为在 Pod
中肯定会在环境中,而不太可能在您的本地环境中。
关于python - 无法连接到 kubernetes python api - 找不到 .kube/config 文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51032599/
我正在开发一个 voip 调用应用程序。我需要做的是在接到来电时将 Activity 带到前台。我在应用程序中使用 Twilio,并在收到推送消息时开始调用。 问题是我试图在接到任何电话时显示 Act
我是一名优秀的程序员,十分优秀!