我使用以下命令运行docker映像:
sudo docker run -dit --net mynetwork read_and_send_apps_logs:latest
现在,我使用Kubernetes运行映像。问题是我不知道在kubernetes中在哪里定义--net?
我可以在部署Yaml中还是在运行$kubectl create -f <...>
时定义它?
答案 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
的概念。