PHP阻塞锁和非阻塞锁机制 YurunLock

码农软件 · 软件分类 · 常用工具包 · 2019-08-13 13:13:11

软件介绍

YurunLock

PHP阻塞锁和非阻塞锁机制,内置解决并发锁重复执行的方案。目前支持文件、Redis、Memcache、Memcached。

composer安装

在你项目中的 composer.json 文件中加入下面的内容

{
    "require": {
        "yurunsoft/yurun-lock": "dev-master"
    }
}

中国用户如果使用composer很卡,请查看:https://pkg.phpcomposer.com/

代码用法

文件锁

<?php
$lock = new \Yurun\Until\Lock\File('我是锁名称');

$lock->lock(); // 阻塞锁
// TODO:在这里做你的一些事情
$lock->unlock(); // 解锁

// 带回调的阻塞锁,防止并发锁处理重复执行
result = $lock->lock(
    function(){
        // TODO:在这里做你的加锁后处理的任务

    },
    function(){
        // 判断是否其它并发已经处理过任务
        return false;
    }
);
switch($result)
{
    case LockConst::LOCK_RESULT_CONCURRENT_COMPLETE:
        // 其它请求已处理
        break;
    case LockConst::LOCK_RESULT_CONCURRENT_UNTREATED:
        // 在当前请求处理
        break;
    case LockConst::LOCK_RESULT_FAIL:
        // 获取锁失败
        break;
}

// 不阻塞锁,获取锁失败就返回false
if($lock->unblockLock())
{
    // TODO:在这里做你的一些事情
}
else
{
    // 获取锁失败
}

redis/memcache/memcached锁

<?php
$lock = new \Yurun\Until\Lock\Redis(    // 可以把Redis替换成Memcache/Memcached,下面代码用法相同
    '我是锁名称',
    array(
        'host'      =>  '127.0.0.1',
        'port'      =>  11211,
        'timeout'   =>  0,
        'pconnect'  =>  false,
    ), // 连接配置,留空则为默认值
    0, // 获得锁等待超时时间,单位:毫秒,0为不限制,留空则为默认值
    1, // 获得锁每次尝试间隔,单位:毫秒,留空则为默认值
    3, // 锁超时时间,单位:秒,留空则为默认值
);

$lock->lock(); // 阻塞锁
// TODO:在这里做你的一些事情
$lock->unlock(); // 解锁

// 带回调的阻塞锁,防止并发锁处理重复执行
result = $lock->lock(
    function(){
        // TODO:在这里做你的加锁后处理的任务

    },
    function(){
        // 判断是否其它并发已经处理过任务
        return false;
    }
);
switch($result)
{
    case LockConst::LOCK_RESULT_CONCURRENT_COMPLETE:
        // 其它请求已处理
        break;
    case LockConst::LOCK_RESULT_CONCURRENT_UNTREATED:
        // 在当前请求处理
        break;
    case LockConst::LOCK_RESULT_FAIL:
        // 获取锁失败
        break;
}

// 不阻塞锁,获取锁失败就返回false
if($lock->unblockLock())
{
    // TODO:在这里做你的一些事情
}
else
{
    // 获取锁失败
}

直接传入操作对象

直接传入操作对象支持文件、redis、memcache、memcached。可以防止重复实例化对象,造成内存和网络负担。

// 文件
$fp = fopen('1.txt', 'w+');
$lock = new \Yurun\Until\Lock\File('我是锁名称', $fp);
$lock->lock();
// 做一些事情
$lock->unlock();
fclose($fp);

// redis、memcache、memcached同理
$redis = new \Redis;
$redis->connect($host, $port, $timeout);
$lock = new \Yurun\Until\Lock\Redis('我是锁名称', $$redis);
$lock->lock();
// 做一些事情
$lock->unlock();
redis->close();

本文地址:https://codercto.com/soft/d/12273.html

大话存储Ⅱ

大话存储Ⅱ

张冬 / 清华大学出版社 / 2011-5 / 99.00元

《大话存储2:存储系统架构与底层原理极限剖析》内容简介:网络存储是一个涉及计算机硬件以及网络协议/技术、操作系统以及专业软件等各方面综合知识的领域。目前国内阐述网络存储的书籍少之又少,大部分是国外作品,对存储系统底层细节的描述不够深入,加之术语太多,初学者很难真正理解网络存储的精髓。《大话存储2:存储系统架构与底层原理极限剖析》以特立独行的行文风格向读者阐述了整个网络存储系统。从硬盘到应用程序,对......一起来看看 《大话存储Ⅱ》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

在线进制转换器
在线进制转换器

各进制数互转换器

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码