beaucal/beaucal-long-throttle
最新稳定版本:v0.6.0
Composer 安装命令:
composer require beaucal/beaucal-long-throttle
包简介
Prevent an action for some long amount of time. Hours, day, months, years.
关键字:
README 文档
README
Now with 100% code coverage.
Prevent an action for some amount of time. Hours, day, months, years, anything. Allows for multiple locks (e.g. 100/day) and clearing/releasing a lock just made. And it works just like it should, every single lock lasts exactly how long you specify and is taken atomically.
N.B. This is true/false throttling; this library does not sleep();
Installation
- In
application.config.php, add as follows:
'modules' => [..., 'BeaucalLongThrottle', ...];
- Import into your database
data/beaucal_throttle.sql:
CREATE TABLE IF NOT EXISTS `beaucal_throttle` ( `id` int(11) unsigned NOT NULL AUTO_INCREMENT PRIMARY KEY, `key` varchar(255) NOT NULL UNIQUE KEY, `end_datetime` DATETIME NOT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8; ALTER TABLE `beaucal_throttle` ADD INDEX (`end_datetime`);
To Use
Either you get the lock or you don't.
// in controller $throttle = $this->getServiceLocator()->get('BeaucalLongThrottle'); // term? $term = new DateTimeUnit(2, 'weeks'); // or $term = new DateTimeEnd(new DateTime('+2 weeks')); if ($throttle->takeLock('BiWeeklyReport', $term)) { // lock is taken atomically, made for 2 weeks: safe to do your work } else { // locked from before: leave it alone & perhaps try again later } /** * N.B. May throw \BeaucalLongThrottle\Exception\PhantomLockException, when * lock is reported to be set but upon verification step is actually not. * This is truly exceptional and shouldn't be just thrown aside. */
Allow Multiple Locks
You can allow any number of locks e.g. 'lock1' => 5/hour, 'lock2' => 100/day. Here's how:
// copy beaucallongthrottle.global.php to your config/autoload/ $throttle = [ // ... 'adapter_class' => 'BeaucalLongThrottle\Adapter\DbMultiple', // was Adapter\Db // ... ] $regexCounts = [ /** * E.g. You can create 3 'do-stuff' locks before the lock can't be taken. * Those not matching here are allowed the usual 1. */ '/^do-stuff$/' => 3 ]; // in controller $throttle = $this->getServiceLocator()->get('BeaucalLongThrottle'); $throttle->takeLock('do-stuff', new DateTimeUnit(1, 'day')); // YES $throttle->takeLock('do-stuff', new DateTimeUnit(1, 'day')); // YES $throttle->takeLock('do-stuff', new DateTimeUnit(1, 'day')); // YES $throttle->takeLock('do-stuff', new DateTimeUnit(1, 'day')); // FALSE // ... // A DAY LATER $throttle->takeLock('do-stuff', new DateTimeUnit(1, 'day')); // YES
Clearing Locks
$throttle = $this->getServiceLocator()->get('BeaucalLongThrottle'); $handle = $throttle->takeLock('year-end', new DateTimeUnit(1, 'year')); // YES $throttle->takeLock('year-end', new DateTimeUnit(1, 'year')); // FALSE if ($whoopsBackingOut) { $throttle->clearLock($handle); } $throttle->takeLock('year-end', new DateTimeUnit(1, 'year')); // YES
Lock with APC
For something more quick-n-dirty, use APC locking. This is adequate for short-term throttling with the usual caveats regarding APC persistence (e.g. some other part of your app might flush the entire cache, a PHP restart, out of memory).
N.B. If takeLock() fails, don't try to sleep() it out;
that won't work for some reason to do with how apc_add() works.
Instead, handle the no-lock condition then try again next request.
// copy beaucallongthrottle.global.php to your config/autoload/ $throttle = [ // ... 'adapter_class' => 'BeaucalLongThrottle\Adapter\Apc', // was Adapter\Db // ... ] // in controller $throttle = $this->getServiceLocator()->get('BeaucalLongThrottle'); // alternatively, a shortcut factory that doesn't require config $throttle = $this->getServiceLocator()->get('BeaucalLongThrottle_APC');
统计信息
- 总下载量: 87
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-05-04