Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/zhaocong6/lock
高性能分布式并发锁, 行为限流
https://github.com/zhaocong6/lock
lock redis
Last synced: about 4 hours ago
JSON representation
高性能分布式并发锁, 行为限流
- Host: GitHub
- URL: https://github.com/zhaocong6/lock
- Owner: zhaocong6
- License: mit
- Created: 2018-04-08T07:57:02.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2020-07-30T03:15:34.000Z (over 4 years ago)
- Last Synced: 2025-01-05T19:07:38.450Z (7 days ago)
- Topics: lock, redis
- Language: PHP
- Homepage:
- Size: 65.4 KB
- Stars: 286
- Watchers: 12
- Forks: 54
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- favorite-link - 高性能,并发抢占锁,并发队列锁。
README
[laravel版本](https://github.com/zhaocong6/laravel-lock)
# 环境要求
1.PHP >= 7
2.composer
3.redis(必须支持lua)
4.predis
# composer 安装移步 [composer中文网](https://www.phpcomposer.com/).
# redis 安装[redis中文网](http://www.redis.net.cn/)
# predis 安装
composer require predis/predis
# lock 安装
composer require nabao/lock
# 抢占锁
## lock(callable $callback, string $lock_val)
多进程并发时, 其中某一个进程得到锁后, 其他进程将被拒绝
$callback
回调函数, 可返回值
$lock_val
锁定值
# 多参数抢占锁
## lock(callable $callback, array $lock_vals)
多进程并发时, 其中某一个进程得到锁后, 其他进程将被拒绝
$callback
回调函数, 可返回值
$lock_vals
锁定值(数组)
# 队列锁## queueLock($closure, $lock_val, $max_queue_process = 100, $expiration = 60)
多进程并发时, 其中某一个进程得到锁后, 其他进程将等待解锁(配置最大等待进程后, 超过等待数量后进程将被拒绝)$callback
回调函数, 可返回值
$lock_val
锁定值
$max_queue_process
队列最大等待进程
$expiration
进程最大执行时间# 多参数队列锁
## queueLock($closure, $lock_vals, $max_queue_process = 100)
多进程并发时, 其中某一个进程得到锁后, 其他进程将等待解锁(配置最大等待进程后, 超过等待数量后进程将被拒绝)$callback
回调函数, 可返回值
$lock_vals
锁定值(数组)
$max_queue_process
队列最大等待进程# 使用
//静态调用
$lock_val = 'user:pay:1';
Lock::lock(function($redis){
echo 'hello world!';
}, $lock_val);
//实例化调用
$lock = new Lock();
$lock_val = 'user:pay:1';
$lock->lock(function($redis){
echo 'hello world!';
}, $lock_val);
//多参数锁
$lock = new Lock();
$lock_val[] = 'user:pay:1';
$lock_val[] = 'user:pay:2';
$lock->lock(function($redis){
echo 'hello world!';
}, $lock_val);# 限流
## isActionAllowed($key, $period, $max_count)
$key 限制key
$period 限制时间(秒)
$max_count 限制时间内最大数量
# config配置
## 目前兼容tp.其它框架请实例化传参/*
|--------------------------------------------------------------------------
| lock配置文件
|--------------------------------------------------------------------------
|
|drive 锁驱动(默认redis)
|
|redis redis驱动配置
| host 地址
| port 端口
|
|params 参数配置
| max_queue_process 进程池最大进程
| expiration 锁值过期时间
|
*/
'lock'=>[
'drive' => 'redis',
'redis' => [
'host' => '127.0.0.1',
'port' => '6379'
],
'params' => [
'max_queue_process' => 100
'expiration' => 5
]
]