#mqtt-client #tls #protocols #stream #tcp #mqttc #mqtt3

netopt

提供用于处理tcp或ssl流的选项,并在两者之间进行选择

4个版本

使用旧的Rust 2015

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

#21 in #mqtt-client

Download history 23/week @ 2023-11-20 15/week @ 2023-11-27 3/week @ 2023-12-04 13/week @ 2023-12-11 16/week @ 2023-12-18 8/week @ 2023-12-25 16/week @ 2024-01-08 13/week @ 2024-01-15 5/week @ 2024-01-22 7/week @ 2024-02-05 11/week @ 2024-02-12 35/week @ 2024-02-19 34/week @ 2024-02-26 28/week @ 2024-03-04

109 monthly downloads
用于 2 crates

MIT 许可证

62KB
2K SLoC

RustMQ

Build Status

该仓库是专注于MQTT协议的crate集合。

Crates

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

Binaries

  • 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"

服务器

也许在将来

依赖关系

~0.2–1.7MB
~39K SLoC