MQTT 介紹
- 它是一種 機器之間通信 machine-to-machine (M2M)、物聯網 Internet of Things (IoT)經常使用的一種輕量級消息傳輸協議
- 適用於網絡帶寬較低的場合
- 包含發佈、訂閱模式,經過一個代理服務器(broker),任何一個客戶端(client)均可以訂閱或者發佈某個主題的消息,而後訂閱了該主題的客戶端則會收到該消息
mqtt仍是以前公司有需求因此寫的一個demo,在這裏記錄下來,方便有人使用的時候查閱,不涉及mqtt的具體講解,只是貼代碼和運行過程。html
www.runoob.com/w3cnote/mqt…android
www.ibm.com/developerwo…apache
RaindeMacBook-Pro:bin rain$ ./apollo create mybroker
Creating apollo instance at: mybroker
Generating ssl keystore...
Warning:
JKS 密鑰庫使用專用格式。建議使用 "keytool -importkeystore -srckeystore keystore -destkeystore keystore -deststoretype pkcs12" 遷移到行業標準格式 PKCS12。
You can now start the broker by executing:
"/Users/rain/Documents/Soft/apache-apollo-1.7.1/bin/mybroker/bin/apollo-broker" run
Or you can run the broker in the background using:
"/Users/rain/Documents/Soft/apache-apollo-1.7.1/bin/mybroker/bin/apollo-broker-service" start
複製代碼
RaindeMacBook-Pro:bin rain$ ls
apollo apollo.cmd mybroker testbroker
RaindeMacBook-Pro:bin rain$ cd mybroker/
RaindeMacBook-Pro:mybroker rain$ ls
bin data etc log tmp
RaindeMacBook-Pro:mybroker rain$ cd bin
RaindeMacBook-Pro:bin rain$ ls
apollo-broker apollo-broker-service
複製代碼
<dependency>
<groupId>org.eclipse.paho</groupId>
<artifactId>org.eclipse.paho.client.mqttv3</artifactId>
<version>1.2.0</version>
</dependency>
複製代碼
import org.eclipse.paho.client.mqttv3.*;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
public class MqttServer2 {
/**
* 代理服務器ip地址
*/
public static final String MQTT_BROKER_HOST = "tcp://127.0.0.1:61613";
/**
* 訂閱標識
*/
public static final String MQTT_TOPIC = "test2";
private static String userName = "admin";
private static String password = "password";
/**
* 客戶端惟一標識
*/
public static final String MQTT_CLIENT_ID = "android_server_xiasuhuei32";
private static MqttTopic topic;
private static MqttClient client;
public static void main(String... args) {
// 推送消息
MqttMessage message = new MqttMessage();
try {
client = new MqttClient(MQTT_BROKER_HOST, MQTT_CLIENT_ID, new MemoryPersistence());
MqttConnectOptions options = new MqttConnectOptions();
options.setCleanSession(true);
options.setUserName(userName);
options.setPassword(password.toCharArray());
options.setConnectionTimeout(10);
options.setKeepAliveInterval(20);
topic = client.getTopic(MQTT_TOPIC);
message.setQos(1);
message.setRetained(false);
message.setPayload("message from server222222".getBytes());
client.connect(options);
while (true) {
MqttDeliveryToken token = topic.publish(message);
token.waitForCompletion();
System.out.println("已經發送222");
Thread.sleep(10000);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
複製代碼
import org.eclipse.paho.client.mqttv3.*;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
public class MyMqttClient {
/**
* 代理服務器ip地址
*/
public static final String MQTT_BROKER_HOST = "tcp://127.0.0.1:61613";
/**
* 客戶端惟一標識
*/
public static final String MQTT_CLIENT_ID = "android_xiasuhuei321";
/**
* 訂閱標識
*/
// public static final String MQTT_TOPIC = "xiasuhuei321";
/**
*
*/
public static final String USERNAME = "admin";
/**
* 密碼
*/
public static final String PASSWORD = "password";
public static final String TOPIC_FILTER = "test2";
private volatile static MqttClient mqttClient;
private static MqttConnectOptions options;
public static void main(String... args) {
try {
// host爲主機名,clientid即鏈接MQTT的客戶端ID,通常以客戶端惟一標識符表示,
// MemoryPersistence設置clientid的保存形式,默認爲之內存保存
mqttClient = new MqttClient(MQTT_BROKER_HOST, MQTT_CLIENT_ID, new MemoryPersistence());
// 配置參數信息
options = new MqttConnectOptions();
// 設置是否清空session,這裏若是設置爲false表示服務器會保留客戶端的鏈接記錄,
// 這裏設置爲true表示每次鏈接到服務器都以新的身份鏈接
options.setCleanSession(true);
// 設置用戶名
options.setUserName(USERNAME);
// 設置密碼
options.setPassword(PASSWORD.toCharArray());
// 設置超時時間 單位爲秒
options.setConnectionTimeout(10);
// 設置會話心跳時間 單位爲秒 服務器會每隔1.5*20秒的時間向客戶端發送個消息判斷客戶端是否在線,但這個方法並無重連的機制
options.setKeepAliveInterval(20);
// 鏈接
mqttClient.connect(options);
// 訂閱
mqttClient.subscribe(TOPIC_FILTER);
// 設置回調
mqttClient.setCallback(new MqttCallback() {
@Override
public void connectionLost(Throwable throwable) {
System.out.println("connectionLost");
}
@Override
public void messageArrived(String s, MqttMessage mqttMessage) throws Exception {
System.out.println("Topic: " + s + " Message: " + mqttMessage.toString());
}
@Override
public void deliveryComplete(IMqttDeliveryToken iMqttDeliveryToken) {
}
});
} catch (Exception e) {
e.printStackTrace();
}
}
}
複製代碼
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.persist.MemoryPersistence;
/**
*發佈端
*/
public class PublishSample {
public static void main(String[] args) {
String topic = "test2";
String content = "hello 哈哈";
int qos = 1;
String broker = "tcp://127.0.0.1:61613";
String userName = "admin";
String password = "password";
String clientId = "pubClient";
// 內存存儲
MemoryPersistence persistence = new MemoryPersistence();
try {
// 建立客戶端
MqttClient sampleClient = new MqttClient(broker, clientId, persistence);
// 建立連接參數
MqttConnectOptions connOpts = new MqttConnectOptions();
// 在從新啓動和從新鏈接時記住狀態
connOpts.setCleanSession(false);
// 設置鏈接的用戶名
connOpts.setUserName(userName);
connOpts.setPassword(password.toCharArray());
// 創建鏈接
sampleClient.connect(connOpts);
// 建立消息
MqttMessage message = new MqttMessage(content.getBytes());
// 設置消息的服務質量
message.setQos(qos);
// 發佈消息
sampleClient.publish(topic, message);
// 斷開鏈接
sampleClient.disconnect();
// 關閉客戶端
sampleClient.close();
} catch (MqttException me) {
System.out.println("reason " + me.getReasonCode());
System.out.println("msg " + me.getMessage());
System.out.println("loc " + me.getLocalizedMessage());
System.out.println("cause " + me.getCause());
System.out.println("excep " + me);
me.printStackTrace();
}
}
}
複製代碼
import org.eclipse.paho.client.mqttv3.*;
import org.eclipse.paho.client.mqttv3.persist.MemoryPersistence;
/**
*訂閱端
*/
public class SubscribeSample {
public static void main(String[] args) throws MqttException {
String HOST = "tcp://127.0.0.1:61613";
String TOPIC = "test2";
int qos = 1;
String clientid = "subClient";
String userName = "admin";
String passWord = "password";
try {
// host爲主機名,test爲clientid即鏈接MQTT的客戶端ID,通常以客戶端惟一標識符表示,MemoryPersistence設置clientid的保存形式,默認爲之內存保存
MqttClient client = new MqttClient(HOST, clientid, new MemoryPersistence());
// MQTT的鏈接設置
MqttConnectOptions options = new MqttConnectOptions();
// 設置是否清空session,這裏若是設置爲false表示服務器會保留客戶端的鏈接記錄,這裏設置爲true表示每次鏈接到服務器都以新的身份鏈接
options.setCleanSession(true);
// 設置鏈接的用戶名
options.setUserName(userName);
// 設置鏈接的密碼
options.setPassword(passWord.toCharArray());
// 設置超時時間 單位爲秒
options.setConnectionTimeout(10);
// 設置會話心跳時間 單位爲秒 服務器會每隔1.5*20秒的時間向客戶端發送個消息判斷客戶端是否在線,但這個方法並無重連的機制
options.setKeepAliveInterval(20);
// 設置回調函數
client.setCallback(new MqttCallback() {
public void connectionLost(Throwable cause) {
System.out.println("connectionLost");
}
public void messageArrived(String topic, MqttMessage message) throws Exception {
System.out.println("topic:"+topic);
System.out.println("Qos:"+message.getQos());
System.out.println("message content:"+new String(message.getPayload()));
}
public void deliveryComplete(IMqttDeliveryToken token) {
System.out.println("deliveryComplete---------"+ token.isComplete());
}
});
client.connect(options);
//訂閱消息
client.subscribe(TOPIC, qos);
} catch (Exception e) {
e.printStackTrace();
}
}
}
複製代碼