jardisadapter / dbconnection
PDO connection factory with read/write splitting, round-robin load balancing, and automatic health checks
Requires
- php: >=8.2
- ext-pdo: *
- jardissupport/contract: ^1.0
- jardissupport/dotenv: ^1.0
Requires (Dev)
- phpstan/phpstan: ^2.0.4
- phpunit/phpunit: ^10.5
- squizlabs/php_codesniffer: ^3.11.2
This package is auto-updated.
Last update: 2026-03-31 07:51:00 UTC
README
Part of the Jardis Business Platform — Enterprise-grade PHP components for Domain-Driven Design
PDO connection factory with read/write splitting, round-robin load balancing, and automatic health checks. Create typed connections for MySQL, PostgreSQL, or SQLite via ConnectionFactory, then compose them into a ConnectionPool for replica-aware query routing. Health checks run SELECT 1 with a configurable TTL cache so failover is fast and non-intrusive.
Features
- Read/Write Splitting — Route writes to the primary and reads to replicas automatically
- Round-Robin Load Balancing — Distributes read queries evenly across all configured readers
- Health Checks —
SELECT 1validation with positive and negative result caching - Transaction Support —
beginTransaction(),commit(),rollback(),inTransaction()on every connection - Reconnect —
reconnect()rebuilds the PDO connection from config on failure - MySQL / PostgreSQL / SQLite — Dedicated factory methods per driver with typed config
- External PDO Wrapping —
fromPdo()integrates existing connections without refactoring - ConnectionPool Stats —
getStats()exposes reads, writes, and failover counts at runtime
Installation
composer require jardisadapter/dbconnection
Quick Start
use JardisAdapter\DbConnection\Factory\ConnectionFactory; $factory = new ConnectionFactory(); // Create a MySQL connection and run a query $connection = $factory->mysql( host: 'localhost', user: 'app_user', password: 'secret', database: 'mydb' ); $pdo = $connection->pdo(); $users = $pdo->query('SELECT * FROM users')->fetchAll();
Advanced Usage
use JardisAdapter\DbConnection\Factory\ConnectionFactory; use JardisAdapter\DbConnection\ConnectionPool; use JardisAdapter\DbConnection\Config\ConnectionPoolConfig; $factory = new ConnectionFactory(); // Primary writer + two read replicas $pool = new ConnectionPool( writer: $factory->mysql('primary.db', 'user', 'secret', 'mydb'), readers: [ $factory->mysql('replica1.db', 'user', 'secret', 'mydb'), $factory->mysql('replica2.db', 'user', 'secret', 'mydb'), ], config: new ConnectionPoolConfig(validateConnections: true) ); // Writes go to the primary $pool->getWriter()->pdo()->exec('INSERT INTO orders (total) VALUES (99.99)'); // Reads are distributed round-robin across replicas $orders = $pool->getReader()->pdo()->query('SELECT * FROM orders')->fetchAll(); // Inspect pool activity $stats = $pool->getStats(); // ['reads' => 1, 'writes' => 1, 'failovers' => 0, 'readers' => 2] // Transactions on a dedicated connection $conn = $factory->postgres('localhost', 'user', 'secret', 'mydb'); $conn->beginTransaction(); try { $conn->pdo()->exec('UPDATE accounts SET balance = balance - 100 WHERE id = 1'); $conn->pdo()->exec('UPDATE accounts SET balance = balance + 100 WHERE id = 2'); $conn->commit(); } catch (\Throwable $e) { $conn->rollback(); throw $e; } // Wrap an existing PDO from a legacy system $legacy = $factory->fromPdo($existingPdo);
PDO Connection Options
All driver factory methods accept an options array passed directly to the PDO constructor. This is useful for long-running processes (RoadRunner, Swoole, FrankenPHP) where persistent connections avoid reconnect overhead per request:
use PDO; $connection = $factory->mysql( host: 'localhost', user: 'app_user', password: 'secret', database: 'mydb', options: [ PDO::ATTR_PERSISTENT => true, PDO::ATTR_TIMEOUT => 5, ] );
Note: Persistent connections are reused across requests within the same worker process. Ensure your database server is configured for the expected number of concurrent connections (workers × connections per worker).
These options apply per connection — in a ConnectionPool, each connection can have its own settings.
Documentation
Full documentation, guides, and API reference:
docs.jardis.io/adapter/dbconnection
License
This package is licensed under the PolyForm Shield License 1.0.0. Free for all use except building competing frameworks or developer tooling.