MQTT Java客户端Eclipse paho实现数据的发送和接收

MQTT(MQ Telemetry Transport)是IBM开发的一种网络应用层的协议

使用场景:

1、不可靠、网络带宽小的网络

2、运行的设备CPU、内存非常有限

 

特点:

1、基于发布/订阅模型的协议

2、他是二进制协议,二进制的特点就是紧凑、占用空间小。他的协议头只有2个字节

3、提供了三种消息可能性保障:最多一次 0、最少一次 1、只有一次 2

 

maven依赖

<dependency>
	<groupId>org.eclipse.paho</groupId>
	<artifactId>org.eclipse.paho.client.mqttv3</artifactId>
	<version>1.1.1</version>
</dependency>

 

发送消息示例

import org.eclipse.paho.client.mqttv3.IMqttDeliveryToken;
import org.eclipse.paho.client.mqttv3.MqttCallback;
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.MqttMessage;
import org.eclipse.paho.client.mqttv3.MqttPersistenceException;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;

/**
 * 发送数据到mqtt服务器
 * @author:涂有
 * @date 2017年8月16日 下午11:15:22
 */
public class PubMsg {
	private static int qos = 2; //只有一次
	private static String broker = "tcp://10.100.124.206:1883";
	private static String userName = "tuyou";
	private static String passWord = "tuyou";

	
	private static MqttClient connect(String clientId,String userName,
			String password) throws MqttException {
		MemoryPersistence persistence = new MemoryPersistence();
		MqttConnectOptions connOpts = new MqttConnectOptions();
		connOpts.setCleanSession(true);
		connOpts.setUserName(userName);
		connOpts.setPassword(password.toCharArray());
		connOpts.setConnectionTimeout(10);
		connOpts.setKeepAliveInterval(20);
//		String[] uris = {"tcp://10.100.124.206:1883","tcp://10.100.124.207:1883"};
//		connOpts.setServerURIs(uris);  //起到负载均衡和高可用的作用
		MqttClient mqttClient = new MqttClient(broker, clientId, persistence);
		mqttClient.setCallback(new PushCallback("test"));
		mqttClient.connect(connOpts);
		return mqttClient;
	}

	private static void pub(MqttClient sampleClient, String msg,String topic) 
			throws MqttPersistenceException, MqttException {
		MqttMessage message = new MqttMessage("ertwersdfas".getBytes());
		message.setQos(qos);
		message.setRetained(false);
		sampleClient.publish(topic, message);
	}
	
	private static void publish(String str,String clientId,String topic) throws MqttException{
		MqttClient mqttClient = connect(clientId,userName,passWord);

		if (mqttClient != null) {
			pub(mqttClient, str, topic);
			System.out.println("pub-->" + str);
		}

		if (mqttClient != null) {
			mqttClient.disconnect();
		}
	}

	public static void main(String[] args) throws MqttException {
		publish("message content","client-id-0","$share/edge/server/public/a");
	}
}

class PushCallback implements MqttCallback {
	private String threadId;
	public PushCallback(String threadId){
		this.threadId = threadId;
	}
	
    public void connectionLost(Throwable cause) {
    	
    }

    public void deliveryComplete(IMqttDeliveryToken token) {
//       System.out.println("deliveryComplete---------" + token.isComplete());
    }

    public void messageArrived(String topic, MqttMessage message) throws Exception {
    	String msg = new String(message.getPayload());
    	System.out.println(threadId + " " + msg);
    }
}

 

消费消息示例

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.persist.MemoryPersistence;

public class SubMsg {

//	 private static String topic = "$share/testgroup/wyptest1";
//	 private static String topic = "$queue/wyptest1";
//	 private static String topic = "wyptest1";
     private static int qos = 2;
     private static String broker = "tcp://10.100.124.207:1883";
     private static String userName = "tuyou";
     private static String passWord = "tuyou";
    

     private static MqttClient connect(String clientId) throws MqttException{
    	 MemoryPersistence persistence = new MemoryPersistence();
    	 MqttConnectOptions connOpts = new MqttConnectOptions();
//    	 String[] uris = {"tcp://10.100.124.206:1883","tcp://10.100.124.206:1883"};
    	 connOpts.setCleanSession(false);
         connOpts.setUserName(userName);
         connOpts.setPassword(passWord.toCharArray());
         connOpts.setConnectionTimeout(10);
         connOpts.setKeepAliveInterval(20);
//         connOpts.setServerURIs(uris);
//         connOpts.setWill(topic, "close".getBytes(), 2, true);
         MqttClient mqttClient = new MqttClient(broker, clientId, persistence);
         mqttClient.connect(connOpts);
    	 return mqttClient;
     }
     
     public static void sub(MqttClient mqttClient,String topic) throws MqttException{
         int[] Qos  = {qos};
         String[] topics = {topic};
         mqttClient.subscribe(topics, Qos);
     }
     
     
    private static void runsub(String clientId, String topic) throws MqttException{
    	MqttClient mqttClient = connect(clientId);
    	if(mqttClient != null){
			sub(mqttClient,topic);
    	}
    }
    public static void main(String[] args) throws MqttException{
    	
		runsub("client-id-1", "$share/testgroupa/edge/server/private/+");
    }
}

 

听说,打赏我的人最后都找到了真爱。

 

 

  • 8
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
MQTT 协议中,消息的发送接收是非常重要的。Eclipse Paho 是一个 MQTT 客户端库,支持多种编程语言,例如 Java、C++、Python 等。本文将重点介绍 Eclipse Paho 中消息的发送接收。 一、消息的发送 1.1 发送消息的基本流程 在 Eclipse Paho 中,发送消息的基本流程如下: 1. 创建一个 MqttClient 对象。 2. 连接到 MQTT 服务端。 3. 创建一个 MqttMessage 对象,设置消息的内容和 QoS 等级。 4. 调用 MqttClient 的 publish() 方法发送消息。 5. 断开 MQTT 连接。 1.2 代码示例 下面是一个使用 Eclipse Paho 发送消息的 Java 代码示例: ```java import org.eclipse.paho.client.mqttv3.*; import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence; public class MqttPublishSample { public static void main(String[] args) { String topic = "MQTT Examples"; String content = "Message from MqttPublishSample"; int qos = 2; String broker = "tcp://localhost:1883"; String clientId = "JavaSample"; MemoryPersistence persistence = new MemoryPersistence(); try { MqttClient sampleClient = new MqttClient(broker, clientId, persistence); MqttConnectOptions connOpts = new MqttConnectOptions(); connOpts.setCleanSession(true); sampleClient.connect(connOpts); MqttMessage message = new MqttMessage(content.getBytes()); message.setQos(qos); sampleClient.publish(topic, message); sampleClient.disconnect(); System.out.println("Message published"); } catch(MqttException me) { System.out.println("Reason: " + me.getReasonCode()); System.out.println("Message: " + me.getMessage()); System.out.println("Loc: " + me.getLocalizedMessage()); System.out.println("Cause: " + me.getCause()); System.out.println("Excep: " + me); me.printStackTrace(); } } } ``` 在这个代码示例中,我们创建了一个 MqttClient 对象,并连接到本地的 MQTT 服务器。然后,我们创建了一个 MqttMessage 对象,设置了消息的内容和 QoS 等级,并使用 publish() 方法将消息发送到指定的主题。 1.3 QoS 等级 在 MQTT 协议中,有三种不同的 QoS 等级:0、1 和 2。QoS 等级越高,消息的可靠性越高,但是网络负载也会相应增加。 - QoS 0:最多发送一次,没有确认,可能会出现消息丢失或重复。 - QoS 1:至少发送一次,确保消息至少被接收一次,但可能会出现重复消息。 - QoS 2:只发送一次,确保消息仅被接收一次,但网络负担较大。 二、消息的接收 2.1 接收消息的基本流程 在 Eclipse Paho 中,接收消息的基本流程如下: 1. 创建一个 MqttClient 对象。 2. 连接到 MQTT 服务端。 3. 创建一个 MqttCallback 对象,用于处理接收到的消息。 4. 订阅一个或多个主题。 5. 等待接收消息。 6. 断开 MQTT 连接。 2.2 代码示例 下面是一个使用 Eclipse Paho 接收消息的 Java 代码示例: ```java import org.eclipse.paho.client.mqttv3.*; import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence; public class MqttSubscribeSample { public static void main(String[] args) { String topic = "MQTT Examples"; String broker = "tcp://localhost:1883"; String clientId = "JavaSample"; MemoryPersistence persistence = new MemoryPersistence(); try { MqttClient sampleClient = new MqttClient(broker, clientId, persistence); MqttConnectOptions connOpts = new MqttConnectOptions(); connOpts.setCleanSession(true); sampleClient.connect(connOpts); sampleClient.setCallback(new MqttCallback() { public void connectionLost(Throwable cause) { System.out.println("Connection lost"); } public void messageArrived(String topic, MqttMessage message) throws Exception { System.out.println("Message received: " + new String(message.getPayload())); } public void deliveryComplete(IMqttDeliveryToken token) { System.out.println("Delivery complete"); } }); sampleClient.subscribe(topic); // Wait for messages Thread.sleep(5000); sampleClient.disconnect(); System.out.println("Disconnected"); } catch(MqttException me) { System.out.println("Reason: " + me.getReasonCode()); System.out.println("Message: " + me.getMessage()); System.out.println("Loc: " + me.getLocalizedMessage()); System.out.println("Cause: " + me.getCause()); System.out.println("Excep: " + me); me.printStackTrace(); } catch(InterruptedException e) { e.printStackTrace(); } } } ``` 在这个代码示例中,我们创建了一个 MqttClient 对象,并连接到本地的 MQTT 服务器。然后,我们创建了一个 MqttCallback 对象,用于处理接收到的消息。在 MqttCallback 的 messageArrived() 方法中,我们可以处理接收到的消息。 最后,我们使用 subscribe() 方法订阅了一个主题,并等待 5 秒钟接收消息。在接收完消息之后,我们断开了 MQTT 连接。 总结 在本文中,我们介绍了使用 Eclipse Paho 发送接收 MQTT 消息的基本流程,并提供了 Java 代码示例。同时,我们还介绍了 MQTT 的 QoS 等级。
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值