安装
brew install nsq
启动
启动nsqlookupd
nsqlookupd
data:image/s3,"s3://crabby-images/eda99/eda9908ce32b63ac1971a6a1cb3da416d7a38604" alt=""
启动nsqd
nsqd --lookupd-tcp-address=127.0.0.1:4160
data:image/s3,"s3://crabby-images/6e88e/6e88e603653c622ba3021e5d1d0262a1b2b62b5a" alt=""
data:image/s3,"s3://crabby-images/a3f79/a3f79284268b0899f4eea9f8d68bd1d1a02354a1" alt=""
但是安装官网上这样操作在后面的步骤中遇到了问题,具体的稍后再讲。
后来我用的是:
nsqd --lookupd-tcp-address=127.0.0.1:4160 --broadcast-address=127.0.0.1
后面再讲原因
启动nsqadmin
nsqadmin --lookupd-http-address=127.0.0.1:4161
启动之后就可以访问http://127.0.0.1:4171/
,看到图形化界面了
data:image/s3,"s3://crabby-images/1e32f/1e32f5f1dbdd03d6fa1ad38a66963e5aab68dab4" alt=""
建立topic
curl 'http://127.0.0.1:4161/topic/create?topic=test' -d ''
data:image/s3,"s3://crabby-images/2fb51/2fb51e0d88b5941c23e408aae97bdf42f8bf6b10" alt=""
建立channel
这里建立3个channel
curl 'http://127.0.0.1:4161/channel/create?topic=test&channel=ch1' -d ''
curl 'http://127.0.0.1:4161/channel/create?topic=test&channel=ch2' -d ''
curl 'http://127.0.0.1:4161/channel/create?topic=test&channel=ch3' -d ''
data:image/s3,"s3://crabby-images/bc065/bc0651dcc17fc3ee11b102d192867e4c34c3489a" alt=""
启动nsq_to_file接收指定的topic
nsq_to_file --topic=test --channel=ch1 --output-dir=/tmp/ch1 --lookupd-http-address=127.0.0.1:4161
nsq_to_file --topic=test --channel=ch2 --output-dir=/tmp/ch2 --lookupd-http-address=127.0.0.1:4161
nsq_to_file --topic=test --channel=ch3 --output-dir=/tmp/ch3 --lookupd-http-address=127.0.0.1:4161
到这里就报如下错:
data:image/s3,"s3://crabby-images/3c213/3c213d530bb3703dd49ebe17271f419102771a5e" alt=""
并且访问http://127.0.0.1:4171/时点击topic也会报错。
data:image/s3,"s3://crabby-images/dd120/dd1205602ca1bd049aede8014b3625a884e51e3a" alt=""
看上面的报错信息,应该就是连接不上nsqd.注意到nsqd的命令行参数。
-broadcast-address string
address that will be registered with lookupd (defaults to the OS hostname) (default "PROSNAKES.local")
默认是操作系统主机名,客户端无法识别。
在Mac上应该显示指定
nsqd --lookupd-tcp-address=127.0.0.1:4160 --broadcast-address=127.0.0.1
data:image/s3,"s3://crabby-images/c2498/c249860b52305657fcbedf75201c8478b651bdd7" alt=""
这样就可以连接成功了。
向指定topic发送消息
curl -d 'hello world 1' 'http://127.0.0.1:4151/pub?topic=test'
data:image/s3,"s3://crabby-images/79d13/79d13050122205be681a964a267eee978a4e91fd" alt=""
data:image/s3,"s3://crabby-images/91a1e/91a1e32bfcbd2f83a13254374b3883cc920cc10d" alt=""
网友评论