jardisadapter/dbconnection
最新稳定版本:v1.0.0
Composer 安装命令:
composer require jardisadapter/dbconnection
包简介
PDO connection factory with read/write splitting, round-robin load balancing, and automatic health checks
README 文档
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/en/adapter/dbconnection
License
This package is licensed under the MIT License.
Jardis · Documentation · Headgent
KI-gestützte Entwicklung
Dieses Package liefert einen Skill für Claude Code, Cursor, Continue und Aider mit. Installation im Konsumentenprojekt:
composer require --dev jardis/dev-skills
Mehr Details: https://docs.jardis.io/skills
统计信息
- 总下载量: 202
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 6
- 依赖项目数: 2
- 推荐数: 2
其他信息
- 授权协议: MIT
- 更新时间: 2026-03-09