MQTT的学习研究(十一) IBM MQTT 简单发布订阅实例
- package com.etrip.push;
- import com.ibm.mqtt.MqttAdvancedCallback;
- import com.ibm.mqtt.MqttClient;
- import com.ibm.mqtt.MqttException;
- import com.ibm.mqtt.MqttSimpleCallback;
- /**
- *
- Android推送方案分析(MQTT/XMPP/GCM)
- 方案1、 使用GCM服务(Google Cloud Messaging)
- 简介:Google推出的云消息服务,即第二代的G2DM。
- 优点:Google提供的服务、原生、简单,无需实现和部署服务端。
- 缺点:Android版本限制(必须大于2.2版本),该服务在国内不够稳定、需要用户绑定Google帐号,受限于Google。
- 方案2、 使用XMPP协议(Openfire + Spark + Smack)
- 简介:基于XML协议的通讯协议,前身是Jabber,目前已由IETF国际标准化组织完成了标准化工作。
- 优点:协议成熟、强大、可扩展性强、目前主要应用于许多聊天系统中,且已有开源的Java版的开发实例androidpn。
- 缺点:协议较复杂、冗余(基于XML)、费流量、费电,部署硬件成本高。
- 方案3、 使用MQTT协议
- 简介:轻量级的、基于代理的“发布/订阅”模式的消息传输协议。
- 优点:协议简洁、小巧、可扩展性强、省流量、省电,目前已经应用到企业领域(参考:
- 且已有C++版的服务端组件rsmb。
- 缺点:不够成熟、实现较复杂、服务端组件rsmb不开源,部署硬件成本较高。
- 方案4、 使用HTTP轮循方式
- 简介:定时向HTTP服务端接口(Web Service API)获取最新消息。
- 优点:实现简单、可控性强,部署硬件成本低。
- 缺点:实时性差。
- 对各个方案的优缺点的研究和对比,推荐使用MQTT协议的方案进行实现,主要原因是: MQTT最快速,也最省流量
- (固定头长度仅为2字节),且极易扩展,适合二次开发 。接下来,我们就来分析使用MQTT方案进行Android消息的原理
- 和方法,并架设自己的推送服务。
- *
- */
- public class MQTTPubSub {
- private final static String CONNECTION_STRING = "tcp://192.168.208.46:1883";
- private final static boolean CLEAN_START = true;
- private final static short KEEP_ALIVE = 30;//低耗网络,但是又需要及时获取数据,心跳30s
- private final static String CLIENT_ID = "client1";
- public String PUBLISH_TOPICS="tokudu/china";
- private final static String[] TOPICS = {
- "Test/TestTopics/Topic1",
- "Test/TestTopics/Topic2",
- "Test/TestTopics/Topic3",
- "tokudu/china"
- };
- private final static int[] QOS_VALUES = {0, 0, 2, 0};
- //////////////////
- private MqttClient mqttClient = null;
- public MQTTPubSub(){
- try {
- //创建MqttClient对象
- mqttClient = new MqttClient(CONNECTION_STRING);
- //创建回调处理器
- SimpleCallbackHandler simpleCallbackHandler = new SimpleCallbackHandler();
- //mqttClient.registerSimpleHandler(simpleCallbackHandler);//注册接收消息方法
- mqttClient.registerAdvancedHandler(new AdvancedCallbackHandler());//注册接收消息方法
- //创建连接
- mqttClient.connect(CLIENT_ID, CLEAN_START, KEEP_ALIVE);
- //订阅接主题
- mqttClient.subscribe(TOPICS, QOS_VALUES);
- /**
- * 完成订阅后,可以增加心跳,保持网络通畅,也可以发布自己的消息
- */
- mqttClient.publish(PUBLISH_TOPICS, "keepalive".getBytes(), QOS_VALUES[0], true);
- } catch (MqttException e) {
- e.printStackTrace();
- }
- }
- /**
- * 简单回调函数,处理client接收到的主题消息
- * @author pig
- *
- */
- class SimpleCallbackHandler implements MqttSimpleCallback{
- /**
- * 当客户机和broker意外断开时触发
- * 可以再此处理重新订阅
- */
- @Override
- public void connectionLost() throws Exception {
- System.out.println("客户机和broker已经断开");
- }
- /**
- * 客户端订阅消息后,该方法负责回调接收处理消息
- */
- @Override
- public void publishArrived(String topicName, byte[] payload, int Qos, boolean retained) throws Exception {
- System.out.println("订阅主题: " + topicName);
- System.out.println("消息数据: " + new String(payload));
- System.out.println("消息级别(0,1,2): " + Qos);
- System.out.println("是否是实时发送的消息(false=实时,true=服务器上保留的最后消息): " + retained);
- }
- }
- /**
- * 高级回调
- * @author pig
- *
- */
- class AdvancedCallbackHandler implements MqttAdvancedCallback{
- @Override
- public void connectionLost() throws Exception {
- // TODO Auto-generated method stub
- }
- /**
- * 接收到的消息的信息
- */
- @Override
- public void publishArrived(String topicName, byte[] payload, int Qos,
- boolean retained) throws Exception {
- System.out.println("订阅主题: " + topicName);
- System.out.println("消息数据: " + new String(payload));
- System.out.println("消息级别(0,1,2): " + Qos);
- System.out.println("是否是实时发送的消息(false=实时,true=服务器上保留的最后消息): " + retained);
- }
- @Override
- public void published(int arg0) {
- // TODO Auto-generated method stub
- }
- @Override
- public void subscribed(int Qos, byte[] payload) {
- System.out.println("消息数据: " + new String(payload));
- System.out.println("消息级别(0,1,2): " + Qos);
- }
- @Override
- public void unsubscribed(int arg0) {
- // TODO Auto-generated method stub
- }
- }
- /**
- * @param args
- */
- public static void main(String[] args) {
- new MQTTPubSub();
- }
- }
MQTT的学习研究(十一) IBM MQTT 简单发布订阅实例的更多相关文章
- MQTT的学习研究(十三) IBM MQTTV3 简单发布订阅实例
使用IBM MQTTv3实现相关的发布订阅功能 MQTTv3的发布消息的实现: package com.etrip.mqttv3; import com.ibm.micro.client.mqttv3 ...
- RabbitMQ学习总结 第四篇:发布/订阅 Publish/Subscribe
目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...
- MQTT协议学习研究 & Mosquitto简要教程(安装和使用)
若初次接触MQTT协议,可先理解以下概念: [MQTT协议特点]——相比于RESTful架构的物联网系统,MQTT协议借助消息推送功能,可以更好地实现远程控制. [MQTT协议角色]——在RESTfu ...
- MQTT的学习研究(十四) MQTT moquette 的 Callback API 消息发布订阅的实现
在moquette-mqtt中提供了回调callback模式的发布和订阅但是在订阅之后没有发现有消息接收的方法,参看moquette-mqtt中Block,Future式的发布订阅基础是callbac ...
- MQTT的学习研究(十)【转】mosquitto——一个开源的mqtt代理
MQTT(MQ Telemetry Transport),消息队列遥测传输协议,轻量级的发布/订阅协议,适用于一些条件比较苛刻的环境,进行低带宽.不可靠或间歇性的通信.值得一提的是mqtt提供三种不同 ...
- MQTT的学习研究(三)moquette-mqtt 的使用之mqtt服务发布主题信息
接着上一篇的moquette-mqtt 的使用之broker启动之后,我们需要启动moquette-mqtt 的服务端发布消息. 在moquette-mqtt 的mqtt-client中三种方式实现发 ...
- MQTT的学习研究(十二) MQTT moquette 的 Future API 消息发布订阅的实现
MQTT moquette 的Server发布主题 package com.etrip.mqtt.future; import java.net.URISyntaxException; import ...
- MQTT的学习研究(四)moquette-mqtt 的使用之mqtt Blocking API客户端订阅并接收主题信息
在上面两篇关于mqtt的broker的启动和mqtt的服务端发布主题信息之后,我们客户端需要订阅相关的信息并接收相关的主题信息. package com.etrip.mqtt; import java ...
- MQTT的学习研究(二)moquette-mqtt 的使用之mqtt broker的启动
在MQTT 官网 (http://mqtt.org/software)中有众多MQTT的实现方式.具体参看官网,Moquette是基于Apache Mina 的模型的一个Java MQTT broke ...
随机推荐
- C语言 · 矩阵相乘 · 算法提高
算法提高 矩阵相乘 时间限制:1.0s 内存限制:256.0MB 问题描述 小明最近在为线性代数而头疼,线性代数确实很抽象(也很无聊),可惜他的老师正在讲这矩阵乘法这一段内容. 当然 ...
- XMLHttpRequest对象的常用属性与方法
方法 一, open(); 书上解释: 用于设置请求的目标url请求方法, 以及其他参数信息 个人理解: 发送请求的页面在不刷新的情况能将参数传给一个服务器进行处理, 这个方法就是将这些个参数传送过去 ...
- 标题添加菜单HeaderContextMenu
<!DOCTYPE html><html><head> <meta charset="UTF-8"> <title>Co ...
- GOF23设计模式汇总
转自:http://www.cnblogs.com/zhili/p/DesignPatternSummery.html#3037698 C#设计模式总结 一.引言 经过这段时间对设计模式的学习,自己的 ...
- RunnableException与CheckedException
Checked Exception 编译时异常 编译的时候检查你的代码可能在运行的时候抛出异常,这通常在编译的时候要去处理的. RunnableException 运行时异常,可以编译通过,但如果不处 ...
- php header函数下载文件实现代码
在php中header函数的使用很大,header不但可以向客户端发送原始的 HTTP 报头信息,同时还可以直接实现文件下载操作 header函数最常用的不是用于下载而是用于发送http类的 跳转 它 ...
- Java处理图片时编译不通过
Java中处理图片时,MyEclipse需要导入以下包: import com.sun.image.codec.jpeg.JPEGCodec; import com.sun.image.codec.j ...
- 【Java面试题】28 简述synchronized和java.util.concurrent.locks.Lock的异同 ?
主要相同点:Lock能完成synchronized所实现的所有功能 主要不同点:Lock有比synchronized更精确的线程语义和更好的性能.synchronized会自动释放锁,而Lock一定要 ...
- C#获取并修改文件扩展名的方法
本文实例讲述了C#获取并修改文件扩展名的方法.分享给大家供大家参考.具体分析如下: 这里使用C#编程的方法改变文件扩展名的文件,必须使用Path类. Path类用来解析文件系统路径的各个部分.静态方法 ...
- Xcode 5: 将新项目同步到Svn上
stackoverflow 两种办法,一是使用比较成熟的svn客户端,二是使用终端.以下为终端方法: 假设已经通过Xcode->Preferences->Accounts将reposito ...