定制 tourze/symfony-aop-lock-bundle 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

tourze/symfony-aop-lock-bundle

最新稳定版本:1.0.1

Composer 安装命令:

composer require tourze/symfony-aop-lock-bundle

包简介

A lightweight Symfony bundle providing declarative distributed locking based on AOP (Aspect-Oriented Programming). Easily add locking logic to your methods using attributes, enabling safe concurrency control in distributed environments.

README 文档

README

English | 中文

Latest Version PHP Version License Build Status Quality Score Coverage Status Total Downloads

A lightweight Symfony bundle providing declarative distributed locking based on AOP (Aspect-Oriented Programming). Easily add locking logic to your methods using attributes, enabling safe concurrency control in distributed environments.

Features

  • Declarative locking with the #[Lockable] attribute
  • Customizable lock key with Twig template syntax
  • Automatic lock acquire/release (even on exception)
  • Seamless integration with Symfony Lock component
  • Suitable for distributed/multi-instance deployments

Installation

Requirements:

  • PHP >= 8.1
  • Symfony >= 6.4
  • Required dependencies: symfony/lock, twig/twig, tourze/symfony-aop-bundle

Install via Composer:

composer require tourze/symfony-aop-lock-bundle

Register the bundle in your config/bundles.php if not auto-registered:

return [
    // ... other bundles
    Tourze\Symfony\AopLockBundle\AopLockBundle::class => ['all' => true],
];

Quick Start

Annotate your methods with #[Lockable]:

use Tourze\Symfony\AopLockBundle\Attribute\Lockable;

class OrderService
{
    #[Lockable]
    public function processOrder(string $orderId): void
    {
        // business logic
    }

    #[Lockable(key: "user_{{ userId }}_update")]
    public function updateUserProfile(int $userId, array $data): void
    {
        // business logic
    }
}
  • The lock key can be customized using method parameters and Twig syntax, e.g. order_{{ orderId }}.
  • Supported Twig variables: method parameters, joinPoint.method, joinPoint.class, etc.

Documentation

  • API Reference
  • Configuration:
    • Default lock timeout: 30 seconds
    • All lock/unlock logic is handled automatically by the aspect
  • Advanced:
    • Implement your own lock service by extending the aspect or LockService interface
    • Customize lock behavior by overriding LockAspect

Performance & Best Practices

  • Only use locking where necessary, as it introduces network overhead
  • Keep lock scope as small as possible
  • Use fine-grained keys to maximize concurrency
  • Ensure all nodes have synchronized clocks in distributed setups
  • Monitor for lock timeouts and failures

Contributing

Please see CONTRIBUTING.md for details.

Issues and PRs are welcome!

  • Follow PSR coding standards
  • Add tests for new features
  • Run static analysis: composer phpstan

License

The MIT License (MIT). Please see License File for more information.

Changelog

See Releases for version history.

统计信息

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

GitHub 信息

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

其他信息

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

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固