Crate deadpool_postgres
source · [−]Expand description
Deadpool for PostgreSQL

Deadpool is a dead simple async pool for connections and objects of any type.
This crate implements a deadpool
manager for tokio-postgres
and also provides a statement
cache by wrapping tokio_postgres::Client
and tokio_postgres::Transaction
.
Features
Feature | Description | Extra dependencies | Default |
---|---|---|---|
rt_tokio_1 | Enable support for tokio crate | deadpool/rt_tokio_1 | yes |
rt_async-std_1 | Enable support for async-std crate | deadpool/rt_async-std_1 | no |
serde | Enable support for serde crate | deadpool/serde , serde/derive | no |
Important: async-std
support is currently limited to the
async-std
specific timeout function. You still need to enable
the tokio1
feature of async-std
in order to use this crate
with async-std
.
Example
use deadpool_postgres::{Config, Manager, ManagerConfig, Pool, RecyclingMethod, Runtime};
use tokio_postgres::NoTls;
#[tokio::main]
async fn main() {
let mut cfg = Config::new();
cfg.dbname = Some("deadpool".to_string());
cfg.manager = Some(ManagerConfig { recycling_method: RecyclingMethod::Fast });
let pool = cfg.create_pool(Some(Runtime::Tokio1), NoTls).unwrap();
for i in 1..10 {
let mut client = pool.get().await.unwrap();
let stmt = client.prepare_cached("SELECT 1 + $1").await.unwrap();
let rows = client.query(&stmt, &[&i]).await.unwrap();
let value: i32 = rows[0].get(0);
assert_eq!(value, i + 1);
}
}
Example with config
and dotenv
crate
PG__DBNAME=deadpool
use deadpool_postgres::{Manager, Pool, Runtime};
use dotenv::dotenv;
use tokio_postgres::NoTls;
#[derive(Debug, serde::Deserialize)]
struct Config {
pg: deadpool_postgres::Config
}
impl Config {
pub fn from_env() -> Result<Self, config::ConfigError> {
let mut cfg = config::Config::new();
cfg.set_default("pg.dbname", "deadpool");
cfg.merge(config::Environment::new().separator("__"))?;
cfg.try_into()
}
}
#[tokio::main]
async fn main() {
dotenv().ok();
let mut cfg = Config::from_env().unwrap();
let pool = cfg.pg.create_pool(Some(Runtime::Tokio1), NoTls).unwrap();
for i in 1..10 {
let mut client = pool.get().await.unwrap();
let stmt = client.prepare_cached("SELECT 1 + $1").await.unwrap();
let rows = client.query(&stmt, &[&i]).await.unwrap();
let value: i32 = rows[0].get(0);
assert_eq!(value, i + 1);
}
}
Note: The code above uses the crate name config_crate
because of the
config
feature and both features and dependencies share the same namespace.
In your own code you will probably want to use ::config::ConfigError
and
::config::Config
instead.
Example using an existing tokio_postgres::Config
object
use std::env;
use deadpool_postgres::{Manager, ManagerConfig, Pool, RecyclingMethod};
use tokio_postgres::NoTls;
#[tokio::main]
async fn main() {
let mut pg_config = tokio_postgres::Config::new();
pg_config.host_path("/run/postgresql");
pg_config.host_path("/tmp");
pg_config.user(env::var("USER").unwrap().as_str());
pg_config.dbname("deadpool");
let mgr_config = ManagerConfig {
recycling_method: RecyclingMethod::Fast
};
let mgr = Manager::from_config(pg_config, NoTls, mgr_config);
let pool = Pool::builder(mgr).max_size(16).build().unwrap();
for i in 1..10 {
let mut client = pool.get().await.unwrap();
let stmt = client.prepare_cached("SELECT 1 + $1").await.unwrap();
let rows = client.query(&stmt, &[&i]).await.unwrap();
let value: i32 = rows[0].get(0);
assert_eq!(value, i + 1);
}
}
FAQ
-
The database is unreachable. Why does the pool creation not fail?
Deadpool has identical startup and runtime behaviour and therefore the pool creation will never fail.
If you want your application to crash on startup if no database connection can be established just call
pool.get().await
right after creating the pool. -
Why are connections retrieved from the pool sometimes unuseable?
In
deadpool-postgres 0.5.5
a new recycling method was implemented which is the default since0.8
. With that recycling method the manager no longer performs a test query prior returning the connection but relies solely ontokio_postgres::Client::is_closed
instead. Under some rare circumstances (e.g. unreliable networks) this can lead totokio_postgres
not noticing a disconnect and reporting the connection as useable.The old and slightly slower recycling method can be enabled by setting
ManagerConfig::recycling_method
toRecyclingMethod::Verified
or when using theconfig
crate by settingPG__MANAGER__RECYCLING_METHOD=Verified
. -
How can I enable features of the
tokio-postgres
crate?Make sure that you depend on the same version of
tokio-postgres
asdeadpool-postgres
does and enable the needed features in your ownCrate.toml
file:[dependencies] deadpool-postgres = { version = "0.9" } tokio-postgres = { version = "0.7", features = ["with-uuid-0_8"] }
Important: The version numbers of
deadpool-postgres
andtokio-postgres
do not necessarily match. If they do it is just a coincidence that both crates have the same MAJOR and MINOR version number. -
How can I clear the statement cache?
You can call
pool.manager().statement_cache.clear()
to clear all statement caches orpool.manager().statement_cache.remove()
to remove a single statement from all caches.Important: The
ClientWrapper
also provides astatement_cache
field which hasclear()
andremove()
methods which only affect a single client.
License
Licensed under either of
- Apache License, Version 2.0 (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Re-exports
pub use tokio_postgres;
Macros
This macro creates all the type aliases usually reexported by
deadpool-* crates. Crates that implement a deadpool manager should
be considered stand alone crates and users of it should not need
to use deadpool
directly.
Structs
Wrapper around tokio_postgres::Client
with a StatementCache
.
Configuration object.
Configuration object for a Manager
.
Statistics regarding an object returned by the pool
Pool
configuration.
Representation of a cache of Statement
s.
Structure holding a reference to all StatementCache
s and providing
access for clearing all caches and removing single statements from them.
The current pool status.
Wrapper around tokio_postgres::Transaction
with a StatementCache
from the Client
object it was created by.
Wrapper around tokio_postgres::TransactionBuilder
with a
StatementCache
from the Client
object it was created by.
Enums
Channel binding configuration.
This error is returned if there is something wrong with the configuration
Possible methods of how a connection is recycled.
Enumeration for picking a runtime implementation.
TLS configuration.
Properties required of a session.
Type Definitions
Type alias for using deadpool::managed::BuildError
with tokio_postgres
.
Type alias for using deadpool::managed::CreatePoolError
with tokio_postgres
.
Type alias for using deadpool::managed::Hook
with tokio_postgres
.
Type alias for using deadpool::managed::HookError
with tokio_postgres
.
Type alias for using deadpool::managed::HookErrorCause
with tokio_postgres
.
Type alias for using deadpool::managed::Object
with tokio_postgres
.
Type alias for using deadpool::managed::Pool
with tokio_postgres
.
Type alias for using deadpool::managed::PoolBuilder
with tokio_postgres
.
Type alias for using deadpool::managed::PoolError
with tokio_postgres
.