MQTT的学习研究(五) MQTT moquette 的 Blocking API 发布消息服务端使用
参看官方文档:
* Java 为 MQ Telemetry Transport 创建异步发布程序
*在此任务中,您将遵循教程来修改第一个发布程序。通过修改,
*使应用程序能够发送发布而不等待传递确认信息。传递确认
*信息由您创建的回调类来接收。
*
*
*
*4.使客户机断开连接
* a.除去其中包含 token.waitForCompletion 表达式的语句。 主线程将继续执行,而不等待传递发布。
* b.测试客户机是否已断开连接。 将错误返回到 MqttCallback 中的 lostConnection 方法之后,MQTT 客户机将断开连接,客户机应用程序也可能断开连接。测试是否有打开的连接。
* c.使用常量 Example.quiesceTimeout 来设置使客户机停顿的最长时间。
* if (client.isConnected())
* client.disconnect(Example.quiesceTimeout);
*当满足下面三种情况的组合形式时,客户机就完成了:
* a.已经对在此会话中(如果重新启动了会话,则是在先前会话中)已发布的所有消息调用了回调。
* b.消息未完成,然而停顿时间间隔已到期。缺省情况下,停顿时间间隔为 30 秒。通过将要等待的毫秒数作为 client.disconnect 的一个参数来传递,即可更改停顿超时。
* c.在发布了某些消息并由客户机进行排队之后,但是在发送这些消息之前调用了 client.disconnect。已排队的消息尚未处于“未完成”状态。如果会话可重新启动,那么重新启动会话时就会重新发送消息。
* 缺省情况下,停顿时间间隔为 30 秒。
MQTT的消息发布代码:
- package com.etrip.wsmqtt.server;
- 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.client.mqttv3.MqttTopic;
- /**
- * 使用 Java 为 MQ Telemetry Transport 创建异步发布程序
- *
- *
- *
- *
- * 消息发布的类的具体的实现
- *
- * @author longgangbai
- *
- */
- public class WSMQTTServerPubAsync {
- public static void main(String[] args) {
- try {
- //创建MqttClient对象
- MqttClient client = new MqttClient(WSMQTTServerCommon.TCPAddress, WSMQTTServerCommon.clientId);
- //创建MQTT相关的主题
- MqttTopic topic = client.getTopic(WSMQTTServerCommon.topicString);
- //创建MQTT的消息体
- MqttMessage message = new MqttMessage();
- //设置消息传输的类型
- message.setQos(2);
- //设置是否在服务器中保存消息体
- message.setRetained(false);
- //设置消息的内容
- message.setPayload(WSMQTTServerCommon.publication.getBytes());
- //创建一个MQTT的回调类
- WSMQTTServerCallBack callback = new WSMQTTServerCallBack(WSMQTTServerCommon.clientId);
- //MqttClient绑定
- client.setCallback(callback);
- //MqttClient连接
- client.connect();
- System.out.println("Publishing \"" + message.toString()
- + "\" on topic \"" + topic.getName() + "\" with QoS = "
- + message.getQos());
- System.out.println("For client instance \"" + client.getClientId()
- + "\" on address " + client.getServerURI() + "\"");
- //发送消息并获取回执
- MqttDeliveryToken token = topic.publish(message);
- System.out.println("With delivery token \"" + token.hashCode()
- + " delivered: " + token.isComplete());
- Thread.sleep(100000000000000l);
- //关闭连接
- if (client.isConnected())
- client.disconnect(WSMQTTServerCommon.quiesceTimeout);
- System.out.println("Disconnected: delivery token \"" + token.hashCode()
- + "\" received: " + token.isComplete());
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
MQTT消息发布回调代码:
- package com.etrip.wsmqtt.server;
- import com.ibm.micro.client.mqttv3.*;
- /**
- * 发布消息的回调类
- *
- * 必须实现MqttCallback的接口并实现对应的相关接口方法
- * ◦CallBack 类将实现 MqttCallBack。每个客户机标识都需要一个回调实例。在此示例中,构造函数传递客户机标识以另存为实例数据。在回调中,将它用来标识已经启动了该回调的哪个实例。
- * ◦必须在回调类中实现三个方法:
- *
- * public void messageArrived(MqttTopic topic, MqttMessage message)
- * 接收已经预订的发布。
- *
- * public void connectionLost(Throwable cause)
- * 在断开连接时调用。
- *
- * public void deliveryComplete(MqttDeliveryToken token))
- * 接收到已经发布的 QoS 1 或 QoS 2 消息的传递令牌时调用。
- *
- *
- * ◦由 MqttClient.connect 激活此回调。
- *
- * @author longgangbai
- */
- public class WSMQTTServerCallBack implements MqttCallback {
- private String instanceData = "";
- public WSMQTTServerCallBack(String instance) {
- instanceData = instance;
- }
- /**
- * 接收到消息的回调的方法
- */
- public void messageArrived(MqttTopic topic, MqttMessage message) {
- try {
- System.out.println("Message arrived: \"" + message.toString()
- + "\" on topic \"" + topic.toString() + "\" for instance \""
- + instanceData + "\"");
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- /**
- * 消息连接丢失
- */
- public void connectionLost(Throwable cause) {
- System.out.println("Connection lost on instance \"" + instanceData
- + "\" with cause \"" + cause.getMessage() + "\" Reason code "
- + ((MqttException)cause).getReasonCode() + "\" Cause \""
- + ((MqttException)cause).getCause() + "\"");
- cause.printStackTrace();
- }
- /**
- *
- */
- public void deliveryComplete(MqttDeliveryToken token) {
- try {
- System.out.println("Delivery token \"" + token.hashCode()
- + "\" received by instance \"" + instanceData + "\"");
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
常量类:
- package com.etrip.wsmqtt.server;
- import java.util.UUID;
- /**
- *
- * 消息发布消息的常量字段
- *
- * @author longgangbai
- */
- public final class WSMQTTServerCommon {
- //发布broker的ip和端口
- public static final String TCPAddress =System.getProperty("TCPAddress", "tcp://192.168.208.46:1883");
- //客户端的Id
- public static String clientId =String.format("%-23.23s", System.getProperty("clientId", (UUID.randomUUID().toString())).trim()).replace('-', '_');
- //发布消息的主题
- public static final String topicString = System.getProperty("topicString", "china/beijing");
- //发布的消息
- public static final String publication =System.getProperty("publication", "Hello World " + String.format("%tc", System.currentTimeMillis()));
- //超时时间
- public static final int quiesceTimeout = Integer.parseInt(System.getProperty("timeout", "10000"));
- public static final int sleepTimeout = Integer.parseInt(System.getProperty("timeout", "10000"));
- public static final boolean cleanSession =Boolean.parseBoolean(System.getProperty("cleanSession", "false"));
- public static final int QoS =Integer.parseInt(System.getProperty("QoS", "1"));
- public static final boolean retained =Boolean.parseBoolean(System.getProperty("retained", "false"));
- }
MQTT的学习研究(五) MQTT moquette 的 Blocking API 发布消息服务端使用的更多相关文章
- MQTT的学习研究(十四) MQTT moquette 的 Callback API 消息发布订阅的实现
在moquette-mqtt中提供了回调callback模式的发布和订阅但是在订阅之后没有发现有消息接收的方法,参看moquette-mqtt中Block,Future式的发布订阅基础是callbac ...
- MQTT的学习研究(十二) MQTT moquette 的 Future API 消息发布订阅的实现
MQTT moquette 的Server发布主题 package com.etrip.mqtt.future; import java.net.URISyntaxException; import ...
- MQTT的学习研究(十一) IBM MQTT 简单发布订阅实例
package com.etrip.push; import com.ibm.mqtt.MqttAdvancedCallback; import com.ibm.mqtt.MqttClient; im ...
- MQTT的学习研究(四)moquette-mqtt 的使用之mqtt Blocking API客户端订阅并接收主题信息
在上面两篇关于mqtt的broker的启动和mqtt的服务端发布主题信息之后,我们客户端需要订阅相关的信息并接收相关的主题信息. package com.etrip.mqtt; import java ...
- MQTT的学习研究(三)moquette-mqtt 的使用之mqtt服务发布主题信息
接着上一篇的moquette-mqtt 的使用之broker启动之后,我们需要启动moquette-mqtt 的服务端发布消息. 在moquette-mqtt 的mqtt-client中三种方式实现发 ...
- MQTT的学习研究(二)moquette-mqtt 的使用之mqtt broker的启动
在MQTT 官网 (http://mqtt.org/software)中有众多MQTT的实现方式.具体参看官网,Moquette是基于Apache Mina 的模型的一个Java MQTT broke ...
- MQTT协议学习研究 & Mosquitto简要教程(安装和使用)
若初次接触MQTT协议,可先理解以下概念: [MQTT协议特点]——相比于RESTful架构的物联网系统,MQTT协议借助消息推送功能,可以更好地实现远程控制. [MQTT协议角色]——在RESTfu ...
- MQTT的学习研究(十)【转】mosquitto——一个开源的mqtt代理
MQTT(MQ Telemetry Transport),消息队列遥测传输协议,轻量级的发布/订阅协议,适用于一些条件比较苛刻的环境,进行低带宽.不可靠或间歇性的通信.值得一提的是mqtt提供三种不同 ...
- MQTT的学习研究(六) MQTT moquette 的 Blocking API 订阅消息客户端使用
* 使用 Java 为 MQ Telemetry Transport 创建订户 * 在此任务中,您将遵循教程来创建订户应用程序.订户将针对主题创建预订并接收该预订的发布. * 提供了一个示例订户应用程 ...
随机推荐
- JavaScrip——练习(做悬浮框)
通过HTML.CSS.JSP来实现 1.首先确定通过div嵌套来实现: 大的div里放默认显示的一层,限制其总层次高,设置超出部分隐藏 小的div里放鼠标移过去时显示的一层:3行1列的表格 1.1.什 ...
- NFS根文件系统
按照以前文档可以正确制作根文件系统,并且开发板可正确nfs挂测主机目录. 现只需修改bootargs,使内核启动时挂测文件系统即可.setenv bootargs mem=64M console=tt ...
- 【RMAN】使用RMAN增量备份刷新 Standby Database
Step 1: Create the Incremental Backup RMAN> BACKUP DEVICE TYPE DISK INCREMENTAL FROM SCN 750983 D ...
- js学习笔记33----DOM操作
前面有讲过一些DOM的基本概念. 今天来说一下DOM 的一些基本操作,主要有创建节点,追加节点,删除节点. 1.创建DOM元素: createElement(标签名) —— 创建一个节点 append ...
- (转)windows下编译最新的x264
二:<windows下编译最新的x264> X264更新的比较快,每天都有更新,但算法模块,基本结构是没有多大变化的.x264都是用C语言写的包括C99,但C99语法是在VC中是没法用的( ...
- find_circ 识别circRNA 的原理
find_circ 通过识别junction reads 来预测circRNA 和参考基因组比对完之后,首先剔除和基因组完全比对的reads,保留没比对上的reads, 这部分reads 直接比是比对 ...
- devstack install attributeError: 'module' object has no attribute '__version__'
work around: edit the file /usr/local/lib/python2.7/dist-packages/openstack/session.py and remove th ...
- Java调用FTP实例
package com.test; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStre ...
- Java基础--常用IO流使用实例
读取文本文件: private static void ioDemo1() { try { FileReader fileReader = new FileReader("C:\\Users ...
- error: Allowed memory size
错误提示 error: Allowed memory size of 8388608 bytes exhausted (tried to allocate 35 bytes) in D:\www\Th ...