NATS服务器部署及测试

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/51002444 NATS服务器部署及测试作者:chszs,未经博主允许不得转载。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/51002444

NATS服务器部署及测试

作者:chszs,未经博主允许不得转载。经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs

NATS的服务器是使用Golang语言开发的,其可执行文件的名字为gnatsd,表示Go NATS Daemon。NATS服务器是一个开源软件,基于MIT许可证发布。

NATS Server有Linux版、Mac版、Windows版。下面以Linux版为例,详述其部署过程。

NATS Server当前的最新版本为0.7.2版,有三种二进制发布包,详见:https://github.com/nats-io/gnatsd/releases/

  • gnatsd-v0.7.2-darwin-amd64.tar.gz for Mac的版本
  • gnatsd-v0.7.2-linux-amd64.tar.gz for Linux x64的版本
  • gnatsd-v0.7.2-linux-arm.tar.gz for Linux ARM的版本

虽然NATS Server是用Go语言开发的,但运行gnatsd无需安装Golang环境。gnatsd非常的轻量级,发布包只有2MB多,启动时可以无需任何参数,直接运行即可。

1、NATS Server的服务器配置

gnatsd接受命令行参数作为控制手段。主要的服务器参数如下。

1)服务器选项

  • -a, –addr HOST 绑定主机IP地址(默认是0.0.0.0)
  • -p, –port PORT 客户端连接NATS服务器使用的端口(默认是4222)
  • -P, –pid FILE 存储PID的文件
  • -m, –http_port PORT 使用HTTP端口作为监听端口
  • -ms, –https_port PORT 使用HTTPS端口作为监听端口
  • -c, –config FILE 指定配置文件

2)日志选项

  • -l, –log FILE 指定日志输出的文件
  • -T, –logtime 是否开启日志的时间戳(默认为true)
  • -s, –syslog 启用syslog作为日志方法
  • -r, –remote_syslog 远程日志服务器的地址(默认为udp://localhost:514)
  • -D, –debug 开启调试输出
  • -V, –trace 跟踪原始的协议
  • -DV 调试并跟踪

3)授权认证选项

  • –user user 连接需要的用户名
  • –pass password 连接需要的密码

4)TLS安全选项

  • –tls 启用TLS,不验证客户端(默认为false)
  • –tlscert FILE 服务器证书文件
  • –tlskey FILE 服务器证书私钥
  • –tlsverify 启用TLS,每一个客户端都要认证
  • –tlscacert FILE 客户端证书CA用于认证

5)集群选项

  • –routes [rurl-1, rurl-2] 路线征求并连接

6)常规选项

  • -h, –help 显示帮助消息
  • -v, –version 显示版本信息

2、NATS Server部署

1)解压

# tar zvxf /home/gnatsd-v0.7.2-linux-amd64.tar.gz 
./
LICENSE
README.md
gnatsd

2)运行

# ./gnatsd 
[10787] 2016/03/28 23:22:18.472500 [INF] Starting gnatsd version 0.7.2
[10787] 2016/03/28 23:22:18.472716 [INF] Listening for client connections on 0.0.0.0:4222
[10787] 2016/03/28 23:22:18.473127 [INF] gnatsd is ready

3)查看运行

# ps -ef |grep gnatsd
root     10787 10296  0 23:22 pts/0    00:00:00 ./gnatsd
root     10795 10669  0 23:22 pts/2    00:00:00 grep --color=auto gnats

4)远程登录

在远程机器上(我的是win 8.1),执行Telnet登录:

C:\> telnet xxx.xxx.xxx.xxx 4222

连上后Telnet立刻输出:

INFO {"server_id":"321233a60fd2a889a1a2f96bc1e95afe","version":"0.7.2","go":"go1.5.2","host":"0.0.0.0","port":4222,"auth
_required":false,"ssl_required":false,"tls_required":false,"tls_verify":false,"max_payload":1048576}

可见,gnatsd使用了Golang 1.5.2版开发。再次按下回车键,Telnet断开连接,显示:

-ERR 'Unknown Protocol Operation'
-ERR 'Parser Error'

遗失对主机的连接。

同样,gnatsd服务器端也会输出这样的信息:

[10787] 2016/03/28 23:31:47.050594 [ERR] xxx.xxx.xxx.xxx:58007 - cid:2 - Error reading from client: Client Parser ERROR, state=0, i=0: proto='"\r"...'

3、发布/订阅模式的验证

使用两个客户端进行验证。在远程Windows主机上开两个CMD命令行环境,均使用命令“C:> telnet xxx.xxx.xxx.xxx 4222”连上gnatsd服务器。为了以示区别,这里命名为客户端A和客户端B,A表示发布者,B表示订阅者。

1)订阅者B运行

订阅者B使用通配符foot.*注册主题ID为90的主题,订阅成功,gnatsd服务器返回+OK消息。

sub foo.* 90
+OK

2)发布者A运行

发布者A发布一条消息到主题foo.bar,消息有效负载的长度为5,按下回车。消息发布成功,gnatsd服务器返回+OK消息。

pub foo.bar 5
hello
+OK

3)订阅者B显示

sub foo.* 90
+OK
MSG foo.bar 90 5
hello

前两行是之前的内容,后两行是新获得的推送消息。可见,发布/订阅的消息通信成功。

4)发布者A继续执行

发布者A继续执行以下命令,消息发布成功,gnatsd服务器返回+OK消息。

pub foo.bar optional.reply.subject 5
hello
+OK

5)接收者B继续显示

MSG foo.bar 90 5
hello
PING
MSG foo.bar 90 optional.replay  ly.subject 5
hello

后面三行都是新增的消息内容,其中PING是维持连接的消息。

6)接收者B执行

接收者B执行取消订阅命令,命令消息发送成功,gnatsd服务器返回+OK消息。

unsub 90
+OK

7)发布者A运行

发布者A再次发布一条消息到主题foo.bar,消息有效负载的长度为5,按下回车。消息发布成功,gnatsd服务器返回+OK消息。

pub foo.bar 5
hell2
+OK

此时接收者B收不到消息,因为订阅已经取消了。
客户端发出心跳命令消息PING(用小写ping也是同样的),gnatsd服务器返回PONG消息。

ping
PONG
PING
PONG
相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
目录
相关文章
|
12天前
|
弹性计算 安全 Linux
使用阿里云服务器安装Z-Blog博客网站流程,新手一键部署教程
本教程教你如何在阿里云99元服务器上,通过宝塔Linux面板一键部署Z-Blog博客。基于CentOS 7.9系统,从远程连接、安装宝塔面板、开放端口到部署Z-Blog全流程详解,操作简单,新手也能轻松搭建个人博客网站。
206 13
|
12天前
|
弹性计算 Devops Shell
用阿里云 DevOps Flow 实现 ECS 部署自动化:从准备到落地的完整指南
阿里云 DevOps Flow 是一款助力开发者实现自动化部署的高效工具,支持代码流水线构建、测试与部署至ECS实例,显著提升交付效率与稳定性。本文详解如何通过 Flow 自动部署 Bash 脚本至 ECS,涵盖环境准备、流水线搭建、源码接入、部署流程设计及结果验证,助你快速上手云上自动化运维。
62 0
监控 安全 Linux
38 0
|
1月前
|
监控 Java Linux
Apache NiFi项目的编译与部署于CentOS服务器
总而言之,Apache NiFi的编译和部署虽然涉及多个步骤,但这些操作步骤简明扼要,即使是不太熟悉Java或Maven的用户也能跟随指南完成。通过遵循上述步骤,您将能够在CentOS服务器上成功部署Apache NiFi,为您的数据流处理任务建立一个功能强大的平台。
127 16
|
1月前
|
资源调度 负载均衡 JavaScript
使用PM2工具部署Vue.js应用于服务器
以上步骤完成之后,你就成功利⽤ PM⼆工具将 Vuejs 应⽰程序部署至服 务 器,并且配合反向代理实现了高效稳定访问及负载均衡功能。
84 0
|
1月前
|
运维 数据可视化 数据库
一小时搞定服务器软件部署:资深工程师实测方案
本文分享了一位运维工程师在短时间内将30个不同软件部署到新服务器上的实战经验。面对全新 Rocky Linux 系统,传统手工部署方式效率低下且容易出错。作者尝试多种自动化方案后,最终选择使用自动化部署工具,通过其内置的 Docker Compose 模板和可视化界面,实现快速、批量部署,大幅提升效率,30个应用仅用约1小时完成,显著节省时间和人力成本。
|
1月前
|
Java 关系型数据库 应用服务中间件
零基础服务器搭建教程:30分钟快速部署你的第一台服务器
入职小白突遭“下马威”,首周被要求搭建包含 Odoo ERP、NGINX、MySQL 和 Java 应用的服务器,却从零基础开始摸索,历经系统配置、软件安装、服务部署等重重难关。在时间紧、技术难的困境中,意外发现一键部署工具 ,借助其自动化能力快速完成任务,不仅赢得老板认可,也开启了自主学习之路:从 systemd 到 NGINX 配置,从 Odoo 结构到 Shell 脚本编写,逐步成长为“能搭服务器的人”。
零基础服务器搭建教程:30分钟快速部署你的第一台服务器
|
1月前
|
运维 Prometheus 监控
3 年部署经验总结:用自动化工具轻松管理 300+ 服务器开源软件
三年前接手公司IT部门时,我满怀信心,却发现部署效率低下。尽管使用了GitLab、Jenkins、Zabbix等100+开源工具,部署仍耗时费力。文档厚重如百科,却难解实际困境。一次凌晨三点的加班让我下定决心改变现状。偶然看到一篇国外博客,介绍了自动化部署的高效方式,我深受启发。
118 0

热门文章

最新文章