首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >码头工人蜂拥而至,在集装箱里听,但不在外面听。

码头工人蜂拥而至,在集装箱里听,但不在外面听。
EN

Stack Overflow用户
提问于 2016-11-10 12:19:41
回答 1查看 762关注 0票数 1

我们有一个数字对接图像运行在一个蜂群模式,并有困难,让其中之一,以听取外部。

如果我执行容器,我可以将URL压缩在0.0.0.0:8080上。

当我查看主机上的网络时,我看到一个数据包被卡在Recv-Q中,用于这个监听端口(但对于其他正确工作的端口则不然)。

看看NAT规则,我实际上可以将172.19.0.2:8084放在码头主机(docker_gwbridge)上,而不是在实际的停靠主机IP上(172.31.105.59)。

我尝试了许多不同的点(7080,8084,8085),也停止了对接,做了一个rm -rf /var/lib/docker,然后尝试只运行这个容器,但没有成功。对于为什么这个容器映像不起作用,但其他5个却很好的原因,有什么想法吗?

码头服务

代码语言:javascript
复制
docker service create --with-registry-auth --replicas 1 --network myoverlay \
  --publish 8084:8080 \
  --name containerimage \
  docker.repo.net/containerimage

ss -ltn

代码语言:javascript
复制
State       Recv-Q Send-Q                                              Local Address:Port                                                               Peer Address:Port

LISTEN      0      128                                                 172.31.105.59:7946                                                                          *:*
LISTEN      0      128                                                             *:ssh                                                                           *:*
LISTEN      0      128                                                     127.0.0.1:smux                                                                          *:*
LISTEN      0      128                                                 172.31.105.59:2377                                                                          *:*
LISTEN      0      128                                                            :::webcache                                                                     :::*
LISTEN      0      128                                                            :::tproxy                                                                       :::*
LISTEN      0      128                                                            :::us-cli                                                                       :::*
LISTEN      0      128                                                            :::us-srv                                                                       :::*
LISTEN      0      128                                                            :::4243                                                                         :::*
LISTEN      1      128                                                            :::8084                                                                         :::*
LISTEN      0      128                                                            :::ssh                                                                          :::*
LISTEN      0      128                                                            :::cslistener                                                                   :::*

iptables -n -L -t nat

代码语言:javascript
复制
Chain PREROUTING (policy ACCEPT)
target     prot opt source               destination
DOCKER-INGRESS  all  --  0.0.0.0/0            0.0.0.0/0            ADDRTYPE match dst-type LOCAL
DOCKER     all  --  0.0.0.0/0            0.0.0.0/0            ADDRTYPE match dst-type LOCAL

Chain INPUT (policy ACCEPT)
target     prot opt source               destination

Chain OUTPUT (policy ACCEPT)
target     prot opt source               destination
DOCKER-INGRESS  all  --  0.0.0.0/0            0.0.0.0/0            ADDRTYPE match dst-type LOCAL
DOCKER     all  --  0.0.0.0/0           !127.0.0.0/8          ADDRTYPE match dst-type LOCAL

Chain POSTROUTING (policy ACCEPT)
target     prot opt source               destination
MASQUERADE  all  --  172.19.0.0/16        0.0.0.0/0
MASQUERADE  all  --  0.0.0.0/0            0.0.0.0/0            ADDRTYPE match src-type LOCAL
MASQUERADE  all  --  172.17.0.0/16        0.0.0.0/0
MASQUERADE  all  --  172.18.0.0/16        0.0.0.0/0

Chain DOCKER (2 references)
target     prot opt source               destination
RETURN     all  --  0.0.0.0/0            0.0.0.0/0
RETURN     all  --  0.0.0.0/0            0.0.0.0/0

Chain DOCKER-INGRESS (2 references)
target     prot opt source               destination
DNAT       tcp  --  0.0.0.0/0            0.0.0.0/0            tcp dpt:8084 to:172.19.0.2:8084
DNAT       tcp  --  0.0.0.0/0            0.0.0.0/0            tcp dpt:9000 to:172.19.0.2:9000
DNAT       tcp  --  0.0.0.0/0            0.0.0.0/0            tcp dpt:8083 to:172.19.0.2:8083
DNAT       tcp  --  0.0.0.0/0            0.0.0.0/0            tcp dpt:8080 to:172.19.0.2:8080
DNAT       tcp  --  0.0.0.0/0            0.0.0.0/0            tcp dpt:8081 to:172.19.0.2:8081
DNAT       tcp  --  0.0.0.0/0            0.0.0.0/0            tcp dpt:8082 to:172.19.0.2:8082
RETURN     all  --  0.0.0.0/0            0.0.0.0/0

ip a\ grep 172.19

代码语言:javascript
复制
inet 172.19.0.1/16 scope global docker_gwbridge

ip a

代码语言:javascript
复制
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 9001 qdisc pfifo_fast state UP qlen 1000
    link/ether 12:d1:da:a7:1d:1a brd ff:ff:ff:ff:ff:ff
    inet 172.31.105.59/24 brd 172.31.105.255 scope global dynamic eth0
       valid_lft 3088sec preferred_lft 3088sec
    inet6 fe80::10d1:daff:fea7:1d1a/64 scope link
       valid_lft forever preferred_lft forever
3: docker0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN
    link/ether 02:42:55:ae:ff:f5 brd ff:ff:ff:ff:ff:ff
    inet 172.17.0.1/16 scope global docker0
       valid_lft forever preferred_lft forever
4: docker_gwbridge: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP
    link/ether 02:42:ce:b5:27:49 brd ff:ff:ff:ff:ff:ff
    inet 172.19.0.1/16 scope global docker_gwbridge
       valid_lft forever preferred_lft forever
    inet6 fe80::42:ceff:feb5:2749/64 scope link
       valid_lft forever preferred_lft forever
23: vethe2712d7@if22: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether 92:58:81:03:25:20 brd ff:ff:ff:ff:ff:ff link-netnsid 1
    inet6 fe80::9058:81ff:fe03:2520/64 scope link
       valid_lft forever preferred_lft forever
34: vethc446bc2@if33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether e2:a7:0f:d4:aa:1d brd ff:ff:ff:ff:ff:ff link-netnsid 4
    inet6 fe80::e0a7:fff:fed4:aa1d/64 scope link
       valid_lft forever preferred_lft forever
40: vethf1238ff@if39: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether e6:1a:87:a4:18:2a brd ff:ff:ff:ff:ff:ff link-netnsid 5
    inet6 fe80::e41a:87ff:fea4:182a/64 scope link
       valid_lft forever preferred_lft forever
46: vethe334e2d@if45: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether a2:5f:2c:98:10:42 brd ff:ff:ff:ff:ff:ff link-netnsid 6
    inet6 fe80::a05f:2cff:fe98:1042/64 scope link
       valid_lft forever preferred_lft forever
58: vethda32f8d@if57: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether ea:40:a2:68:d3:89 brd ff:ff:ff:ff:ff:ff link-netnsid 7
    inet6 fe80::e840:a2ff:fe68:d389/64 scope link
       valid_lft forever preferred_lft forever
41596: veth9eddb38@if41595: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether fa:99:eb:48:be:b0 brd ff:ff:ff:ff:ff:ff link-netnsid 9
    inet6 fe80::f899:ebff:fe48:beb0/64 scope link
       valid_lft forever preferred_lft forever
41612: veth161a89a@if41611: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc noqueue master docker_gwbridge state UP
    link/ether b6:33:62:08:da:c4 brd ff:ff:ff:ff:ff:ff link-netnsid 3
    inet6 fe80::b433:62ff:fe08:dac4/64 scope link
       valid_lft forever preferred_lft forever
EN

回答 1

Stack Overflow用户

发布于 2016-11-11 08:55:19

好的,这是容器的正常行为,端口映射只能在主机IP中使用。因此,如果使用容器IP,则必须到达端口8080 (应用程序的实际端口)。

由于您使用的--publish,容器的端口8080映射到主机IP上的端口8084。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40527483

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档