我有以下设置
创建了两个docker swarm服务
docker service create --name karaf1-service --replicas 1 --network karaf_net karaf1:2.0.0
docker service create --name karaf2-service --replicas 1 --network karaf_net karaf2:2.0.0
现在这些容器在启动时打开套接字端口,我观察到一段时间它能够成功地创建它,但是失败了很多时间。
ServerSocketFactory.getDefault().createServerSocket(serverPort)
如果两个容器都在一个节点上启动,则大多成功,但是当容器在不同节点上创建时,每次都会几乎失败。
在解决网络问题之前,容器至少应创建套接字。
此容器无法打开套接字
root@bd48643080b2:/opt/apache/apache-karaf-4.1.5# netstat -tulnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:8101 0.0.0.0:* LISTEN 61/java
tcp 0 0 127.0.0.1:1099 0.0.0.0:* LISTEN 61/java
tcp 0 0 0.0.0.0:41551 0.0.0.0:* LISTEN 61/java
tcp 0 0 127.0.0.11:44853 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:44444 0.0.0.0:* LISTEN 61/java
以下容器能够在端口4550上创建它,但有时反之亦然
root@38d26c7dde1a:/opt/apache/apache-karaf-4.1.5# netstat -tulnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:37347 0.0.0.0:* LISTEN 61/java
tcp 0 0 0.0.0.0:8101 0.0.0.0:* LISTEN 61/java
tcp 0 0 0.0.0.0:4550 0.0.0.0:* LISTEN 61/java
tcp 0 0 127.0.0.11:37575 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:1099 0.0.0.0:* LISTEN 61/java
tcp 0 0 127.0.0.1:35321 0.0.0.0:* LISTEN 61/java
tcp 0 0 0.0.0.0:44444 0.0.0.0:* LISTEN 61/java
已确定根本原因: 由于我正在创建两个服务,因此在创建第一个服务时,我向第二个服务提供第二个服务作为主机名,以保持验证状态,因此Java在主机名上抛出错误,例如“ karaf2-service”
java.net.UnknownHostException: karaf2-service: Name or service not known
at java.net.Inet4AddressImpl.lookupAllHostAddr(Native Method)
at java.net.InetAddress$2.lookupAllHostAddr(InetAddress.java:928)
现在我无法在etc / hosts中添加karaf2-service的条目,因此套接字不抱怨,因为我不知道将哪个IP分配给docker-swarm服务?在覆盖网络中,我们主要与服务名称进行通信。
任何解决此问题的建议?
答案 0 :(得分:0)
最简单的方法是检查容器启动是否可以访问其他服务,否则,请等待几秒钟,然后重试。
有多种工具可以执行此操作,例如:“ {@ 3}}