1.PHP >= 7
2.composer
3.redis(必须支持lua)
4.predis
移步 composer中文网.
redis不支持window平台, window平台下的redis服务器由微软团队维护,版本一般比较旧. 一些redis新数据结构和功能会有限制,建议window用户安装linux虚拟机
linux移步 redis中文网
window github redis window
composer require predis/predis
composer require nabao/lock
多进程并发时, 其中某一个进程得到锁后, 其他进程将被拒绝
$callback
回调函数, 可返回值
$lock_val
锁定值
$expiration
进程最大执行时间
多进程并发时, 其中某一个进程得到锁后, 其他进程将等待解锁(配置最大等待进程后, 超过等待数量后进程将被拒绝)
$callback
回调函数, 可返回值
$lock_val
锁定值
$max_queue_process
队列最大等待进程
$expiration
进程最大执行时间
//静态调用
$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配置文件
|--------------------------------------------------------------------------
|
|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
]
]