db: connection pool (#24161)

This commit is contained in:
Hitalo Souza 2025-04-10 01:17:32 +01:00 committed by GitHub
parent 3e7414b9b7
commit bab3f23189
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 114 additions and 0 deletions

38
vlib/db/mysql/pool.v Normal file
View File

@ -0,0 +1,38 @@
module mysql
pub struct ConnectionPool {
mut:
connections chan DB
config Config
}
// new_connection_pool creates a new connection pool with the given size and configuration.
pub fn new_connection_pool(config Config, size int) !ConnectionPool {
mut connections := chan DB{cap: size}
for _ in 0 .. size {
conn := connect(config)!
connections <- conn
}
return ConnectionPool{
connections: connections
config: config
}
}
// acquire gets a connection from the pool
pub fn (mut pool ConnectionPool) acquire() !DB {
return <-pool.connections or { return error('Failed to acquire a connection from the pool') }
}
// release returns a connection back to the pool.
pub fn (mut pool ConnectionPool) release(conn DB) {
pool.connections <- conn
}
// close closes all connections in the pool.
pub fn (mut pool ConnectionPool) close() {
for _ in 0 .. pool.connections.len {
mut conn := <-pool.connections or { break }
conn.close()
}
}

38
vlib/db/pg/pool.v Normal file
View File

@ -0,0 +1,38 @@
module pg
pub struct ConnectionPool {
mut:
connections chan DB
config Config
}
// new_connection_pool creates a new connection pool with the given size and configuration.
pub fn new_connection_pool(config Config, size int) !ConnectionPool {
mut connections := chan DB{cap: size}
for _ in 0 .. size {
conn := connect(config)!
connections <- conn
}
return ConnectionPool{
connections: connections
config: config
}
}
// acquire gets a connection from the pool
pub fn (mut pool ConnectionPool) acquire() !DB {
return <-pool.connections or { return error('Failed to acquire a connection from the pool') }
}
// release returns a connection back to the pool.
pub fn (mut pool ConnectionPool) release(conn DB) {
pool.connections <- conn
}
// close closes all connections in the pool.
pub fn (mut pool ConnectionPool) close() {
for _ in 0 .. pool.connections.len {
conn := <-pool.connections or { break }
conn.close()
}
}

38
vlib/db/sqlite/pool.v Normal file
View File

@ -0,0 +1,38 @@
module sqlite
pub struct ConnectionPool {
mut:
connections chan DB
config string
}
// new_connection_pool creates a new connection pool with the given size and configuration.
pub fn new_connection_pool(config string, size int) !ConnectionPool {
mut connections := chan DB{cap: size}
for _ in 0 .. size {
conn := connect(config)!
connections <- conn
}
return ConnectionPool{
connections: connections
config: config
}
}
// acquire gets a connection from the pool
pub fn (mut pool ConnectionPool) acquire() !DB {
return <-pool.connections or { return error('Failed to acquire a connection from the pool') }
}
// release returns a connection back to the pool.
pub fn (mut pool ConnectionPool) release(conn DB) {
pool.connections <- conn
}
// close closes all connections in the pool.
pub fn (mut pool ConnectionPool) close() {
for _ in 0 .. pool.connections.len {
mut conn := <-pool.connections or { break }
conn.close() or { panic('Failed to close connection: ${err}') }
}
}