容器服务为容器创建全局的网络,集群中的容器都可以通过容器的 eth0 的网络接口访问其它容器。
编排示例
例如:分别在两台机器上创建容器,并记录它们的 IP 地址、容器名、hostname,登录容器远程终端,通过 ping 命令测试这两个容器跨节点网络通信情况。
network-test1:
image: busybox
hostname: server1
command: sh -c 'ifconfig eth0; sleep 100000'
tty: true
environment:
- 'constraint:aliyun.node_index==1'
network-test2:
image: busybox
hostname: server2
command: sh -c 'ifconfig eth0; sleep 100000'
tty: true
environment:
- 'constraint:aliyun.node_index==2'
容器跨主机互联测试方法
可以看到这两个服务的容器分布在不同的节点上
通过容器 IP 进行测试
通过容器服务管理控制台或者通过 test_network-test1_1 容器输出的ifconfig eth0日志,您可以看到 test_network-test1_1 容器的 IP 地址为172.18.0.4。您可以通过连接远程终端在 test_network-test2_1 容器内访问 test_network-test1_1 容器的 IP 地址,来测试网络是否通信。
在 shell 输入栏执行 sh 命令,然后输入 ping 172.18.0.4 命令。
通过容器名进行测试
您可以在对应容器的详情页面查看容器名,默认的容器名为 {project-name}_{service-name}_{container-index}。在 shell 输入栏执行 sh 命令,然后输入 ping test_network_test1_1 ,通过容器名进行网络连通性测试。
通过 hostname 进行测试
在本示例中,在编排模板中指定了 hostname,因此您可以也通过 hostname 进行网络连通性测试。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。