当前位置:  开发笔记 > 编程语言 > 正文

我如何从Kubernetes pod中运行curl命令

如何解决《我如何从Kubernetespod中运行curl命令》经验,为你挑选了2个好方法。

我有以下问题: -

1:我使用以下命令登录Kubernetes pod: -

./cluster/kubectl.sh exec my-nginx-0onux -c my-nginx -it bash

'ip addr show'

命令显示已分配pod的ip.由于pod是一个逻辑概念,我假设我登录了一个docker容器而不是pod,在这种情况下,pod ip与docker container ip相同.这种理解是否正确?

2:来自Kubernetes节点,我这样做sudo docker ps,然后执行以下操作: -

sudo docker exec  71721cb14283 -it '/bin/bash'

这不起作用.有人知道我做错了吗?

3:我想使用curl从pod中访问我创建的nginx服务.如何在此pod或容器中安装curl以从内部访问服务.我想这样做是为了理解网络连接.



1> Andreas Lund..:

以下是在kubernetes网络中获取curl命令行以测试和探索内部REST端点的方法.

要获得在网络内运行的busybox的提示,请执行以下命令.(提示是每个开发人员使用一个唯一的容器.)

kubectl run curl- --image=radial/busyboxplus:curl -i --tty --rm

您可以省略--rm并保持实例运行以供以后重新使用.要在以后重复使用,请键入:

kubectl attach -c curl- -i -t

使用该命令kubectl get pods可以看到所有正在运行的POD.类似于curl-yourname-944940652-fvj28.

编辑:请注意,您需要先从终端登录谷歌云(一次)才能执行此操作!这是一个示例,请确保放入您的区域,群集和项目:gcloud container clusters get-credentials example-cluster --zone europe-west1-c --project example-148812



2> MrE..:

Kubernetes的想法是将Pod分配在主机上,但是没有确定的或永久的,因此您不应尝试从容器中查找容器或Pod的IP,而应使用Kubernetes所谓的Service

Kubernetes 服务是通过定义的一组选择器到Pod的路径kube-proxy,它将通过请求将负载均衡给所有具有给定选择器的Pod。

简而言之:

例如,创建一个带有名为“名称” 的标签Pod。假设使用您调用的选择器 创建服务,例如您为其分配了端口。name=mypod name=mypodmyService9000

然后您可以使用以下方法从豆荚卷曲到该服务所服务的豆荚 curl http://myService:9000

这是假设您当然正在运行DNS Pod。如果您在创建ServiceBlancer类型的服务时要求它并在AWS或GKE上运行,则该服务也可以从群集外部使用。对于仅供内部使用的服务,只需设置该标志clusterIP: None,它就不会在外部进行负载平衡。

请参阅此处的参考:

https://kubernetes.io/docs/concepts/services-networking/service/ https://kubernetes.io/docs/tutorials/services/

推荐阅读
帆侮听我悄悄说星星
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有