kriss/webman-lock

This package is abandoned and no longer maintained. The author suggests using the webman-tech/symfony-lock package instead.

webman lock plugin

v2.0.0 2022-09-18 12:13 UTC

This package is auto-updated.

Last update: 2022-09-18 13:33:35 UTC


README

symfony/lock for webman

介绍

在 webman 中简化使用业务锁功能

解决以下问题:

  • 并发业务操作有时候需要锁来防止并发导致的数据插入或更新问题
  • 单独使用 symfony/lock 时一般使用 $factory->createLock('key'),此时 key 是一个字符串,不利于后期维护或多处使用

安装

compoer require webman-tech/symfony-lock

使用

定义一个自己的 Locker 类,比如:support\facade\Locker.php,继承 WebmanTech\SymfonyLock\Locker

然后在类上方加入注释(用于代码提示),举例如下:

<?php

namespace support\facade;

use Symfony\Component\Lock\LockInterface;

/**
 * @method static LockInterface order(?string $orderId = null, ?float $ttl = null, ?bool $autoRelease = null, ?string $prefix = null)
 * @method static LockInterface changeCash(?string $userId = null, ?float $ttl = null, ?bool $autoRelease = null, ?string $prefix = null)
 */
class Locker extends \WebmanTech\SymfonyLock\Locker
{
}

业务中使用

<?php

namespace app\controller;

use support\facade\Locker;

class Cash {
    public function changeCash()
    {
        $lock = Locker::cash($currentUserId);
        if (!$lock->acquire()) {
            throw new \Exception('操作太频繁,请稍后再试');
        }
        try {
            // 修改用户金额
        } finally {
            $lock->release();
        }
        
        return 'ok';
    }
}

更多操作参考:symfony/lock 文档