Memcached::cas の詳細な説明

高洛峰
リリース: 2016-10-17 10:20:50
オリジナル
1230 人が閲覧しました

Memcached::cas

(PECL memcached >= 0.1.0)

Memcached::cas — 値の比較と交換

Description

public bool Memcached::cas ( float $cas_token , string $key ,mixed $value [, int $expiration ] )

Memcached::cas() は「チェックと設定」操作を実行するため、現在のクライアントによる前回以降の値のみを取得し、キーに対応する値は他のクライアントによって変更されていない場合のみ、値を書き込むことができます。チェックは、cas_token パラメータを通じて実行されます。このパラメータは、Memcach によって既存の要素に割り当てられる一意の 64 ビット値です。この値を取得する方法については、Memcached::get*() 一連のメソッドのドキュメントを確認してください。注: PHP の整数スペース制限により、この値は double 型になります。

翻訳注: これは、Memcache 拡張機能に対する Memcached 拡張機能の非常に重要な利点です。このようなシステムレベルの競合検出メカニズム (楽観的ロック) (Memcache 自体によって提供される) を使用すると、高い同時実行性の下でデータのセキュリティを確保できます。

パラメータ

cas_token

Memcache によって生成された、既存の要素に関連付けられた一意の値。

key

値を保存するために使用されるキーの名前。

value

保存された値。

expiration

有効期限、デフォルトは 0 です。 詳細については、「有効期限」を参照してください。

戻り値

成功した場合は TRUE を返し、失敗した場合は FALSE を返します。 Memcached::getResultCode() は、このクライアントが要素を保存しようとしたときに要素が最後に取得されてから、別のクライアントによって要素が変更されていることが判明した場合、 Memcached::RES_DATA_EXISTS を返します。

例 #1 Memcached::cas() 例

<?php
$m = new Memcached();
$m->addServer(&#39;localhost&#39;, 11211);
do {
    /* 获取ip列表以及它的标记 */
    $ips = $m->get(&#39;ip_block&#39;, null, $cas);
    /* 如果列表不存在, 创建并进行一个原子添加(如果其他客户端已经添加, 这里就返回false)*/
    if ($m->getResultCode() == Memcached::RES_NOTFOUND) {
        $ips = array($_SERVER[&#39;REMOTE_ADDR&#39;]);
        $m->add(&#39;ip_block&#39;, $ips);
    /* 其他情况下,添加ip到列表中, 并以cas方式去存储, 这样当其他客户端修改过, 则返回false */
    } else { 
        $ips[] = $_SERVER[&#39;REMOTE_ADDR&#39;];
        $m->cas($cas, &#39;ip_block&#39;, $ips);
    }   
} while ($m->getResultCode() != Memcached::RES_SUCCESS);
?>
ログイン後にコピー


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート