MQTT介绍(3)java模拟MQTT的发布,订阅
MQTT目录:
在此强调一下mqtt的使用场景:
1、不可靠、网络带宽小的网络
2、运行的设备CPU、内存非常有限
在idea中简单模拟测试代码:
第一步:添加mqtt-client的依赖
- <!--验证mqtt协议-->
- <!-- https://mvnrepository.com/artifact/org.eclipse.paho/mqtt-client -->
- <dependency>
- <groupId>org.eclipse.paho</groupId>
- <artifactId>mqtt-client</artifactId>
- <version>0.4.</version>
- </dependency>
第二步:具体代码实现:
分三部分:
第一:服务端:
- package com.huhy.web.common.mqtt;
- import org.eclipse.paho.client.mqttv3.MqttClient;
- import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
- import org.eclipse.paho.client.mqttv3.MqttDeliveryToken;
- import org.eclipse.paho.client.mqttv3.MqttException;
- import org.eclipse.paho.client.mqttv3.MqttMessage;
- import org.eclipse.paho.client.mqttv3.MqttPersistenceException;
- import org.eclipse.paho.client.mqttv3.MqttTopic;
- import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
- /**
- * @Author:huhy
- * @DATE:Created on 2017/12/1 14:29
- * @Modified By:
- * @Class Description:
- */
- public class ServerMQTT {
- //tcp://MQTT安装的服务器地址:MQTT定义的端口号
- public static final String HOST = "tcp://localhost:61613";
- //定义一个主题
- public static final String TOPIC = "huhy";
- //定义MQTT的ID,可以在MQTT服务配置中指定
- private static final String clientid = "server";
- private MqttClient client;
- private MqttTopic topic11;
- private String userName = "admin"; //非必须
- private String passWord = "password"; //非必须
- private MqttMessage message;
- /**
- * 构造函数
- * @throws MqttException
- */
- public ServerMQTT() throws MqttException {
- // MemoryPersistence设置clientid的保存形式,默认为以内存保存
- client = new MqttClient(HOST, clientid, new MemoryPersistence());
- connect();
- }
- /**
- * 用来连接服务器
- */
- private void connect() {
- MqttConnectOptions options = new MqttConnectOptions();
- options.setCleanSession(false);
- options.setUserName(userName);
- options.setPassword(passWord.toCharArray());
- // 设置超时时间
- options.setConnectionTimeout();
- // 设置会话心跳时间
- options.setKeepAliveInterval();
- try {
- client.setCallback(new PushCallback());
- client.connect(options);
- topic11 = client.getTopic(TOPIC);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- /**
- *
- * @param topic
- * @param message
- * @throws MqttPersistenceException
- * @throws MqttException
- */
- public void publish(MqttTopic topic , MqttMessage message) throws MqttPersistenceException,
- MqttException {
- MqttDeliveryToken token = topic.publish(message);
- token.waitForCompletion();
- System.out.println("message is published completely! "
- + token.isComplete());
- }
- /**
- * 启动入口
- * @param args
- * @throws MqttException
- */
- public static void main(String[] args) throws MqttException, InterruptedException {
- ServerMQTT server = new ServerMQTT();
- server.message = new MqttMessage();
- server.message.setQos(); //保证消息能到达一次
- server.message.setRetained(true);
- server.message.setPayload("abcde1".getBytes());
- server.publish(server.topic11 , server.message);
- Thread.sleep();
- server.message.setPayload("abcde2".getBytes());
- server.publish(server.topic11 , server.message);
- Thread.sleep();
- server.message.setPayload("abcde3".getBytes());
- server.publish(server.topic11 , server.message);
- System.out.println(server.message.isRetained() + "------ratained状态");
- }
- }
第二部分:客户端代码:
- package com.huhy.web.common.mqtt;
- import org.eclipse.paho.client.mqttv3.MqttClient;
- import org.eclipse.paho.client.mqttv3.MqttConnectOptions;
- import org.eclipse.paho.client.mqttv3.MqttException;
- import org.eclipse.paho.client.mqttv3.MqttTopic;
- import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
- import java.util.concurrent.ScheduledExecutorService;
- /**
- * @Author:huhy
- * @DATE:Created on 2017/12/1 14:34
- * @Modified By:
- * @Class Description:
- */
- public class ClientMQTT {
- public static final String HOST = "tcp://localhost:61613";
- public static final String TOPIC1 = "huhy";
- private static final String clientid = "client";
- private MqttClient client;
- private MqttConnectOptions options;
- private String userName = "admin"; //非必须
- private String passWord = "password"; //非必须
- @SuppressWarnings("unused")
- private ScheduledExecutorService scheduler;
- private void start() {
- try {
- // host为主机名,clientid即连接MQTT的客户端ID,一般以唯一标识符表示,MemoryPersistence设置clientid的保存形式,默认为以内存保存
- client = new MqttClient(HOST, clientid, new MemoryPersistence());
- // MQTT的连接设置
- options = new MqttConnectOptions();
- // 设置是否清空session,这里如果设置为false表示服务器会保留客户端的连接记录,设置为true表示每次连接到服务器都以新的身份连接
- options.setCleanSession(false);
- // 设置连接的用户名
- options.setUserName(userName);
- // 设置连接的密码
- options.setPassword(passWord.toCharArray());
- // 设置超时时间 单位为秒
- options.setConnectionTimeout();
- // 设置会话心跳时间 单位为秒 服务器会每隔1.5*20秒的时间向客户端发送个消息判断客户端是否在线,但这个方法并没有重连的机制
- options.setKeepAliveInterval();
- // 设置回调
- client.setCallback(new PushCallback());
- MqttTopic topic = client.getTopic(TOPIC1);
- //setWill方法,如果项目中需要知道客户端是否掉线可以调用该方法。设置最终端口的通知消息
- //遗嘱 options.setWill(topic, "close".getBytes(), 2, true);
- client.connect(options);
- //订阅消息
- int[] Qos = {};
- String[] topic1 = {TOPIC1};
- client.subscribe(topic1, Qos);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- public static void main(String[] args) throws MqttException {
- ClientMQTT client = new ClientMQTT();
- client.start();
- }
- }
第三部分:关于客户端和服务端的回调函数(注意,我这说客户端和服务端是不准确的,准确的来说是叫发布和订阅,为了好理解就这样了
- package com.huhy.web.common.mqtt;
- /**
- * @Author:huhy
- * @DATE:Created on 2017/12/1 14:33
- * @Modified By:
- * @Class Description:
- */
- import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
- import org.eclipse.paho.client.mqttv3.MqttCallback;
- import org.eclipse.paho.client.mqttv3.MqttMessage;
- /**
- * 发布消息的回调类
- *
- * 必须实现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 激活此回调。
- *
- */
- public class PushCallback implements MqttCallback {
- @Override
- public void connectionLost(Throwable cause) {
- // 连接丢失后,一般在这里面进行重连
- System.out.println("连接断开,可以做重连");
- }
- @Override
- public void deliveryComplete(IMqttDeliveryToken token) {
- System.out.println("deliveryComplete---------" + token.isComplete());
- }
- @Override
- public void messageArrived(String topic, MqttMessage message) throws Exception {
- // subscribe后得到的消息会执行到这里面
- System.out.println("接收消息主题 : " + topic);
- System.out.println("接收消息Qos : " + message.getQos());
- System.out.println("接收消息内容 : " + new String(message.getPayload()));
- }
- }
关于运行分别启动就可以了,要先代理服务器启动起来,关于怎么启动看我上节的讲解
MQTT介绍(3)java模拟MQTT的发布,订阅的更多相关文章
- java实现 redis的发布订阅(简单易懂)
redis的应用场景实在太多了,现在介绍一下它的几大特性之一 发布订阅(pub/sub). 特性介绍: 什么是redis的发布订阅(pub/sub)? Pub/Sub功能(means Publ ...
- 第三节: List类型的介绍、生产者消费者模式、发布订阅模式
一. List类型基础 1.介绍 它是一个双向链表,支持左进.左出.右进.右出,所以它即可以充当队列使用,也可以充当栈使用. (1). 队列:先进先出, 可以利用List左进右出,或者右进左出(Lis ...
- java 观察这模式(发布订阅模式)
观察者设计模式定义了对象间的一种一对多的组合关系,以便一个对象的状态发生变化时,所有依赖于它的对象都得到通知并自动刷新. 发布者发布信息,订阅者获取信息,订阅了就能收到信息,没订阅就收不到信息. 抽象 ...
- MQTT介绍(1)简单介绍
MQTT目录: MQTT简单介绍 window安装MQTT服务器和client java模拟MQTT的发布,订阅 MQTT: MQTT(Message Queuing Telemetry Transp ...
- Java模拟登陆02【转载】
在使用java访问URL时,如果该URL需要身份验证,那么就不能够直接访问,因为没有登陆.那么,如何解决这个问题呢? 方法是使用java模拟登陆,登陆后记录下cookie信息,在下次发起请求时 ...
- java模拟Cookies登陆
在使用java访问URL时,如果该URL需要身份验证,那么就不能够直接访问,因为没有登陆.那么,如何解决这个问题呢? 方法是使用java模拟登陆,登陆后记录下cookie信息,在下次发起请求时时将co ...
- java 发布订阅
https://www.cnblogs.com/coderdxj/p/9627310.html java 观察这模式(发布订阅模式) 观察者设计模式定义了对象间的一种一对多的组合关系,以便一个对象 ...
- 最通俗易懂的Redis发布订阅及代码实战
发布订阅简介 除了使用List实现简单的消息队列功能以外,Redis还提供了发布订阅的消息机制.在这种机制下,消息发布者向指定频道(channel)发布消息,消息订阅者可以收到指定频道的消息,同一个频 ...
- Redis 发布订阅,小功能大用处,真没那么废材!
今天小黑哥来跟大家介绍一下 Redis 发布/订阅功能. 也许有的小伙伴对这个功能比较陌生,不太清楚这个功能是干什么的,没关系小黑哥先来举个例子. 假设我们有这么一个业务场景,在网站下单支付以后,需要 ...
随机推荐
- java调用存储过程、存储函数
需要用到的接口 接口 CallableStatement JDK文档对改接口的说明: public interface CallableStatement extends PreparedStatem ...
- java文件上传-使用apache-fileupload组件
目前文件上传的(框架)组件:Apache----fileupload .Orialiy – COS – 2008() .Jsp-smart-upload – 200M. 用fileupload上传文件 ...
- Eclipse调用hadoop2运行MR程序(转)
hadoop:hadoop2.2 ,windows myeclipse环境: Eclipse调用hadoop运行MR程序其实就是普通的java程序可以提交MR任务到集群执行而已.在Hadoop1中,只 ...
- rabbitmq实现一台服务器同时给所有的consumer发送消息(tp框架)(第四篇)
之前的学习了把消息直接publish到queue里面,然后consume掉, 真实的情况,我们会把消息先发送到exchange里面,由它来处理,是发给某一个队列,还是发给某些队列,还是丢弃掉? exc ...
- 【C#小知识】C#中一些易混淆概念总结(八)---------解析接口 分类: C# 2014-02-18 00:09 2336人阅读 评论(4) 收藏
这一篇主要来解析关于面向对象中最总要的一个概念--接口. 对于接口来说,C#是有规定使用Interface关键字来声明接口.它的声明是和类一致的.可以说接口就是一个特殊的抽象类.如下代码: cl ...
- centos下kubernetes+flannel部署(旧)
更合理的部署方式参见<Centos下Kubernetes+Flannel部署(新)> 一.准备工作 1. 三台centos主机 k8s(即kubernetes,下同)master: 10. ...
- Java性能调优:利用JMC进行性能分析
JMC, 即Java任务控制(Java Mission Control)是从Java7(7u40)和 Java8 的商业版本包括一项新的监控和控制特性. JMC 程序 (JDK_HOME\bin目录下 ...
- 数据序列化导读(2)[YAML]
上一节讲了JSON, 这一节将介绍YAML.可以认为,YAML是JSON的超集,但是更加简单易用,适合人类阅读和书写. 1. 什么是YAML? YAML是YAML Ain't Markup Lang ...
- Maven可以提交到官方公共仓库maven.org
参考http://central.sonatype.org/pages/ossrh-guide.html这个网址的操作,即可提交到maven.org. 这里有具体的实践方法:http://blog.c ...
- Linux下svn服务器搭建
初次在linux上搭建svn服务器,本来以为很繁琐,其实很简单,主要分为以下几个步骤: 1. 首先安装subversion,命令:yum install subversion 2. 创建svn仓库 ...