| Crates.io | r2d2_mysql_rustls |
| lib.rs | r2d2_mysql_rustls |
| version | 26.0.0 |
| created_at | 2025-03-17 16:23:46.21844+00 |
| updated_at | 2025-03-17 16:23:46.21844+00 |
| description | MySQL support for the r2d2 connection pool without native-tls. |
| homepage | |
| repository | https://github.com/Jormungendr/r2d2-mysql |
| max_upload_size | |
| id | 1595668 |
| size | 46,207 |
Include r2d2_mysql in the [dependencies] section of your Cargo.toml:
[dependencies]
r2d2_mysql = "24"
use std::{env, sync::Arc, thread};
use r2d2_mysql::{
mysql::{prelude::*, Opts, OptsBuilder},
r2d2, MySqlConnectionManager,
};
fn main() {
let url = env::var("DATABASE_URL").unwrap();
let opts = Opts::from_url(&url).unwrap();
let builder = OptsBuilder::from_opts(opts);
let manager = MySqlConnectionManager::new(builder);
let pool = Arc::new(r2d2::Pool::builder().max_size(4).build(manager).unwrap());
let mut tasks = vec![];
for _ in 0..3 {
let pool = pool.clone();
let th = thread::spawn(move || {
let mut conn = pool.get().expect("error getting connection from pool");
let _ = conn
.query("SELECT version()")
.map(|rows: Vec<String>| rows.is_empty())
.expect("error executing query");
});
tasks.push(th);
}
for th in tasks {
let _ = th.join();
}
}