MQTT(Message Queuing Telemetry Transport)是一種輕量級的消息傳輸協(xié)議,它被設(shè)計(jì)用于低帶寬和不穩(wěn)定網(wǎng)絡(luò)環(huán)境下的物聯(lián)網(wǎng)設(shè)備通信。Rust是一種安全、并發(fā)和高效的編程語言,它在系統(tǒng)編程和網(wǎng)絡(luò)編程方面有著很好的表現(xiàn)。在本教程中,我們將介紹如何使用Rust語言和paho-mqtt模塊實(shí)現(xiàn)MQTT協(xié)議的應(yīng)用。
前面寫過3篇介紹
rumqttc
的教程,本篇開始使用paho-mqtt
模塊是c庫的封裝, 支持v5協(xié)議,qos 2等更復(fù)雜的特性。
環(huán)境準(zhǔn)備
我們需要先安裝好相關(guān)的開發(fā)環(huán)境。在Cargo.toml中添加依賴:
paho-mqtt = "0.12.1"
連接MQTT服務(wù)器
在使用MQTT協(xié)議之前,我們需要先連接到MQTT服務(wù)器。以下是連接MQTT服務(wù)器的示例代碼:
extern crate paho_mqtt as mqtt;
fn main() {
let host = "tcp://localhost:1883";
let cli = mqtt::Client::new(host).unwrap();
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
}
在上面的示例代碼中,我們首先創(chuàng)建了一個(gè)MQTT客戶端對象,并指定了MQTT服務(wù)器的地址。然后,我們創(chuàng)建了一個(gè)連接選項(xiàng)對象,并設(shè)置了心跳間隔和會(huì)話清除標(biāo)志。最后,我們使用連接選項(xiàng)對象連接到MQTT服務(wù)器,并打印連接響應(yīng)信息。
發(fā)布MQTT消息
在連接到MQTT服務(wù)器之后,我們可以使用MQTT客戶端對象來發(fā)布消息。以下是發(fā)布MQTT消息的示例代碼:
extern crate paho_mqtt as mqtt;
fn main() {
let host = "tcp://localhost:1883";
let cli = mqtt::Client::new(host).unwrap();
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
let topic = "test/topic";
let payload = "Hello, MQTT!";
let message = mqtt::MessageBuilder::new()
.topic(topic)
.payload(payload)
.qos(mqtt::QOS_1)
.finalize();
let response = cli.publish(message).unwrap();
println!("Published MQTT message: {:?}", response);
}
在上面的示例代碼中,我們首先連接到MQTT服務(wù)器,然后創(chuàng)建了一個(gè)MQTT消息對象,并設(shè)置了消息主題、消息負(fù)載和消息服務(wù)質(zhì)量等級。最后,我們使用MQTT客戶端對象來發(fā)布消息,并打印發(fā)布響應(yīng)信息。
訂閱MQTT主題
在使用MQTT協(xié)議之前,我們需要先訂閱MQTT主題。以下是訂閱MQTT主題的示例代碼:
extern crate paho_mqtt as mqtt;
fn main() {
let host = "tcp://localhost:1883";
let cli = mqtt::Client::new(host).unwrap();
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
let topic = "test/topic";
let qos = mqtt::QOS_1;
let response = cli.subscribe(topic, qos).unwrap();
println!("Subscribed to MQTT topic: {:?}", response);
}
在上面的示例代碼中,我們首先連接到MQTT服務(wù)器,然后創(chuàng)建了一個(gè)MQTT訂閱對象,并設(shè)置了訂閱主題和服務(wù)質(zhì)量等級。最后,我們使用MQTT客戶端對象來訂閱主題,并打印訂閱響應(yīng)信息。
同時(shí)發(fā)布和訂閱MQTT消息
在使用MQTT協(xié)議時(shí),我們通常需要同時(shí)發(fā)布和訂閱MQTT消息。以下是同時(shí)發(fā)布和訂閱MQTT消息的示例代碼:
extern crate paho_mqtt as mqtt;
fn main() {
let host = "tcp://localhost:1883";
let cli = mqtt::Client::new(host).unwrap();
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
let topic = "test/topic";
let qos = mqtt::QOS_1;
let response = cli.subscribe(topic, qos).unwrap();
println!("Subscribed to MQTT topic: {:?}", response);
let payload = "Hello, MQTT!";
let message = mqtt::MessageBuilder::new()
.topic(topic)
.payload(payload)
.qos(mqtt::QOS_1)
.finalize();
let response = cli.publish(message).unwrap();
println!("Published MQTT message: {:?}", response);
for message in cli.start_consuming() {
println!("Received MQTT message: {:?}", message);
}
}
在上面的示例代碼中,我們首先連接到MQTT服務(wù)器,然后創(chuàng)建了一個(gè)MQTT訂閱對象,并設(shè)置了訂閱主題和服務(wù)質(zhì)量等級。接著,我們創(chuàng)建了一個(gè)MQTT消息對象,并使用MQTT客戶端對象來發(fā)布消息。最后,我們使用MQTT客戶端對象來接收消息,并打印接收到的消息。
斷開MQTT服務(wù)器連接
在使用MQTT協(xié)議之后,我們需要斷開與MQTT服務(wù)器的連接。以下是斷開MQTT服務(wù)器連接的示例代碼:
extern crate paho_mqtt as mqtt;
fn main() {
let host = "tcp://localhost:1883";
let cli = mqtt::Client::new(host).unwrap();
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
cli.disconnect(None).unwrap();
println!("Disconnected from MQTT server.");
}
在上面的示例代碼中,我們首先連接到MQTT服務(wù)器,然后使用MQTT客戶端對象來斷開與MQTT服務(wù)器的連接,并打印斷開連接信息。
進(jìn)階使用
在本節(jié)中,我們將介紹如何使用Rust語言和paho-mqtt模塊實(shí)現(xiàn)MQTT協(xié)議的進(jìn)階應(yīng)用。我們將提供2個(gè)示例,分別是:
- 使用SSL/TLS連接MQTT服務(wù)器
- 使用認(rèn)證機(jī)制連接MQTT服務(wù)器
使用SSL/TLS連接MQTT服務(wù)器
在使用MQTT協(xié)議時(shí),我們通常需要使用SSL/TLS協(xié)議來保證通信安全。以下是使用SSL/TLS連接MQTT服務(wù)器的示例代碼:
extern crate paho_mqtt as mqtt;
extern crate rustls;
use std::fs::File;
use std::io::BufReader;
use std::sync::Arc;
fn main() {
let host = "ssl://localhost:8883";
let cli = mqtt::Client::new(host).unwrap();
let mut config = rustls::ClientConfig::new();
let cert_file = &mut BufReader::new(File::open("cert.pem").unwrap());
config.root_store.add_pem_file(cert_file).unwrap();
let tls = Arc::new(rustls::ClientSession::new(&Arc::new(config), host));
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.ssl_options(mqtt::SslOptionsBuilder::new()
.ssl_version(mqtt::SslVersion::TlsV1_2)
.server_name_indication(host)
.build(tls))
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
}
在上面的示例代碼中,我們首先創(chuàng)建了一個(gè)MQTT客戶端對象,并指定了使用SSL/TLS協(xié)議連接MQTT服務(wù)器的地址。然后,我們創(chuàng)建了一個(gè)SSL/TLS配置對象,并從PEM文件中加載證書。接著,我們創(chuàng)建了一個(gè)SSL/TLS會(huì)話對象,并使用SSL/TLS配置對象和MQTT服務(wù)器地址來初始化會(huì)話對象。最后,我們創(chuàng)建了一個(gè)連接選項(xiàng)對象,并設(shè)置了心跳間隔、SSL/TLS選項(xiàng)和會(huì)話清除標(biāo)志。我們使用連接選項(xiàng)對象連接到MQTT服務(wù)器,并打印連接響應(yīng)信息。
使用認(rèn)證機(jī)制連接MQTT服務(wù)器
在使用MQTT協(xié)議時(shí),我們通常需要使用認(rèn)證機(jī)制來保證通信安全。以下是使用認(rèn)證機(jī)制連接MQTT服務(wù)器的示例代碼:
extern crate paho_mqtt as mqtt;
fn main() {
let host = "tcp://localhost:1883";
let cli = mqtt::Client::new(host).unwrap();
let username = "user";
let password = "password";
let conn_opts = mqtt::ConnectOptionsBuilder::new()
.keep_alive_interval(std::time::Duration::from_secs(20))
.user_name(username)
.password(password)
.clean_session(false)
.finalize();
let response = cli.connect(conn_opts).unwrap();
println!("Connected to MQTT server: {:?}", response);
}
在上面的示例代碼中,我們首先創(chuàng)建了一個(gè)MQTT客戶端對象,并指定了MQTT服務(wù)器的地址。然后,我們創(chuàng)建了一個(gè)連接選項(xiàng)對象,并設(shè)置了心跳間隔、用戶名、密碼和會(huì)話清除標(biāo)志。我們使用連接選項(xiàng)對象連接到MQTT服務(wù)器,并打印連接響應(yīng)信息。
總結(jié)
在本教程中,我們介紹了如何使用Rust語言和paho-mqtt模塊實(shí)現(xiàn)MQTT協(xié)議的應(yīng)用。我們提供了幾個(gè)基礎(chǔ)應(yīng)用的示例代碼,包括連接MQTT服務(wù)器、發(fā)布MQTT消息、訂閱MQTT主題、同時(shí)發(fā)布和訂閱MQTT消息和斷開MQTT服務(wù)器連接。
-
模塊
+關(guān)注
關(guān)注
7文章
2695瀏覽量
47431 -
網(wǎng)絡(luò)
+關(guān)注
關(guān)注
14文章
7553瀏覽量
88729 -
傳輸協(xié)議
+關(guān)注
關(guān)注
0文章
78瀏覽量
11447 -
MQTT
+關(guān)注
關(guān)注
5文章
650瀏覽量
22487 -
rust語言
+關(guān)注
關(guān)注
0文章
57瀏覽量
3009
發(fā)布評論請先 登錄
相關(guān)推薦
評論