MQTT的学习研究(二)moquette-mqtt 的使用之mqtt broker的启动
在MQTT 官网 (http://mqtt.org/software)中有众多MQTT的实现方式。具体参看官网,Moquette是基于Apache Mina 的模型的一个Java MQTT broker。使用过Mina的同学发现其实broker的启动过程就是一个Mina应用的启动。
在MQTT moquette 中采用MINA作为底层消息的传递方式
本类的目的启动MQTT moquette Broker 的方式,
本文的源代码来自 moquette-broker-0.1-jar-with-dependencies.jar 中的server类
如果想直接启动 moquette-broker-0.1-jar-with-dependencies.jar的jar文件方式
可以执行一些命令实现
java -jar moquette-broker-0.1-jar-with-dependencies.jar
google code 下载MQTT moquette Broker 地址:
http://code.google.com/p/moquette-mqtt/
GIT 下载MQTT moquette client 地址:
https://github.com/fusesource/mqtt-client
在应用程序中使用MQTT的应用:
MQTT moquette 的broker服务启动代码如下:
- package com.etrip.mqtt;
- import java.io.File;
- import java.io.IOException;
- import java.net.InetAddress;
- import java.net.InetSocketAddress;
- import org.apache.mina.core.service.IoAcceptor;
- import org.apache.mina.core.service.IoServiceStatistics;
- import org.apache.mina.core.session.IdleStatus;
- import org.apache.mina.core.session.IoSession;
- import org.apache.mina.filter.codec.ProtocolCodecFilter;
- import org.apache.mina.filter.codec.demux.DemuxingProtocolDecoder;
- import org.apache.mina.filter.codec.demux.DemuxingProtocolEncoder;
- import org.apache.mina.transport.socket.nio.NioSocketAcceptor;
- import org.dna.mqtt.moquette.messaging.spi.impl.SimpleMessaging;
- import org.dna.mqtt.moquette.proto.ConnAckEncoder;
- import org.dna.mqtt.moquette.proto.ConnectDecoder;
- import org.dna.mqtt.moquette.proto.DisconnectDecoder;
- import org.dna.mqtt.moquette.proto.DisconnectEncoder;
- import org.dna.mqtt.moquette.proto.MQTTLoggingFilter;
- import org.dna.mqtt.moquette.proto.PingReqDecoder;
- import org.dna.mqtt.moquette.proto.PingRespEncoder;
- import org.dna.mqtt.moquette.proto.PubAckDecoder;
- import org.dna.mqtt.moquette.proto.PubAckEncoder;
- import org.dna.mqtt.moquette.proto.PubCompDecoder;
- import org.dna.mqtt.moquette.proto.PubCompEncoder;
- import org.dna.mqtt.moquette.proto.PubCompMessage;
- import org.dna.mqtt.moquette.proto.PubRecDecoder;
- import org.dna.mqtt.moquette.proto.PubRecEncoder;
- import org.dna.mqtt.moquette.proto.PubRelDecoder;
- import org.dna.mqtt.moquette.proto.PubRelEncoder;
- import org.dna.mqtt.moquette.proto.PublishDecoder;
- import org.dna.mqtt.moquette.proto.PublishEncoder;
- import org.dna.mqtt.moquette.proto.SubAckEncoder;
- import org.dna.mqtt.moquette.proto.SubscribeDecoder;
- import org.dna.mqtt.moquette.proto.UnsubAckEncoder;
- import org.dna.mqtt.moquette.proto.UnsubscribeDecoder;
- import org.dna.mqtt.moquette.proto.messages.ConnAckMessage;
- import org.dna.mqtt.moquette.proto.messages.DisconnectMessage;
- import org.dna.mqtt.moquette.proto.messages.PingRespMessage;
- import org.dna.mqtt.moquette.proto.messages.PubAckMessage;
- import org.dna.mqtt.moquette.proto.messages.PubRecMessage;
- import org.dna.mqtt.moquette.proto.messages.PubRelMessage;
- import org.dna.mqtt.moquette.proto.messages.PublishMessage;
- import org.dna.mqtt.moquette.proto.messages.SubAckMessage;
- import org.dna.mqtt.moquette.proto.messages.UnsubAckMessage;
- import org.dna.mqtt.moquette.server.MQTTHandler;
- import org.slf4j.Logger;
- import org.slf4j.LoggerFactory;
- /**
- *
- * 在MQTT moquette 中采用MINA作为底层消息的传递方式
- *
- * 本类的目的启动MQTT moquette Broker 的方式,
- *本文的源代码来自 moquette-broker-0.1-jar-with-dependencies.jar 中的server类
- * 如果想直接启动 moquette-broker-0.1-jar-with-dependencies.jar的jar文件方式
- * 可以执行一些命令实现
- * java -jar moquette-broker-0.1-jar-with-dependencies.jar
- *
- *
- * google code 下载MQTT moquette Broker 地址:
- * http://code.google.com/p/moquette-mqtt/
- *
- * GIT 下载MQTT moquette client 地址:
- * https://github.com/fusesource/mqtt-client
- *
- * @author longgangbai
- *
- *
- */
- public class MQTTBrokerProxyServer {
- private static final Logger LOG = LoggerFactory.getLogger(MQTTBrokerProxyServer.class);
- public static final String STORAGE_FILE_PATH = System.getProperty("user.home") + File.separator + "moquette_store.hawtdb";
- private IoAcceptor m_acceptor;
- SimpleMessaging messaging;
- public static void main(String[] args)
- throws IOException
- {
- new MQTTBrokerProxyServer().startServer();
- }
- protected void startServer() throws IOException
- {
- //编码协议类编码器
- DemuxingProtocolDecoder decoder = new DemuxingProtocolDecoder();
- decoder.addMessageDecoder(new ConnectDecoder());//连接编码
- decoder.addMessageDecoder(new PublishDecoder());//发布编码
- decoder.addMessageDecoder(new PubAckDecoder());//发布回执编码
- decoder.addMessageDecoder(new PubRelDecoder());
- decoder.addMessageDecoder(new PubRecDecoder());//接收编码
- decoder.addMessageDecoder(new PubCompDecoder());
- decoder.addMessageDecoder(new SubscribeDecoder());//订阅编码
- decoder.addMessageDecoder(new UnsubscribeDecoder());//取消订阅编码
- decoder.addMessageDecoder(new DisconnectDecoder());//断开连接编码
- decoder.addMessageDecoder(new PingReqDecoder());//心跳ping请求编码
- //解码协议类解码器
- DemuxingProtocolEncoder encoder = new DemuxingProtocolEncoder();
- encoder.addMessageEncoder(ConnAckMessage.class, new ConnAckEncoder());//连接解码
- encoder.addMessageEncoder(SubAckMessage.class, new SubAckEncoder());//订阅通知解码
- encoder.addMessageEncoder(UnsubAckMessage.class, new UnsubAckEncoder());//取消订阅解码
- encoder.addMessageEncoder(PubAckMessage.class, new PubAckEncoder());//发布回执解码
- encoder.addMessageEncoder(PubRecMessage.class, new PubRecEncoder());//接收解码
- encoder.addMessageEncoder(PubCompMessage.class, new PubCompEncoder());
- encoder.addMessageEncoder(PubRelMessage.class, new PubRelEncoder());
- encoder.addMessageEncoder(PublishMessage.class, new PublishEncoder());//发布解码
- encoder.addMessageEncoder(PingRespMessage.class, new PingRespEncoder());//心跳ping相应解码
- encoder.addMessageEncoder(DisconnectMessage.class,new DisconnectEncoder());//断开连接解码
- this.m_acceptor = new NioSocketAcceptor();
- //设置日志的过滤链
- this.m_acceptor.getFilterChain().addLast("logger", new MQTTLoggingFilter("SERVER LOG"));
- //设置编码的过滤链
- this.m_acceptor.getFilterChain().addLast("codec", new ProtocolCodecFilter(encoder, decoder));
- //创建业务处理器类
- MQTTHandler handler = new MQTTHandler();
- //创建一个处理消息体的消息
- this.messaging = SimpleMessaging.getInstance();
- this.messaging.init();
- //设置消息体
- handler.setMessaging(this.messaging);
- //设置业务处理器类
- this.m_acceptor.setHandler(handler);
- ((NioSocketAcceptor)this.m_acceptor).setReuseAddress(true);
- ((NioSocketAcceptor)this.m_acceptor).getSessionConfig().setReuseAddress(true);
- this.m_acceptor.getSessionConfig().setReadBufferSize(2048);
- this.m_acceptor.getSessionConfig().setIdleTime(IdleStatus.BOTH_IDLE, 10);
- this.m_acceptor.getStatistics().setThroughputCalculationInterval(10);
- this.m_acceptor.getStatistics().updateThroughput(System.currentTimeMillis());
- //设置端口号
- this.m_acceptor.bind(new InetSocketAddress(1883));
- //获取绑定的本地的ip地址
- LOG.info("Server binded"+InetAddress.getLocalHost().getHostAddress());
- try {
- Thread.sleep(100000000000000L);
- } catch (InterruptedException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- //销毁broker对象的各种信息
- Runtime.getRuntime().addShutdownHook(new Thread()
- {
- public void run() {
- MQTTBrokerProxyServer.this.stopServer();
- }
- });
- }
- protected void stopServer() {
- LOG.info("Server stopping...");
- this.messaging.stop();
- //Mina IO 统计类
- IoServiceStatistics statistics = this.m_acceptor.getStatistics();
- statistics.updateThroughput(System.currentTimeMillis());
- System.out.println(String.format("Total read bytes: %d, read throughtput: %f (b/s)", new Object[] { Long.valueOf(statistics.getReadBytes()), Double.valueOf(statistics.getReadBytesThroughput()) }));
- System.out.println(String.format("Total read msgs: %d, read msg throughtput: %f (msg/s)", new Object[] { Long.valueOf(statistics.getReadMessages()), Double.valueOf(statistics.getReadMessagesThroughput()) }));
- //关闭相关的会话
- for (IoSession session : this.m_acceptor.getManagedSessions().values()) {
- if ((session.isConnected()) && (!session.isClosing())) {
- session.close(false);
- }
- }
- //销毁本地IoAcceptor对象
- this.m_acceptor.unbind();
- this.m_acceptor.dispose();
- LOG.info("Server stopped");
- }
- }
由 以上代码可以看出,在发布订阅,心跳检测,连接断开,连接时候都需要创建相关的协议编码器对象类中添加相关的编码器对象。
MQTTHandler类为主要broker处理发布和订阅消息的业务处理器类。
IoServiceStatistics类信息统计类。主要统计在mina应用中读写信息的统计。
上面代码主要讲解MQTT moquette的启动下面主要讲述服务段发布消息和客户端订阅接收信息的实现。
MQTT的学习研究(二)moquette-mqtt 的使用之mqtt broker的启动的更多相关文章
- MQTT的学习研究(八)基于HTTP DELETE MQTT 订阅消息服务端使用
HTTP DELETE 订阅主题请求协议和响应协议http://publib.boulder.ibm.com/infocenter/wmqv7/v7r0/topic/com.ibm.mq.csqzau ...
- MQTT的学习研究(九)基于HTTP GET MQTT 抓取消息服务端使用
官方参看文档: HTTP GET 接收主题请求协议和响应协议http://publib.boulder.ibm.com/infocenter/wmqv7/v7r0/topic/com.ibm.mq.c ...
- MQTT的学习研究(七)基于HTTP POST MQTT 发布消息服务端使用
参阅官方文档 http://publib.boulder.ibm.com/infocenter/wmqv7/v7r0/topic/com.ibm.mq.csqzau.doc/ts21220_.htm ...
- MQTT的学习研究(六) MQTT moquette 的 Blocking API 订阅消息客户端使用
* 使用 Java 为 MQ Telemetry Transport 创建订户 * 在此任务中,您将遵循教程来创建订户应用程序.订户将针对主题创建预订并接收该预订的发布. * 提供了一个示例订户应用程 ...
- MQTT的学习研究(四)moquette-mqtt 的使用之mqtt Blocking API客户端订阅并接收主题信息
在上面两篇关于mqtt的broker的启动和mqtt的服务端发布主题信息之后,我们客户端需要订阅相关的信息并接收相关的主题信息. package com.etrip.mqtt; import java ...
- MQTT协议学习研究 & Mosquitto简要教程(安装和使用)
若初次接触MQTT协议,可先理解以下概念: [MQTT协议特点]——相比于RESTful架构的物联网系统,MQTT协议借助消息推送功能,可以更好地实现远程控制. [MQTT协议角色]——在RESTfu ...
- C++的开源跨平台日志库glog学习研究(二)--宏的使用
上一篇从整个工程上简单分析了glog,请看C++的开源跨平台日志库glog学习研究(一),这一篇对glog的实现代码入手,比如在其源码中以宏的使用最为广泛,接下来就先对各种宏的使用做一简单分析. 1. ...
- MQTT的学习研究(十二) MQTT moquette 的 Future API 消息发布订阅的实现
MQTT moquette 的Server发布主题 package com.etrip.mqtt.future; import java.net.URISyntaxException; import ...
- MQTT的学习研究(十四) MQTT moquette 的 Callback API 消息发布订阅的实现
在moquette-mqtt中提供了回调callback模式的发布和订阅但是在订阅之后没有发现有消息接收的方法,参看moquette-mqtt中Block,Future式的发布订阅基础是callbac ...
随机推荐
- sqlserver日期函数<转>
一.sql server日期时间函数Sql Server中的日期与时间函数 1. 当前系统日期.时间 select getdate() 2. dateadd 在向指定日期加上一段时间的基 ...
- Oracle数据误删除的恢复操作
flashbackup 闪回操作: 1. 打开表的闪回功能: alter table dw_stg.fm_user_play_d enable row movement; 2. 查询要闪回的表的记录信 ...
- R语言中的数据处理包dplyr、tidyr笔记
R语言中的数据处理包dplyr.tidyr笔记 dplyr包是Hadley Wickham的新作,主要用于数据清洗和整理,该包专注dataframe数据格式,从而大幅提高了数据处理速度,并且提供了 ...
- Android中使用SoundPool来播放音频
今天找素材重做FlappyBird时学习了一下怎样为应用设置背景音频,发现通过封装SoundPool类就能够非常好的做到这一点. SoundPool类比較适合播放一些类似游戏音效这样的比較短促并且较小 ...
- C#递归累计到父行
搞了半天 写了一个算法,希望能帮到需要的朋友 效果如下 水电费用是由 就是部门水费和电费累加的,而部门水费由科室水费累加起来的 表结构 DataTable dt = new DataTable(); ...
- Canvas 实现图片合成并下载合成图片
现在经常会遇到那种带二维码的推广图片,如下图所示: 1是整张推广图的背景,2是二维码.这种图片的背景是保持不变的,里面的二维码是变化的.所以我们需要把二维码单独生成然后与背景合并. 我们可以通过can ...
- nginx报错:No package erlang available
问题 yum install erlang 报错:No package erlang available 同样的,如果我们在安装nginx的时候出现"No package nginx ava ...
- GDB十分钟教程 (链接)
未联系作者,只能放个链接了. 十分赞的gdb教程. GDB十分钟教程
- Davlik虚拟机
过几天得去面试,感觉原来做的东西都忘了. 有点累,无意看了下二师兄的小论文,想来原先自己也参与过一点点,所以记录下: Dalvik虚拟机中共有3种解释器,分别时SWITCH_INTERP,THREAD ...
- 数据挖掘Apriori算法——学习笔记
关联规则.频繁项集.支持度.置信度 关联规则挖掘: 一起购买的商品 支持度(support) 支持度会随着物品增多而减小.因为是同时购买的比率. 置信度(Confidence) 频繁且强规则,有一定意 ...