【9】JMicro微服务-发布订阅消息服务
如非授权,禁止用于商业用途,转载请注明出处
作者:mynewworldyyl
1. JMicro消息服务目前实现特性
a. JMicro只支持发布订阅消息服务,不支持队列式消息服务;
b. 不支持消息持久化,所以不能保证消息一定能被消费者消费;
c. 发布消息时如果没有消费者,消息直接丢弃;
d. 如果消息按配置的重发时间间隔重复发送多次(可配置)失败,消息直接丢弃;
e. 如果消息失败重发队列超过预先配置的数量,最先失败的消息会被直接丢弃,而新失败消息直接入失败队列排队等待重发;
f. 基于以上几点,如果要求绝对可靠的消息系统,而不是高性能的消息系统,不建议使用JMicro消息服务;
JMicro追求的是简单并且高性能,如果消费者服务是正常等待消息状态,那么消息肯定能高效从消息发送者直达消费者服务,如果消费者不在线,或出了问题无法消费消息,直接失败告诉使用者系统出了问题才应该是最佳的避免问题的方法。
一味地为了解决或支持次要的需求而增加系统的复杂度本身也会增加系统出问题的隐患,特别是复杂度达到一定程度后,很可能意味着软件的失败。
Do one thing and do it well! 微服务口号。
2. 启动消息服务
新打开一个新的CMD窗口,CD进入/jmicro.pubsub,运行
mvn clean install -Pbuild-main (只需构建一次,以后可以重复运行)
运行pubsub服务
java -jar target/jmicro.pubsub-0.0.1-SNAPSHOT-jar-with-dependencies.jar
如果启动时最后出现如下信息,说明pubsub没有启动,需要将/PubSubManager/enableServer的值从false,改为true
通过ZKUI修改方式如下图:
将enableServer的值从false改为true,然后重启服务即可,因为这个值是启动时就检测,只使用一次,即时生效是指:修改值后,之后的使用会使用新的值。
3. 开发消费者
/jmicro.example.provider/src/main/java/org/jmicro/example/pubsub/impl/SimplePubsubImpl.java
@Service(maxSpeed=-1,baseTimeUnit=Constants.TIME_SECONDS) @Component public class SimplePubsubImpl implements ISimplePubsub { private final static Logger logger = LoggerFactory.getLogger(SimplePubsubImpl.class); @Subscribe(topic="/jmicro/test/topic01") public void helloTopic(PSData data) { System.out.println("helloTopic: "+data.getTopic()+", data: "+ data.getData().toString()); } @Subscribe(topic="/jmicro/test/topic01") public void testTopic(PSData data) { System.out.println("testTopic: "+data.getTopic()+", data: "+ data.getData().toString()); } @Subscribe(topic=MonitorConstant.TEST_SERVICE_METHOD_TOPIC) public void statis(PSData data) { Map<Integer,Double> ps = (Map<Integer,Double>)data.getData(); logger.info("总请求:{}, 总响应:{}, TO:{}, TOF:{}, QPS:{}" ,ps.get(MonitorConstant.CLIENT_REQ_BEGIN) ,ps.get(MonitorConstant.STATIS_TOTAL_RESP) ,ps.get(MonitorConstant.CLIENT_REQ_TIMEOUT) ,ps.get(MonitorConstant.CLIENT_REQ_TIMEOUT_FAIL) ,ps.get(MonitorConstant.STATIS_QPS) ); //System.out.println("Topic: "+data.getTopic()+", data: "+ data.getData().toString()); } }
消息消费者也是一个RPC服务,由Component和Service注解实现类,不同点是方法不再由SMethod注解,而是由Subcribe注解,并增加topic属性,值是消息的主题。
方法唯一参数是org.jmicro.api.pubsub.PSData,代码如下
public final class PSData implements Serializable{ private static final long serialVersionUID = 389875668374730999L; private Map<String,Object> context = new HashMap<>(); private byte flag = 0; private String topic; private Object data; public byte getFlag() { return flag; } public void setFlag(byte flag) { this.flag = flag; } public String getTopic() { return topic; } public void setTopic(String topic) { this.topic = topic; } public Map<String, Object> getContext() { return context; } public void setContext(Map<String, Object> context) { this.context = context; } public Object getData() { return data; } public void setData(Object data) { this.data = data; } public void put(String key,Object v) { this.context.put(key, v); } @SuppressWarnings("unchecked") public <T> T get(String key) { return (T) this.context.get(key); } }
data即是消息主体内容,可以是任意JMicro支持的参数类型,支持的参数类型后面会有专题小节详细说明,目前只需要知道:
a. Java 8种基本字据类型,字符串,java.util.Date,java.nio.ByteBuffer;
b. 由a组成的任意POJO类型;
c. 由a,b,c,d组成的任意数组类型,集合类型(LIST,SET);
d. Key为String类型,值为a,b,c,d组成的任意Map类型;
运行消费者
java -jar target/jmicro.example.provider-0.0.1-SNAPSHOT-jar-with-dependencies.jar
4. 消息生产者
public class TestPubSubServer extends JMicroBaseTestCase{ @Test public void testPresurePublish() { final Random ran = new Random(); PubSubManager psm = of.get(PubSubManager.class); AtomicInteger id = new AtomicInteger(0); Runnable r = ()->{ while(true) { try { //Thread.sleep(2000); Thread.sleep(ran.nextInt(100)); psm.publish(new HashMap<String,Object>(), TOPIC, "test pubsub server id: "+id.getAndIncrement()); } catch (Throwable e) { System.out.println(e.getMessage());; } } }; new Thread(r).start(); new Thread(r).start(); /*new Thread(r).start(); new Thread(r).start(); new Thread(r).start();*/ JMicro.waitForShutdown(); } @Test public void testPublishStringMessage() { PubSubManager psm = of.get(PubSubManager.class); psm.publish(new HashMap<String,Object>(), TOPIC, "test pubsub server"); JMicro.waitForShutdown(); } }
这是一个基于JUnit4的单元测试类,继承自org.jmicro.test.JMicroBaseTestCase,消息发布通过org.jmicro.api.pubsub.PubSubManager的三个publish重载方法实现
PubSubManager psm = of.get(PubSubManager.class); psm.publish(new HashMap<String,Object>(), TOPIC, "test pubsub server");
of是JMicroBaseTestCase成员变量,IObjectFactory类型,系统启动就可使用,类似Spring容器,目前知道点就行。
PubSubManager也是系统预实例化的消息发送接口,从of拿来即用。
Eclipse或IDEA分别运行上面3个单元测试方法,查看消费者终端输出,消费端输出代码如下图:
testPublishStringMessage:发送一个简单字符串消息,消费端输出如下图:
testPresurePublish开启多个线程重复发送消息,用于消息服务系统做压力测试 ,消费端输出如下图:
【9】JMicro微服务-发布订阅消息服务的更多相关文章
- Kafka是分布式发布-订阅消息系统
Kafka是分布式发布-订阅消息系统 https://www.biaodianfu.com/kafka.html Kafka是分布式发布-订阅消息系统.它最初由LinkedIn公司开发,之后成为Apa ...
- 分布式发布订阅消息系统 Kafka 架构设计[转]
分布式发布订阅消息系统 Kafka 架构设计 转自:http://www.oschina.net/translate/kafka-design 我们为什么要搭建该系统 Kafka是一个消息系统,原本开 ...
- Kafka(分布式发布-订阅消息系统)工作流程说明
Kafka系统架构Apache Kafka是分布式发布-订阅消息系统.它最初由LinkedIn公司开发,之后成为Apache项目的一部分.Kafka是一种快速.可扩展的.设计内在就是分布式的,分区的和 ...
- kafka 基础知识梳理-kafka是一种高吞吐量的分布式发布订阅消息系统
一.kafka 简介 今社会各种应用系统诸如商业.社交.搜索.浏览等像信息工厂一样不断的生产出各种信息,在大数据时代,我们面临如下几个挑战: 如何收集这些巨大的信息 如何分析它 如何及时做到如上两点 ...
- (三)ActiveMQ之发布- 订阅消息模式实现
一.概念 发布者/订阅者模型支持向一个特定的消息主题发布消息.0或多个订阅者可能对接收来自特定消息主题的消息感兴趣.在这种模型下,发布者和订阅者彼此不知道对方.这种模式好比是匿名公告板.这种模式被概括 ...
- JMS发布/订阅消息传送例子
前言 基于上篇文章"基于Tomcat + JNDI + ActiveMQ实现JMS的点对点消息传送"很容易就可以编写一个发布/订阅消息传送例子,相关环境准备与该篇文章基本类似,主要 ...
- 高吞吐量的分布式发布订阅消息系统Kafka--安装及测试
一.Kafka概述 Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据. 这种动作(网页浏览,搜索和其他用户的行动)是在现代网络上的许多社会功能的一个关键因 ...
- 分布式发布订阅消息系统Kafka
高吞吐量的分布式发布订阅消息系统Kafka--安装及测试 一.Kafka概述 Kafka是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据. 这种动作(网页浏览, ...
- Kafka logo分布式发布订阅消息系统 Kafka
分布式发布订阅消息系统 Kafka kafka是一种高吞吐量的分布式发布订阅消息系统,她有如下特性: 通过O(1)的磁盘数据结构提供消息的持久化,这种结构对于即使数以TB的消息存储也能够保持长时间的稳 ...
随机推荐
- Wifi小车资料
下位机代码 #include <avr/wdt.h> #include <SoftwareSerial.h> #include <EEPROM.h> //设置系统启 ...
- spring mvc 静态资源版本控制
spring bean 文件中增加 <bean class="cn.zno.smse.common.context.VersionServletContext">< ...
- (线段树 区间查询更新) Can you answer these queries? -- hdu--4027
链接: http://acm.hdu.edu.cn/showproblem.php?pid=4027 分析:因为这个操作是把一个数变成平方根,所以显得略棘手,不过如果仔细演算的话会发现一个2^64数的 ...
- Python + Robotframework + Appium 之APP自动化测试实践(二)
废话不多说,直接来实践(二),本次基于Android手机Settings模块下的search功能进行的自动化测试,代码如下 : *** Settings *** Library AppiumLibra ...
- Java性能调优:利用JFR生成性能日志
Java性能调优作为大型分布式系统提供高性能服务的必修课,其重要性不言而喻. 好的分析工具能起到事半功倍的效果,利用分析利器JMC.JFR,可以实现性能问题的准确定位. 本文主要阐述如何利用JFR生成 ...
- 从LSM-Tree、COLA-Tree谈到StackOverflow、OSQA
转自: http://blog.csdn.net/v_july_v/article/details/7526689 从LSM-Tree.COLA-Tree谈到StackOverflow.OSQA 作者 ...
- android 热更新nuwa
简介 Nuwa是比较流行的一种Android热补丁方案的开源实现,它的特点是成功率高,实现简单.当然,热补丁的方案目前已经有很多了,AndFix, Dexposed, Tinker等,之所以要分析Nu ...
- 对C++里面 的知识积累:
unique()[去重函数] unique()是C++标准库函数里面的函数,其功能是去除相邻的重复元素(只保留一个),所以使用前需要对数组进行排序 上面的一个使用中已经给出该函数的一个使用方法,对于长 ...
- hdu 5018
http://acm.hdu.edu.cn/showproblem.php?pid=5018 任意给你三个数,让你判断第三个数是否在以前两个数为开头组成的Fibonacci 数列中. 直接暴力 #in ...
- JavaOperator小框架制作【精品博客】
以下是运算小框架的制作过程,以及核心代码,完成(计算,监听,回馈等): package com.demo2.operator; /** * 运算标准接口 * @author Liudeli */ pu ...