1 stable release
1.0.0 | May 1, 2022 |
---|
#155 in Database implementations
27KB
393 lines
Whitepool - A hunky Rust+Tokio worker pool factory
-
WhitePool is a lightweight, generic pooling library for Rust+Tokio with a focus on simplicity, performance, and rock-solid disaster recovery.
-
Whitepool inspired by Elixir/Erlang Poolboy almost all Elixir/Erlang Database library rely on it for Connetcion Pooling
Example
#[tokio::main]
async fn main() {
let pool_size = 7;
let max_overflow = 4;
// Create a session for communicate with pool channel
let session = Pool::new(pool_size,
max_overflow,
|| {Box::pin(async move {
// tokio_postgres create connection
let (client, connection) =
tokio_postgres::connect("host=localhost user=postgres", NoTls)
.await.unwrap();
tokio::spawn(async move {
if let Err(e) = connection.await {
eprintln!("connection error: {}", e);
}
});
// return client
client
})}).await.run_service();
// session.clone() internally call channel mpsc::Sender::Clone
process(session.clone()).await;
process(session.clone()).await;
process(session.clone()).await;
// wait until all pending checkout handled, then shutdown
session.safe_shutdown().await
tokio::time::sleep(Duration::from_secs(100)).await;
}
pub async fn process(session: Session<Client>) {
// Checkout a resource from Pool
// block_checkout don't block your scheduler
// just await on oneshot with timeout
if let Ok(mut client) = session.block_checkout().await {
// ============== start ===================
let _rows = client
.get()
.query("SELECT $1::TEXT", &[&"hello world"])
.await.unwrap();
// ============== end ===================
// after job done, call checkin
let _ = session.checkin(client).await;
// OR if resource destroy, call this
// session.destroyed(resource).await;
}
}
Options
pool_size
: maximum pool sizemax_overflow
: maximum number of workers created if pool is emptyfactory
: is a closure create a worker
Author
- DanyalMh
License
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Dependencies
~2.3–4MB
~66K SLoC