152 个版本 (56 个稳定版)

2.5.0 2024年7月27日
2.3.4 2024年5月1日
2.3.1 2023年7月14日
2.1.1 2022年4月8日
0.25.0 2019年7月12日

#11数据库接口

Download history 24824/week @ 2024-05-03 26956/week @ 2024-05-10 26114/week @ 2024-05-17 25100/week @ 2024-05-24 30337/week @ 2024-05-31 27941/week @ 2024-06-07 25891/week @ 2024-06-14 28769/week @ 2024-06-21 25786/week @ 2024-06-28 29482/week @ 2024-07-05 32718/week @ 2024-07-12 36222/week @ 2024-07-19 36382/week @ 2024-07-26 36965/week @ 2024-08-02 38265/week @ 2024-08-09 36362/week @ 2024-08-16

每月下载量 154,813
用于 82 个 Crates (71 个直接使用)

MIT 许可证

330KB
9K SLoC

API Docs Build status Downloads Coverage Status Dependency Status LICENSE

Rust AMQP 客户端库。

此项目遵循 AMQP 0.9.1 规范,特别针对 RabbitMQ。

功能开关

  • codegen:生成代码而不是使用预生成的代码
  • native-tls:通过 native-tls 启用 amqps 支持(当设置时优先于 rustls)
  • openssl:通过 openssl 启用 amqps 支持(当设置时优先于 rustls)
  • rustls (默认):通过 rustls 启用 amqps 支持(默认使用 rustls-native-certs)
  • rustls-native-certs:与 rustls 相同,确保即使 rustls 的默认设置更改,我们仍然会使用 rustls-native-certs
  • rustls-webpki-roots-certs:与 rustls 相同,但使用 webkit-roots 代替 rustls-native-certs

与第三方运行时的集成

lapin 可以通过将运行时传递给 ConnectionProperties 来使用您选择的任何运行时。

您可以通过 executor-trait 配置要使用的执行器。

您可以通过 reactor-trait 配置要使用的反应器。

有 tokio、async-std 等实现。

示例

use futures_lite::stream::StreamExt;
use lapin::{
    options::*, publisher_confirm::Confirmation, types::FieldTable, BasicProperties, Connection,
    ConnectionProperties, Result,
};
use tracing::info;

fn main() -> Result<()> {
    if std::env::var("RUST_LOG").is_err() {
        std::env::set_var("RUST_LOG", "info");
    }

    tracing_subscriber::fmt::init();

    let addr = std::env::var("AMQP_ADDR").unwrap_or_else(|_| "amqp://127.0.0.1:5672/%2f".into());

    async_global_executor::block_on(async {
        let conn = Connection::connect(
            &addr,
            ConnectionProperties::default(),
        )
        .await?;

        info!("CONNECTED");

        let channel_a = conn.create_channel().await?;
        let channel_b = conn.create_channel().await?;

        let queue = channel_a
            .queue_declare(
                "hello",
                QueueDeclareOptions::default(),
                FieldTable::default(),
            )
            .await?;

        info!(?queue, "Declared queue");

        let mut consumer = channel_b
            .basic_consume(
                "hello",
                "my_consumer",
                BasicConsumeOptions::default(),
                FieldTable::default(),
            )
            .await?;
        async_global_executor::spawn(async move {
            info!("will consume");
            while let Some(delivery) = consumer.next().await {
                let delivery = delivery.expect("error in consumer");
                delivery
                    .ack(BasicAckOptions::default())
                    .await
                    .expect("ack");
            }
        }).detach();

        let payload = b"Hello world!";

        loop {
            let confirm = channel_a
                .basic_publish(
                    "",
                    "hello",
                    BasicPublishOptions::default(),
                    payload,
                    BasicProperties::default(),
                )
                .await?
                .await?;
            assert_eq!(confirm, Confirmation::NotRequested);
        }
    })
}

依赖项

~7–20MB
~327K SLoC