MQTT的学习研究(十一) IBM MQTT 简单发布订阅实例

  1. package com.etrip.push;
  2. import com.ibm.mqtt.MqttAdvancedCallback;
  3. import com.ibm.mqtt.MqttClient;
  4. import com.ibm.mqtt.MqttException;
  5. import com.ibm.mqtt.MqttSimpleCallback;
  6. /**
  7. *
  8. Android推送方案分析(MQTT/XMPP/GCM)
  9. 方案1、 使用GCM服务(Google Cloud Messaging)
  10. 简介:Google推出的云消息服务,即第二代的G2DM。
  11. 优点:Google提供的服务、原生、简单,无需实现和部署服务端。
  12. 缺点:Android版本限制(必须大于2.2版本),该服务在国内不够稳定、需要用户绑定Google帐号,受限于Google。
  13. 方案2、 使用XMPP协议(Openfire + Spark + Smack)
  14. 简介:基于XML协议的通讯协议,前身是Jabber,目前已由IETF国际标准化组织完成了标准化工作。
  15. 优点:协议成熟、强大、可扩展性强、目前主要应用于许多聊天系统中,且已有开源的Java版的开发实例androidpn。
  16. 缺点:协议较复杂、冗余(基于XML)、费流量、费电,部署硬件成本高。
  17. 方案3、 使用MQTT协议
  18. 简介:轻量级的、基于代理的“发布/订阅”模式的消息传输协议。
  19. 优点:协议简洁、小巧、可扩展性强、省流量、省电,目前已经应用到企业领域(参考:
  20. 且已有C++版的服务端组件rsmb。
  21. 缺点:不够成熟、实现较复杂、服务端组件rsmb不开源,部署硬件成本较高。
  22. 方案4、 使用HTTP轮循方式
  23. 简介:定时向HTTP服务端接口(Web Service API)获取最新消息。
  24. 优点:实现简单、可控性强,部署硬件成本低。
  25. 缺点:实时性差。
  26. 对各个方案的优缺点的研究和对比,推荐使用MQTT协议的方案进行实现,主要原因是: MQTT最快速,也最省流量
  27. (固定头长度仅为2字节),且极易扩展,适合二次开发 。接下来,我们就来分析使用MQTT方案进行Android消息的原理
  28. 和方法,并架设自己的推送服务。
  29. *
  30. */
  31. public class MQTTPubSub {
  32. private final static String CONNECTION_STRING = "tcp://192.168.208.46:1883";
  33. private final static boolean CLEAN_START = true;
  34. private final static short KEEP_ALIVE = 30;//低耗网络,但是又需要及时获取数据,心跳30s
  35. private final static String CLIENT_ID = "client1";
  36. public String PUBLISH_TOPICS="tokudu/china";
  37. private final static String[] TOPICS = {
  38. "Test/TestTopics/Topic1",
  39. "Test/TestTopics/Topic2",
  40. "Test/TestTopics/Topic3",
  41. "tokudu/china"
  42. };
  43. private final static int[] QOS_VALUES = {0, 0, 2, 0};
  44. //////////////////
  45. private MqttClient mqttClient = null;
  46. public MQTTPubSub(){
  47. try {
  48. //创建MqttClient对象
  49. mqttClient = new MqttClient(CONNECTION_STRING);
  50. //创建回调处理器
  51. SimpleCallbackHandler simpleCallbackHandler = new SimpleCallbackHandler();
  52. //mqttClient.registerSimpleHandler(simpleCallbackHandler);//注册接收消息方法
  53. mqttClient.registerAdvancedHandler(new AdvancedCallbackHandler());//注册接收消息方法
  54. //创建连接
  55. mqttClient.connect(CLIENT_ID, CLEAN_START, KEEP_ALIVE);
  56. //订阅接主题
  57. mqttClient.subscribe(TOPICS, QOS_VALUES);
  58. /**
  59. * 完成订阅后,可以增加心跳,保持网络通畅,也可以发布自己的消息
  60. */
  61. mqttClient.publish(PUBLISH_TOPICS, "keepalive".getBytes(), QOS_VALUES[0], true);
  62. } catch (MqttException e) {
  63. e.printStackTrace();
  64. }
  65. }
  66. /**
  67. * 简单回调函数,处理client接收到的主题消息
  68. * @author pig
  69. *
  70. */
  71. class SimpleCallbackHandler implements MqttSimpleCallback{
  72. /**
  73. * 当客户机和broker意外断开时触发
  74. * 可以再此处理重新订阅
  75. */
  76. @Override
  77. public void connectionLost() throws Exception {
  78. System.out.println("客户机和broker已经断开");
  79. }
  80. /**
  81. * 客户端订阅消息后,该方法负责回调接收处理消息
  82. */
  83. @Override
  84. public void publishArrived(String topicName, byte[] payload, int Qos, boolean retained) throws Exception {
  85. System.out.println("订阅主题: " + topicName);
  86. System.out.println("消息数据: " + new String(payload));
  87. System.out.println("消息级别(0,1,2): " + Qos);
  88. System.out.println("是否是实时发送的消息(false=实时,true=服务器上保留的最后消息): " + retained);
  89. }
  90. }
  91. /**
  92. * 高级回调
  93. * @author pig
  94. *
  95. */
  96. class AdvancedCallbackHandler implements MqttAdvancedCallback{
  97. @Override
  98. public void connectionLost() throws Exception {
  99. // TODO Auto-generated method stub
  100. }
  101. /**
  102. * 接收到的消息的信息
  103. */
  104. @Override
  105. public void publishArrived(String topicName, byte[] payload, int Qos,
  106. boolean retained) throws Exception {
  107. System.out.println("订阅主题: " + topicName);
  108. System.out.println("消息数据: " + new String(payload));
  109. System.out.println("消息级别(0,1,2): " + Qos);
  110. System.out.println("是否是实时发送的消息(false=实时,true=服务器上保留的最后消息): " + retained);
  111. }
  112. @Override
  113. public void published(int arg0) {
  114. // TODO Auto-generated method stub
  115. }
  116. @Override
  117. public void subscribed(int Qos, byte[] payload) {
  118. System.out.println("消息数据: " + new String(payload));
  119. System.out.println("消息级别(0,1,2): " + Qos);
  120. }
  121. @Override
  122. public void unsubscribed(int arg0) {
  123. // TODO Auto-generated method stub
  124. }
  125. }
  126. /**
  127. * @param args
  128. */
  129. public static void main(String[] args) {
  130. new MQTTPubSub();
  131. }
  132. }
时间: 2024-08-10 13:39:57

MQTT的学习研究(十一) IBM MQTT 简单发布订阅实例的相关文章

MQTT的学习研究(十三) IBM MQTTV3 简单发布订阅实例

使用IBM MQTTv3实现相关的发布订阅功能 MQTTv3的发布消息的实现: Java代码   package com.etrip.mqttv3; import com.ibm.micro.client.mqttv3.MqttClient; import com.ibm.micro.client.mqttv3.MqttDeliveryToken; import com.ibm.micro.client.mqttv3.MqttMessage; import com.ibm.micro.clien

MQTT的学习研究(三)moquette-mqtt 的使用之mqtt服务发布主题信息

接着上一篇的moquette-mqtt 的使用之broker启动之后,我们需要启动moquette-mqtt 的服务端发布消息. 在moquette-mqtt 的mqtt-client中三种方式实现发布消息的方式: 1.采用阻塞式的连接的(BlockingConnection) 2.采用回调式的连接 (CallbackConnection) 3.采用Future样式的连接(FutureConnection) 本文采用阻塞式作为实验对象. MQ 遥测传输 (MQTT) 是轻量级基于代理的发布/订阅

MQTT的学习研究(十四) MQTT moquette 的 Callback API 消息发布订阅的实现

在moquette-mqtt中提供了回调callback模式的发布和订阅但是在订阅之后没有发现有消息接收的方法,参看moquette-mqtt中Block,Future式的发布订阅基础是callback式订阅发布,但是本人在研究源代码测试,发现 callback方式接收没有成功.所以本文中只是callback式的发布和订阅没有消息接收的过程,尚未查到原因. 采用Callback式 发布主题 Java代码   package com.etrip.mqtt.callback; import java

MQTT的学习研究(十)【转】mosquitto——一个开源的mqtt代理

MQTT(MQ Telemetry Transport),消息队列遥测传输协议,轻量级的发布/订阅协议,适用于一些条件比较苛刻的环境,进行低带宽.不可靠或间歇性的通信.值得一提的是mqtt提供三种不同质量的消息服务: “至多一次”,消息发布完全依赖底层 TCP/IP 网络.会发生消息丢失或重复.这一级别可用于如下情况,环境传感器数据,丢失一次读记录无所谓,因为不久后还会有第二次发送. “至少一次”,确保消息到达,但消息重复可能会发生. “只有一次”,确保消息到达一次.这一级别可用于如下情况,在计

MQTT的学习研究(四)moquette-mqtt 的使用之mqtt Blocking API客户端订阅并接收主题信息

在上面两篇关于mqtt的broker的启动和mqtt的服务端发布主题信息之后,我们客户端需要订阅相关的信息并接收相关的主题信息. Java代码   package com.etrip.mqtt; import java.net.URISyntaxException; import org.fusesource.mqtt.client.BlockingConnection; import org.fusesource.mqtt.client.MQTT; import org.fusesource.

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-de

MQTT的学习研究(十二) MQTT moquette 的 Future API 消息发布订阅的实现

MQTT moquette 的Server发布主题 Java代码   package com.etrip.mqtt.future; import java.net.URISyntaxException; import org.fusesource.mqtt.client.FutureConnection; import org.fusesource.mqtt.client.MQTT; import org.fusesource.mqtt.client.QoS; import org.fuseso

activeMQ学习(2)---------点对点、发布订阅的消息代码实现

以下是个人在学习activemq时从网上找到的资料, 总结留给自己以后复习 点对点的实现 2 @Test public void sendMessage(){ 3 try { 4 // 创建一个连接工厂 5 String url = "tcp://localhost:61616"; 6 ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url); 7 // 设置用户名和密码,这个用户名

MQTT的学习研究(一)MQTT学习网站

MQTT的官方推荐网站: http://mqtt.org/software 使用IBM 的MQTT协议实现push消息地址: http://tokudu.com/2010/how-to-implement-push-notifications-for-android/ google code 下载MQTT moquette Broker 地址:    http://code.google.com/p/moquette-mqtt/    GIT 下载MQTT moquette client 地址: