webman-lock 业务锁

v1.0.0 版本
2022-05-24 版本更新时间
68 安装
1 star

kriss/webman-lock

webman lock plugin

简介

在 webman 中简化使用业务锁功能,使用 symfony/lock

解决以下问题:

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

安装

compoer require kriss/webman-lock

使用

定义一个自己的 Locker 类,比如:support\facade\Locker.php,继承 Kriss\WebmanLock\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 \Kriss\WebmanLock\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 文档