#postgres #pool #async #await

archived mobc-postgres

Postgres support for the mobc connection pool

17 releases

0.8.0 Jan 22, 2023
0.7.0 Jan 13, 2021
0.6.0 Nov 14, 2020
0.5.0 Jan 9, 2020
0.3.0 Nov 30, 2019

#2041 in Database interfaces

Download history 53/week @ 2023-06-10 289/week @ 2023-06-17 183/week @ 2023-06-24 187/week @ 2023-07-01 201/week @ 2023-07-08 177/week @ 2023-07-15 226/week @ 2023-07-22 168/week @ 2023-07-29 244/week @ 2023-08-05 253/week @ 2023-08-12 357/week @ 2023-08-19 174/week @ 2023-08-26 208/week @ 2023-09-02 202/week @ 2023-09-09 230/week @ 2023-09-16 95/week @ 2023-09-23

746 downloads per month
Used in woddle

MIT/Apache

13KB

mobc-postgres

Build Status crates.io

Documentation

Example

use mobc::Pool;
use std::str::FromStr;
use std::time::Instant;
use mobc_postgres::PgConnectionManager;
use tokio_postgres::Config;
use tokio_postgres::NoTls;


#[tokio::main]
async fn main() {
    let config = Config::from_str("postgres://user:passwd@localhost:5432").unwrap();
    let manager = PgConnectionManager::new(config, NoTls);
    let pool = Pool::builder().max_open(20).build(manager);
    const MAX: usize = 5000;

    let now = Instant::now();
    let (tx, mut rx) = tokio::sync::mpsc::channel::<usize>(16);
    for i in 0..MAX {
        let pool = pool.clone();
        let mut tx_c = tx.clone();
        tokio::spawn(async move {
            let client = pool.get().await.unwrap();
            let rows = client.query("SELECT 1 + 2", &[]).await.unwrap();
            let value: i32 = rows[0].get(0);
            assert_eq!(value, 3);
            tx_c.send(i).await.unwrap();
        });
    }
    for _ in 0..MAX {
        rx.recv().await.unwrap();
    }

    println!("cost: {:?}", now.elapsed());
}

Dependencies

~10–47MB
~793K SLoC