#连接池 #bolt #mobc # #neo4j #连接管理器 #数据库

mobc-bolt

mobc 连接池的 bolt 客户端管理器

3 个版本 (重大更新)

0.2.0 2022年12月28日
0.1.0 2021年11月24日
0.0.0 2021年7月10日

#1708异步


用于 warpgrapher

MIT 许可证

235KB
4K SLoC

bolt_client 支持 mobc 连接池。

示例

use std::env;

use mobc_bolt::{
    mobc::Pool,
    bolt_client::Metadata,
    bolt_proto::{version::*, Value},
    Manager,
};

#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
    // Configure a connection manager. We'll request Bolt v4.4 or v4.3.
    let manager = Manager::new(
        env::var("BOLT_TEST_ADDR")?,
        env::var("BOLT_TEST_DOMAIN").ok(),
        [V4_4, V4_3, 0, 0],
        Metadata::from_iter(vec![
            ("user_agent", "bolt-client/X.Y.Z"),
            ("scheme", "basic"),
            ("principal", &env::var("BOLT_TEST_USERNAME")?),
            ("credentials", &env::var("BOLT_TEST_PASSWORD")?),
        ]),
    ).await?;

    // Create a connection pool. This should be shared across your application.
    let pool = Pool::builder().build(manager);

    // Fetch and use a connection from the pool
    let mut conn = pool.get().await?;
    let response = conn.run("RETURN 1 as num;", None, None).await?;
    let pull_meta = Metadata::from_iter(vec![("n", 1)]);
    let (records, response) = conn.pull(Some(pull_meta)).await?;
    assert_eq!(records[0].fields(), &[Value::from(1)]);

    Ok(())
}

依赖项

~13–25MB
~420K SLoC