使用NATS替换NSQ为后台服务解耦
简介
满世界的后台都在向微服务架构发展,我对微服务的理解是将一个复杂的业务分拆为多个服务,由多个服务协作完成一个服务;在后台微服务架构时需要考虑高可用、一致性等问题,也要考虑在实现上、编码上的复杂程度,大多同行采用消息服务中间件对服务进行解耦,微服务多个服务间通过消息中间件进行通信。当然有不少做法是采用RPC方式,当服务多、出现网状RPC调用就会很复杂,管理上也不太方便。
之前我们采用NSQ进行通信(开发语言JAVA&Golang),NSQ的离线消息存储功能也蛮好用,如果程序挂了,重启后不会丢消息。
为什么用NAT替换NSQ,各有什么优缺点
特性 | NSQ | NAT |
---|---|---|
离线 | 支持 | 不支持 |
实时性 | 准实时 | 准实时 |
请求-应答 | 需自行封装 | 自带 |
NSQ的离线功能与消息顺序
- 当程序挂掉重启后可以继续接收处理消息,保证消息不丢失,这项功能对实时性要求不高的业务是非常好用的,可以异步模式,PUB端发送到NSQ就ok,无需关心SUB端处理成功与否以及处理及时性;
- 消息是可能乱序的,这种情况出现在既有离线消息又有内存实时消息的时候,NSQ是不保证绝对的消息顺序的;
NSQ的请求-应答模式
- NSQ本身只提供PUB-SUB,没有请求-应答模式,需要自己进行封装,当然也很简单;在某些业务场景使用纯异步模式不太合适,需要类似RPC的请求-应答模式;
使用NSQ消息中间件,部署应用服务(主备、双主)
以下例子以单个微服务部署两个应用为例子
- 两个应用订阅相同主题,使用相同的CHANNEL,同一条消息只有一个应用接收到,比如鉴权接口,只要一个鉴权通过即可;
- 两个应用订阅相同主题,使用不同的CHANNEL,同一条消息两个应用接收到,比如处理临时内存数据,两个应用都需要更新自身内部内存数据;
NAT的优势(什么性能之类的就不说,基本上都满足需求的)
参考 http://blog.csdn.net/chszs/article/details/50996679
- PUB/SUB模型 针对同一个主题只有订阅了都可以接收到,掉线了就接收不到(不存储离线消息)
- Request/Reply模型 当有多个订阅者收到请求后,只需要其中一个处理成功并Reply即算成功
- 队列模型 在PUB/SUB和Request/Reply上增加队列模型,同一条消息只有一个订阅者接收到
- 使用队列模型,当有多个订阅者时是随机选择订阅者发送消息,不保证负载均衡(切记)
以上,NAT支持异步调用、同步调用,双主、主备模式,假负载模式;做内部消息通信、为微服务架构解耦是非常合适的。
PS:参考
使用NATS替换NSQ为后台服务解耦的更多相关文章
- golang 后台服务设计精要
原文地址 守护进程 传统的后台服务一般作为守护进程(daemon)运行.linux 上创建 daemon 的步骤一般如下: 创建子进程,父进程退出: 调用系统调用 setsid() 脱离控制终端: 调 ...
- redis在Windows下以后台服务一键搭建集群(多机器)
redis在Windows下以后台服务一键搭建集群(多机器) 一.概述 此教程介绍如何在windows系统中多台机器之间布置redis集群,同时要以后台服务的模式运行.布置以脚本的形式,一键完成.多台 ...
- redis在Windows下以后台服务一键搭建集群(单机--伪集群)
redis在Windows下以后台服务一键搭建集群(单机--伪集群) 一.概述 此教程介绍如何在windows系统中同一台机器上布置redis伪集群,同时要以后台服务的模式运行.布置以脚本的形式,一键 ...
- iPhone Anywehre虚拟定位提示“后台服务未启动,请重新安装应用后使用”的解决方法
问题描述: iPhone越狱了,之后在Cydia中安装Anywhere虚拟定位,但是打开app提示:后台服务未启动,请重新安装应用后使用. 程序无法正常使用... 解决方法: 打开Cydia-已安装, ...
- 带后台服务配置的tomcat使用
tomcat服务启动,将不需要手动启动startup.bat,避免cmd窗口的出现,因为隐藏到后台服务执行: 1,下载. 官网:http://tomcat.apache.org/download-70 ...
- Android 三级联动选择城市+后台服务加载数据库
技术渣,大家将就着看 首先我们需要一个xml数据保存到数据库,这里我从QQ下面找到一个loclist.xml文件 <CountryRegion Name="中国" Code= ...
- highchart访问一次后台服务返回多张图表数据
本文承接上一篇,我们制作动态图表的时候,往往需要的不止一张图表,如果每张图表都与服务接口做一次交互的话未免太过频繁,这无论对前后还是后台都是一种压力,本文介绍一种一次访问返回多组数据的方式来减少前台与 ...
- linux/windows下启用和停止VMware后台服务的脚本
linux/windows下启用和停止VMware后台服务的脚本 linux/windows下启用和停止VMware后台服务的脚本 linux平台 windows平台 本文由乌合之众 lym瞎编,欢迎 ...
- mongodb启动后台服务
将MongoDB部署在服务器机子上时mongodb的实例应为后台服务进行的方式运行,而非前台进程,否则远程会话一关闭mongodb也跟着关闭了.本文介绍mongodb后台服务进程开启和关闭的操作. 开 ...
随机推荐
- Let's Encrypt 免费通配符 SSL 证书申请教程——但是也需要email,域名所有权等,如果是黑产用的话会这样用吗?会不会暴露自己身份???
Let's Encrypt 免费通配符 SSL 证书申请教程 from:https://blog.csdn.net/English0523/article/details/79608464 2018 ...
- nodejs安装 淘宝镜像
1◆ nodejs下载 2◆ 安装 3◆ 测试 4◆ 淘宝镜像 npm install -g cnpm --registry=https://registry.npm.taobao.org 5 ...
- Ubuntu 下matlab 查看memory函数
%Copyright (c) 2012, Michael Hirsch%All rights reserved.%%Redistribution and use in source and binar ...
- python settings :RROR 1130: Host 'XXXXXX' is not allowed to connect to this MySQL server
pymysql.err.InternalError: (1130, u"Host '127.0.0.1' is not allowed to connect to this MySQL se ...
- Zabbix3.4.7监控windows进程
1.首先,找到要监控进程的主机 创建新的监控项 然后应用集选择processes,点击添加,此处是以zabbix_agentd.exe为例添加 2. 为此监控项添加触发器 注意触发器表达式的编写,上面 ...
- Win10系列:VC++ Direct3D图形绘制1
通过前面的介绍,相信读者已经了解了如何新建一个用于开发Direct3D应用程序的项目模版,以及这个项目模版中用于绘制立体图形的主要函数.在本小节中,将通过一个具体的示例来介绍如何使用Visual St ...
- java 一些容易忽视的小点-类和对象
构造器 通过new关键字调用 构造器虽然有返回值,但是不能定义返回值类型(返回值的类型肯定是本类),不能在构造器里使用return返回某个值. 构造器是有权限的,也就是可以添加public,也可以添加 ...
- [转载] JAVA面试题和项目面试核心要点精华总结(想进大公司必看)
JAVA面试题和项目面试核心要点精华总结(想进大公司必看) JAVA面试题和项目面试核心要点精华总结(想进大公司必看)
- oo作业总结(一)
概述 经历了三次oo作业的洗礼,让我对java语言的强大以及面向对象编程有了初步的理解(当然,我是小白).本文接下来就将对自己这三次作业的代码进行分析以及分享自己的心路历程. 基础知识点考核 针对前三 ...
- Linux查看某个进程的磁盘IO读写情况 pidstat
一.现象 1)钉钉告警不断,告警如下CPU使用达到100% 普罗米修斯监控 2)查看数据库,没有发现比平时同一时段,业务量的增加.但是,数据库显示latch free等告警,验证了CPU使用过高导致. ...