承接 tourze/symfony-aop-pool-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

tourze/symfony-aop-pool-bundle

最新稳定版本:1.0.1

Composer 安装命令:

composer require tourze/symfony-aop-pool-bundle

包简介

Symfony AOP connection pool bundle for automatic resource pooling

README 文档

README

English | 中文

Latest Version Total Downloads License PHP Version Code Coverage

AopPoolBundle is a Symfony bundle for automatic connection pooling using AOP (Aspect-Oriented Programming). It provides efficient resource pooling for Redis, database, and custom services, improving performance and resource utilization.

Features

  • Automatic lifecycle management for connections (borrow/return)
  • Built-in Redis and Doctrine DBAL connection pools
  • Custom poolable services via #[ConnectionPool] attribute
  • Connection health checks and resource recycling
  • Lazy initialization, auto-reconnect, and retry support
  • Detailed logging and debug support
  • Compatible with FPM and Workerman environments

Installation

  • Requires PHP 8.1+, Symfony 6.4+
composer require tourze/symfony-aop-pool-bundle

Quick Start

1. Mark Custom Service for Pooling

use Tourze\Symfony\AopPoolBundle\Attribute\ConnectionPool;

#[ConnectionPool]
class YourService {
    private $connection;
    public function doSomething() {
        // Connection is automatically fetched from the pool
        $result = $this->connection->query(...);
        return $result;
    }
}

2. Redis Connection Pool

Redis clients are automatically pooled, no extra configuration required:

class YourService {
    public function __construct(private \Redis $redis) {}
    public function doSomething() {
        return $this->redis->get('key');
    }
}

3. Database Connection Pool

Doctrine DBAL connections are automatically pooled:

use Doctrine\DBAL\Connection;
class YourService {
    public function __construct(private Connection $connection) {}
    public function doSomething() {
        return $this->connection->executeQuery('SELECT ...');
    }
}

Services Automatically Pooled

  • All services tagged as snc_redis.client
  • All doctrine.dbal.*_connection services
  • All services with the #[ConnectionPool] attribute

Configuration

Add the following to your .env if you need to customize:

SERVICE_POOL_DEFAULT_SIZE=500
SERVICE_POOL_CLEANUP_INTERVAL=60
SERVICE_POOL_CONNECTION_LIFETIME=60
SERVICE_POOL_CHECK_REDIS_CONNECTION=0
DEBUG_ConnectionPoolAspect=true

Performance & Debugging Tips

  • Pool only necessary services, set pool size appropriately
  • Enable debug logs to monitor pool usage
  • Ensure connections are properly released

Notes & Limitations

  • Connections are automatically returned to the pool at the end of each request
  • Pool health checks regularly recycle a small portion of connections to prevent resource exhaustion
  • Default pool size: 500 (configurable)
  • Max retry attempts = pool size + 1
  • Pool switching in transactions is not supported
  • Some special services may not be suitable for pooling
  • StopWorkerException is thrown if connection fetch fails; automatic retry supported
  • Reconnect attempts and intervals are configurable
  • Works well in both short-lived (FPM) and long-lived (Workerman) process environments

Contributing

Please see CONTRIBUTING.md for details.

  • Please use Issues for bug reports and feature requests
  • Pull Requests are welcome; ensure tests and code style pass
  • Follow PSR standards

License

MIT License © Tourze

Changelog

See [CHANGELOG.md] if available.

统计信息

  • 总下载量: 26
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-17

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固