如何在Kubernetes中定义网络

时间:2019-02-28 10:40:19

标签: docker kubernetes containers

我使用以下命令运行docker映像:

sudo docker run -dit --net mynetwork read_and_send_apps_logs:latest

现在,我使用Kubernetes运行映像。问题是我不知道在kubernetes中在哪里定义--net?

我可以在部署Yaml中还是在运行$kubectl create -f <...>时定义它?

1 个答案:

答案 0 :(得分:3)

Kubernetes对于每个应用程序网络的概念不同。

如果您只是使用非默认网络在容器之间进行DNS解析,那么您实际上不需要执行任何操作。确保为每个接收入站连接的Pod创建一个Service,并且Kubernetes为您提供its own DNS system。不是Docker风格的ARAnchors主机名,Kubernetes的主机名如containername

如果您尝试将前端与后端服务或涉及多个网络的其他事物进行分区,则可以设置NetworkPolicy。 (我从来没有觉得自己需要这个,但是了解了动机。)

如果要手动设置IP地址或其他非常低级的配置,请不要。 Docker可以自行处理,您不应该将容器IP地址直接用于任何事情。 Kubernetes的设置有很大不同,因此无论如何都无法很好地翻译。

如果您使用servicename.namespacename.svc.cluster.local来使一个容器使用另一个容器的网络名称空间,则在同一Pod中运行两个容器可能对您有用。它们将在同一节点上调度,并共享--net的概念。