#mqtt-client #protocols #stream #read-write #subscribe #publish #rust-mq

mqtt3

Mqtt3 是一个用于从流中读取/写入 MQTT 数据包的 crate。

5 个版本

使用旧的 Rust 2015

0.1.4 2016年6月13日
0.1.3 2016年6月2日
0.1.2 2016年4月18日
0.1.1 2016年4月17日
0.1.0 2016年3月21日

#14 in #subscribe

Download history 29/week @ 2024-03-25 59/week @ 2024-04-01 32/week @ 2024-04-08 40/week @ 2024-04-15 48/week @ 2024-04-22 46/week @ 2024-04-29 40/week @ 2024-05-06 45/week @ 2024-05-13 48/week @ 2024-05-20 40/week @ 2024-05-27 32/week @ 2024-06-03 26/week @ 2024-06-10 42/week @ 2024-06-17 31/week @ 2024-06-24 13/week @ 2024-07-08

92 每月下载量
3 个 crate 中使用 (2 个直接使用)

MIT 许可证

50KB
1.5K SLoC

RustMQ

Build Status

该仓库是针对 MQTT 协议的 crate 的集合。

Crates

  • mqtt3 - MQTT 协议读取/写入 Crates.io
  • netopt - TCP/SSL 连接 Crates.io
  • mqttc - Rust MQTT 客户端 Crates.io

二进制文件

  • mqttc - 控制台 MQTT 客户端

客户端

客户端具有以下功能

  • QoS 0, QoS 1, QoS 2 发布/订阅
  • 最后将消息
  • 自动 Ping
  • 自动重连
  • 支持 SSL (包括 TLS v1.1, TLS v1.2)
  • 模块化:mqtt3, netopt
  • 日志记录

连接

let netopt = NetworkOptions::new();
let mut opts = ClientOptions::new();
opts.set_reconnect(ReconnectMethod::ReconnectAfter(Duration::from_secs(1)));
let mut client = opts.connect("127.0.0.1:1883", netopt).expect("Can't connect to server");

发布

client.publish("a/b/c", "hello", PubOpt.at_least_once()).unwrap();
while (client.await().unwrap().is_some()) {};

订阅

client.subscribe("a/b/c").unwrap();
loop {
    match client.await().unwrap() {
        Some(message) => {
            println!("{:?}", message);
        },
        None => {}
    }
}

命令行界面

mqtt-cli

MQTT 客户端安装

git clone https://github.com/inre/rust-mq.git
cd rust-mq
make && make install

订阅所有主题

mqttc sub

或者尝试,

mqttc sub -a test.mosquitto.org
mqttc sub -a iot.eclipse.org
mqttc sub -a test.mosca.io
mqttc sub -a broker.hivemq.com

发布到主题

mqttc pub -t a/b/c -m "hello"

服务器

也许在未来

依赖

~165KB