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

在上面两篇关于mqtt的broker的启动和mqtt的服务端发布主题信息之后,我们客户端需要订阅相关的信息并接收相关的主题信息。

  1. package com.etrip.mqtt;
  2. import java.net.URISyntaxException;
  3. import org.fusesource.mqtt.client.BlockingConnection;
  4. import org.fusesource.mqtt.client.MQTT;
  5. import org.fusesource.mqtt.client.Message;
  6. import org.fusesource.mqtt.client.QoS;
  7. import org.fusesource.mqtt.client.Topic;
  8. import org.slf4j.Logger;
  9. import org.slf4j.LoggerFactory;
  10. /**
  11. *
  12. * MQTT moquette 的Client 段用于订阅主题,并接收主题信息
  13. *
  14. * 采用阻塞式 订阅主题
  15. *
  16. * @author longgangbai
  17. */
  18. public class MQTTClient {
  19. private static final Logger LOG = LoggerFactory.getLogger(MQTTClient.class);
  20. private final static String CONNECTION_STRING = "tcp://192.168.208.46:1883";
  21. private final static boolean CLEAN_START = true;
  22. private final static short KEEP_ALIVE = 30;// 低耗网络,但是又需要及时获取数据,心跳30s
  23. private final static String CLIENT_ID = "publishService";
  24. public  static Topic[] topics = {
  25. new Topic("china/beijing", QoS.EXACTLY_ONCE),
  26. new Topic("china/tianjin", QoS.AT_LEAST_ONCE),
  27. new Topic("china/henan", QoS.AT_MOST_ONCE)};
  28. public final  static long RECONNECTION_ATTEMPT_MAX=6;
  29. public final  static long RECONNECTION_DELAY=2000;
  30. public final static int SEND_BUFFER_SIZE=2*1024*1024;//发送最大缓冲为2M
  31. public static void main(String[] args)   {
  32. //创建MQTT对象
  33. MQTT mqtt = new MQTT();
  34. BlockingConnection connection=null;
  35. try {
  36. //设置mqtt broker的ip和端口
  37. mqtt.setHost(CONNECTION_STRING);
  38. //连接前清空会话信息
  39. mqtt.setCleanSession(CLEAN_START);
  40. //设置重新连接的次数
  41. mqtt.setReconnectAttemptsMax(RECONNECTION_ATTEMPT_MAX);
  42. //设置重连的间隔时间
  43. mqtt.setReconnectDelay(RECONNECTION_DELAY);
  44. //设置心跳时间
  45. mqtt.setKeepAlive(KEEP_ALIVE);
  46. //设置缓冲的大小
  47. mqtt.setSendBufferSize(SEND_BUFFER_SIZE);
  48. //获取mqtt的连接对象BlockingConnection
  49. connection = mqtt.blockingConnection();
  50. //MQTT连接的创建
  51. connection.connect();
  52. //创建相关的MQTT 的主题列表
  53. Topic[] topics = {new Topic("china/beijing", QoS.AT_LEAST_ONCE)};
  54. //订阅相关的主题信息
  55. byte[] qoses = connection.subscribe(topics);
  56. //
  57. while(true){
  58. //接收订阅的消息内容
  59. Message message = connection.receive();
  60. //获取订阅的消息内容
  61. byte[] payload = message.getPayload();
  62. // process the message then:
  63. LOG.info("MQTTClient Message  Topic="+message.getTopic()+" Content :"+new String(payload));
  64. //签收消息的回执
  65. message.ack();
  66. Thread.sleep(2000);
  67. }
  68. } catch (URISyntaxException e) {
  69. // TODO Auto-generated catch block
  70. e.printStackTrace();
  71. } catch (Exception e) {
  72. // TODO Auto-generated catch block
  73. e.printStackTrace();
  74. }finally{
  75. try {
  76. connection.disconnect();
  77. } catch (Exception e) {
  78. // TODO Auto-generated catch block
  79. e.printStackTrace();
  80. }
  81. }
  82. }
  83. }
上一篇:教你如何一键反编译获取任何微信小程序源代码(图形化界面,傻瓜式操作)


下一篇:Linq to SQL -- Select、Distinct和Count、Sum、Min、Max、Avg