Kubernetes容器之间的通信浅谈
容器到容器通信 Pod到Pod通信 Pod到Service通信 外部到内部通信
apiVersion: v1
kind: Pod
metadata:
name: mc1
spec:
volumes:
- name: html
emptyDir: {}
containers:
- name: 1st
image: nginx
volumeMounts:
- name: html
mountPath: /usr/share/nginx/html
- name: 2nd
image: debian
volumeMounts:
- name: html
mountPath: /html
command: ["/bin/sh", "-c"]
args:
- while true; do
date >> /html/index.html;
sleep 1;
done
在此示例中,我们定义了一个名为html的卷。它的类型为emptyDir,这意味着该卷是在将Pod分配给节点时首次创建的,并且只要该Pod在该节点上运行就存在。顾名思义,它最初是空的。第一个容器运行Nginx服务,并将共享卷挂载到目录/ usr / share / nginx / html。第二个容器使用Debian映像,并将共享卷安装到目录/ html。第二个容器每秒将当前日期和时间添加到共享卷中的index.html文件中。当用户向Pod发出HTTP请求时,Nginx服务器将读取此文件并将其传输给用户以响应该请求。
你可以通过暴露nginx端口并使用浏览器访问它,或直接在容器中检查共享目录来检查Pod是否正常工作:
$ kubectl exec mc1 -c 1st -- /bin/cat /usr/share/nginx/html/index.html
...
$ kubectl exec mc1 -c 2nd -- /bin/cat /html/index.html
...
2、进程间通信(IPC)
apiVersion: v1
kind: Pod
metadata:
name: mc2
spec:
containers:
- name: producer
image: allingeek/ch6_ipc
command: ["./ipc", "-producer"]
- name: consumer
image: allingeek/ch6_ipc
command: ["./ipc", "-consumer"]
restartPolicy: Never
要检查这一点,请使用kubectl create创建pod并观察Pod的状态:
$ kubectl get pods --show-all -w
NAME READY STATUS RESTARTS AGE
mc2 0/2 Pending 0 0s
mc2 0/2 ContainerCreating 0 0s
mc2 0/2 Completed 0 29
现在,您可以检查每个容器的日志,并验证第二个容器是否收到了第一个容器的所有消息,包括退出消息:
kubectl logs mc2 -c producer
...
Produced: f4Produced: 1d
Produced: 9eProduced: 27$
kubectl logs mc2 -c consumer
...
Consumed: f4
Consumed: 1d
Consumed: 9e
Consumed: 27
Consumed: done
但是,此Pod存在一个主要问题,它与容器的启动方式有关。
Pods可以具有多个容器的主要原因是为了支持辅助主应用程序的帮助应用程序。辅助应用程序的典型示例是数据提取器,数据推送器和代理。这种模式的一个示例是带有帮助程序的Web服务器,该程序轮询git存储库以获取新更新。
本实验中的”卷”为在Pod的使用期内容器之间通信提供了一种方法。如果删除并重新创建Pod,则共享卷中存储的所有数据都会丢失。在本文中,我们还讨论了Pod中容器之间的进程间通信的概念,它是共享卷概念的替代方法。现在,您了解了Pod中的容器如何通信和交换数据,接下来可以继续学习其他Kubernetes网络模型,例如Pod到Pod或Pod到Service的通信。
关注「开源Linux」加星标,提升IT技能
评论