nsq源码阅读 nsqd源码四 nsqd/lookup.go 与nsqlookupd服务的交互

NSQD对象的Main()方法中有一段代码:

n.waitGroup.Wrap(func() { n.lookupLoop() })

启动一个goroutine,处理与nsqlookupd进程的交互。封装在nsqd/lookup.go中。

这个goroutine的主要功能有:

1、连接nsqlookupd服务,执行IDENTIFY操作;

2、将nsqd的Metadata中的topic、channel注册到nsqlookupd服务;

3、15秒心跳一次,对nsqlookupd执行一次PING操作;

4、新增或删除topic、channel时,REGISTER或UNREGISTER到nsqlookupd服务。

首先连接nsqlookupd服务,连接到配置文件中nsqlookupd_tcp_addresses和命令行参数中“-lookupd-tcp-address”给定的nsqlookupd服务。

		if connect {
			// 配置文件中或启动命令中指定的nsqlookupd服务的地址
			for _, host := range n.getOpts().NSQLookupdTCPAddresses {
				// 如果已经连接过了,跳过
				if in(host, lookupAddrs) {
					continue
				}
				n.logf("LOOKUP(%s): adding peer", host)
				lookupPeer := newLookupPeer(host, n.getOpts().MaxBodySize, n.getOpts().Logger,
					connectCallback(n, hostname, syncTopicChan))
				// 开始链接lookupd服务
				lookupPeer.Command(nil) // start the connection
				lookupPeers = append(lookupPeers, lookupPeer)
				lookupAddrs = append(lookupAddrs, host)
			}
			// 赋值给n.lookupPeers
			n.lookupPeers.Store(lookupPeers)
			connect = false
		}

初始化时,connect默认为true,会执行这段代码,连接到nsqlookupd服务,执行IDENTIFY操作。newLookupPeer()时,使用了修饰器,关于golang的修饰器,可以看看阿里陈皓大神的博客

go build报错:# command-line-arguments /usr/local/go/pkg/tool/darwin_arm64/link: running clang++ failed: exit status 1 /usr/bin/clang++ -arch arm64 -Wl,-headerpad,1144 -o $WORK/b001/exe/a.out -Qunused-arguments /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/go.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000000.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000001.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000002.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000003.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000004.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000005.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000006.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000007.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000008.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000009.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000010.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000011.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000012.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000013.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000014.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000015.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000016.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000017.o /var/folders/qm/nsq1x34s1gbbt5fsk601lrm80000gn/T/go-link-2772047020/000018.o -lresolv -O2 -g -O2 -g -framework CoreFoundation -framework Security -O2 -g -L/Users/apbhc25035064/Documents/source/anti_cheat/src/vendor/git.intra.weibo.com/ads/ads_common_go/common/cityhash -lstdc++ -lcity -O2 -g -framework CoreFoundation -O2 -g ld: warning: ignoring duplicate libraries: '-lc++' ld: archive member '/' not a mach-o file in '/Users/apbhc25035064/Documents/source/anti_cheat/src/vendor/git.intra.weibo.com/ads/ads_common_go/common/cityhash/libcity.a' clang++: error: linker command failed with exit code 1 (use -v to see invocation)
最新发布
09-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值