首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NSQ码头群

NSQ码头群
EN

Stack Overflow用户
提问于 2016-12-09 16:24:41
回答 2查看 520关注 0票数 3

我试着在码头群中使用NSQ,但没有成功

mhlg/rpi-nsq是为Raspberry Pi ARM7板构建的Docker映像,我可以确认,如果作为普通码头容器运行,mhlg/rpi-nsq是正确工作的。

在码头运行NSQ (确定)

代码语言:javascript
复制
# crete a bridged network
$ docker network create nsq_network

# run lookupd
$ docker run --name nsqlookupd --network nsq_network -p 4160:4160 -p 4161:4161 mhlg/rpi-nsq nsqlookupd

# run nsqd
$ docker run --name nsqd --network nsq_network -p 4150:4150 -p 4151:4151 mhlg/rpi-nsq nsqd --broadcast-address=nsqd --lookupd-tcp-address=nsqlookupd:4160

# run nsqadmin
$ docker run --name nsqadmin --network nsq_network -p 4171:4171  mhlg/rpi-nsq nsqadmin --lookupd-http-address=nsqlookupd:4161

在码头群模式下运行NSQ (失败)--这就是我在群管理器中所做的

代码语言:javascript
复制
# crete an overlay network
$ docker network create nsq_network

# run nsqlookupd
$ docker service create --replicas 1 --name nsqlookupd --network nsq_network -p 4160:4160 -p 4161:4161 mhlg/rpi-nsq nsqlookupd

# run nsqd
$ docker service create --replicas 1 --name nsqd --network nsq_network -p 4150:4150 -p 4151:4151 mhlg/rpi-nsq nsqd --lookupd-tcp-address=nsqlookupd:4160 --broadcast-address=nsqd

# run nsqadmin
$ docker service create --replicas 1 --name nsqadmin --network nsq_network -p 4171:4171  mhlg/rpi-nsq nsqadmin --lookupd-http-address=nsqlookupd:4161

如果我附加到nsqd服务,我可以看到它无法连接到nsqlookupd服务。

代码语言:javascript
复制
[nsqd] 2016/12/09 16:51:56.851953 LOOKUPD(nsqlookupd:4160): sending heartbeat
[nsqd] 2016/12/09 16:51:56.852049 LOOKUP connecting to nsqlookupd:4160
[nsqd] 2016/12/09 16:51:57.852457 LOOKUPD(nsqlookupd:4160): ERROR PING - dial tcp: i/o timeout

看起来覆盖网络创建了一些问题(多播?)但是我想不出我怎么能解决这个问题,尤其是在一个手臂设备上。

我尝试将ssh插入Docker主机,运行nsqd服务,并从nsqd容器中执行一些dns命令

代码语言:javascript
复制
# resolve google.com (OK)
root@3206d1c3cd3d:/# nslookup google.com
Server:     127.0.0.11
Address:    127.0.0.11#53

Non-authoritative answer:
Name:   google.com
Address: 216.58.214.78

# resolve nsqd service (OK) - can resolve the container I'm executing the command from
root@e1f6430acd1c:/# nslookup nsqd
Server:     127.0.0.11
Address:    127.0.0.11#53

Non-authoritative answer:
Name:   nsqd
Address: 10.0.0.2

# resolve nsqlookupd service (FAIL)
root@e1f6430acd1c:/# nslookup nsqlookupd
;; connection timed out; no servers could be reached
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2020-06-28 06:05:09

在码头群中遇到了同样的问题。我就是这样解决的:

代码语言:javascript
复制
docker service create \
--mode global \
--name swarm-master-nsq_nsqlookupd \
--constraint node.role==manager \
--hostname nsqlookupd \
--network name=swarm-master-nsq_nsq,alias=nsqlookupd \
nsqio/nsq:latest /nsqlookupd


docker service create \
--replicas 3 \
--name swarm-master-nsq_nsqd \
--constraint node.role==manager \
--hostname nsqd \
--network name=swarm-master-nsq_nsq,alias=nsqd \
nsqio/nsq:latest sh -c '/nsqd --broadcast-address=$(hostname -i) --lookupd-tcp-address=nsqlookupd:4160'


docker service create \
--replicas 1 \
--publish 4171:4171 \
--name swarm-master-nsq_nsqadmin \
--constraint node.role==manager \
--hostname nsqadmin \
--network name=swarm-master-nsq_nsq,alias=nsqadmin \
nsqio/nsq:latest /nsqadmin --lookupd-http-address=nsqlookupd:4161

据我所知,在您的示例中有几个问题:

  1. 您没有对nsqlookupd和其他服务进行别名。
  2. nsqd的广播是不正确的(假设您希望在某个时候增加nsqd节点的数量)
票数 0
EN

Stack Overflow用户

发布于 2019-06-11 13:57:57

你指出:

代码语言:javascript
复制
# crete an overlay network
$ docker network create nsq_network

然而,这并不会创建一个覆盖网络,而是一个桥接网络。考虑跑步:

代码语言:javascript
复制
docker network create --driver overlay nsq_network
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41064776

复制
相关文章

相似问题

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