當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Redis::watch方法代碼示例

本文整理匯總了PHP中Redis::watch方法的典型用法代碼示例。如果您正苦於以下問題:PHP Redis::watch方法的具體用法?PHP Redis::watch怎麽用?PHP Redis::watch使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Redis的用法示例。


在下文中一共展示了Redis::watch方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: update

 /**
  * {@inheritdoc}
  */
 public function update($key, callable $modifier, $ttl = 0)
 {
     $this->redis->watch($key);
     $data = $this->redis->get($key);
     if ($data === false) {
         $this->redis->unwatch();
         return false;
     } else {
         $modifier($data);
         if ($this->setInTransaction($key, $data, (int) $ttl)) {
             return $data;
         }
     }
     throw new AtomicViolationException("Atomic violation occurred when updating key \"{$key}\".");
 }
開發者ID:lingualeo,項目名稱:php-cache,代碼行數:18,代碼來源:RedisCache.php

示例2: testMultiExec

 public function testMultiExec()
 {
     $this->sequence(Redis::MULTI);
     $this->differentType(Redis::MULTI);
     // with prefix as well
     $this->redis->setOption(Redis::OPT_PREFIX, "test:");
     $this->sequence(Redis::MULTI);
     $this->differentType(Redis::MULTI);
     $this->redis->setOption(Redis::OPT_PREFIX, "");
     $this->redis->set('x', '42');
     $this->assertTrue(TRUE === $this->redis->watch('x'));
     $ret = $this->redis->multi()->get('x')->exec();
     // successful transaction
     $this->assertTrue($ret === array('42'));
     // failed transaction
     $this->redis->watch('x');
     $r = $this->newInstance();
     // new instance, modifying `x'.
     $r->incr('x');
     $ret = $this->redis->multi()->get('x')->exec();
     $this->assertTrue($ret === FALSE);
     // failed because another client changed our watched key between WATCH and EXEC.
     // watch and unwatch
     $this->redis->watch('x');
     $r->incr('x');
     // other instance
     $this->redis->unwatch();
     // cancel transaction watch
     $ret = $this->redis->multi()->get('x')->exec();
     $this->assertTrue($ret === array('44'));
     // succeeded since we've cancel the WATCH command.
 }
開發者ID:stonegithubs,項目名稱:phpredis,代碼行數:32,代碼來源:TestRedis.php

示例3: mget

 protected function mget()
 {
     $this->db->watch([$this->count]);
     $error = $this->db->getLastError();
     if ($error) {
         return $error;
     }
     $replies = $this->db->mGet([$this->count, $this->limit, $this->reset]);
     $error = $this->db->getLastError();
     if ($error) {
         return $error;
     }
     if (!$replies[0] && $replies[0] !== '0') {
         return $this->create();
     }
     return $this->decr($replies);
 }
開發者ID:leilt331,項目名稱:rest_api,代碼行數:17,代碼來源:RateLimiter.php

示例4: freeze

 /**
  * Freezes this cache backend.
  *
  * All data in a frozen backend remains unchanged and methods which try to add
  * or modify data result in an exception thrown. Possible expiry times of
  * individual cache entries are ignored.
  *
  * A frozen backend can only be thawn by calling the flush() method.
  *
  * @throws \RuntimeException
  * @return void
  */
 public function freeze()
 {
     if ($this->isFrozen()) {
         throw new \RuntimeException(sprintf('Cannot add or modify cache entry because the backend of cache "%s" is frozen.', $this->cacheIdentifier), 1323344192);
     }
     do {
         $entriesKey = $this->buildKey('entries');
         $this->redis->watch($entriesKey);
         $entries = $this->redis->lRange($entriesKey, 0, -1);
         $this->redis->multi();
         foreach ($entries as $entryIdentifier) {
             $this->redis->persist($this->buildKey('entry:' . $entryIdentifier));
         }
         $this->redis->set($this->buildKey('frozen'), 1);
         $result = $this->redis->exec();
     } while ($result === false);
     $this->frozen = true;
 }
開發者ID:mkeitsch,項目名稱:flow-development-collection,代碼行數:30,代碼來源:RedisBackend.php

示例5: testFailedTransactions

 public function testFailedTransactions()
 {
     $this->redis->set('x', 42);
     // failed transaction
     $this->redis->watch('x');
     $r = $this->newInstance();
     // new instance, modifying `x'.
     $r->incr('x');
     $ret = $this->redis->multi()->get('x')->exec();
     $this->assertTrue($ret === FALSE);
     // failed because another client changed our watched key between WATCH and EXEC.
     // watch and unwatch
     $this->redis->watch('x');
     $r->incr('x');
     // other instance
     $this->redis->unwatch();
     // cancel transaction watch
     $ret = $this->redis->multi()->get('x')->exec();
     $this->assertTrue($ret === array('44'));
     // succeeded since we've cancel the WATCH command.
 }
開發者ID:Jerry-Shaw,項目名稱:phpredis,代碼行數:21,代碼來源:RedisTest.php

示例6: tryLock

 protected function tryLock()
 {
     $this->redis->watch('lock');
     $result = $this->redis->blPop(array('lock'), static::LOCK_TIMEOUT);
     return !empty($result);
 }
開發者ID:rybakit,項目名稱:taskqueue,代碼行數:6,代碼來源:RedisQueue.php

示例7:

$key = 'test-expire-key';
$redis->expire($key, 60);
//使用秒為單位
$redis->pExpire($key, 60000);
//使用毫秒作為單位
$redis->expireAt($key, 1476868380);
//使用Unix timestamp,指定時間過期
$redis->pExpireAt($key, 1476868380000.0);
//使用Unix timestamp在指定時間過期,區別是毫秒作為單位
$redis->persist($key);
//移除給定key的生存時間
$redis->ttl($key);
//返回key剩餘的過期時間,使用秒為單位
$redis->pttl($key);
//返回key剩餘的過期時間,使用毫秒作為單位
$redis->watch($key2);
$ret = $redis->multi(Redis::MULTI)->get($key)->incr($key1)->del($key2)->exec();
$pip->incr('a');
$pip->get('test-num2');
$pip->incr('b');
$pip->del('a');
$ret = $pip->exec();
var_dump($ret);
exit;
$ret = $redis->incr('test-num2')->incr('test-num2')->exec();
exit('aa' . $redis->get('test-num2'));
$redis->multi(Redis::PIPELINE);
for ($i = 0; $i < 10000; $i++) {
    $redis->incr('test-num')->include('test-num2');
}
$redis->exec();
開發者ID:xiehaowei,項目名稱:php,代碼行數:31,代碼來源:redis.php

示例8: PDO

<?php

/*
$dsn = "mysql:host=localhost;dbname=demo";
$db = new PDO($dsn, 'root', 'root');
*/
$redis = new Redis();
$redis->connect('127.0.0.1', 6379);
$redis->watch('myk');
$vn = $redis->get('myk');
$vn = $vn + 1;
sleep(1);
$redis->multi();
$redis->set('myk', $vn);
$rs = $redis->exec();
if (!$rs) {
    error_log("eeee\n", 3, 'F:/logdata/eee.log');
}
開發者ID:ruyicoder,項目名稱:php,代碼行數:18,代碼來源:ab_watch.php

示例9: removeExpiredJobs

 /**
  * Remove the expired jobs from a given queue.
  *
  * @param  \Redis  $transaction
  * @param  string  $from
  * @param  int  $time
  * @return void
  */
 protected function removeExpiredJobs($transaction, $from, $time)
 {
     $transaction->watch($from);
     $transaction->multi();
     $transaction->zRemRangeByScore($from, '-inf', $time);
 }
開發者ID:targetliu,項目名稱:phpredis,代碼行數:14,代碼來源:PHPRedisQueue.php


注:本文中的Redis::watch方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。