Redis は、ANSI C 言語で書かれたオープンソースのログタイプの Key-Value データベースで、ネットワークをサポートし、メモリベースで永続化でき、複数の言語で API を提供します。
この記事では、PHP で Redis を使用する主なアプリケーション シナリオを主に紹介します。
簡単な文字列キャッシュの練習
$redis->connect('127.0.0.1', 6379); $strCacheKey = 'Test_bihu'; //SET 应用 $arrCacheData = [ 'name' => 'job', 'sex' => '男', 'age' => '30' ]; $redis->set($strCacheKey, json_encode($arrCacheData)); $redis->expire($strCacheKey, 30); # 设置30秒后过期 $json_data = $redis->get($strCacheKey); $data = json_decode($json_data); print_r($data->age); //输出数据 //HSET 应用 $arrWebSite = [ 'google' => [ 'google.com', 'google.com.hk' ], ]; $redis->hSet($strCacheKey, 'google', json_encode($arrWebSite['google'])); $json_data = $redis->hGet($strCacheKey, 'google'); $data = json_decode($json_data); print_r($data); //输出数据
簡単なキューの練習
$redis->connect('127.0.0.1', 6379); $strQueueName = 'Test_bihu_queue'; //进队列 $redis->rpush($strQueueName, json_encode(['uid' => 1,'name' => 'Job'])); $redis->rpush($strQueueName, json_encode(['uid' => 2,'name' => 'Tom'])); $redis->rpush($strQueueName, json_encode(['uid' => 3,'name' => 'John'])); echo "---- 进队列成功 ---- <br /><br />"; //查看队列 $strCount = $redis->lrange($strQueueName, 0, -1); echo "当前队列数据为: <br />"; print_r($strCount); //出队列 $redis->lpop($strQueueName); echo "<br /><br /> ---- 出队列成功 ---- <br /><br />"; //查看队列 $strCount = $redis->lrange($strQueueName, 0, -1); echo "当前队列数据为: <br />"; print_r($strCount);
簡単なパブリッシュとサブスクライブの練習
//以下是 pub.php 文件的内容 cli下运行 ini_set('default_socket_timeout', -1); $redis->connect('127.0.0.1', 6379); $strChannel = 'Test_bihu_channel'; //发布 $redis->publish($strChannel, "来自{$strChannel}频道的推送"); echo "---- {$strChannel} ---- 频道消息推送成功~ <br/>"; $redis->close();
簡単なカウンター練習
//以下是 sub.php 文件内容 cli下运行 ini_set('default_socket_timeout', -1); $redis->connect('127.0.0.1', 6379); $strChannel = 'Test_bihu_channel'; //订阅 echo "---- 订阅{$strChannel}这个频道,等待消息推送...---- <br/><br/>"; $redis->subscribe([$strChannel], 'callBackFun'); function callBackFun($redis, $channel, $msg) { print_r([ 'redis' => $redis, 'channel' => $channel, 'msg' => $msg ]); }
実践ランキングリスト
$redis->connect('127.0.0.1', 6379); $strKey = 'Test_bihu_comments'; //设置初始值 $redis->set($strKey, 0); $redis->INCR($strKey); //+1 $redis->INCR($strKey); //+1 $redis->INCR($strKey); //+1 $strNowCount = $redis->get($strKey); echo "---- 当前数量为{$strNowCount}。 ---- ";
簡単な文字列悲観的ロックの練習
説明: 悲観的ロック)、名前が示すように、非常に悲観的です。
データを取りに行くたびに、他の人が改変してしまうと思うので、データを取得するたびにロックをかけています。
シナリオ: プロジェクトでキャッシュが使用されており、キャッシュにタイムアウトが設定されている場合。
同時実行の量が比較的大きい場合、ロックメカニズムがない場合、キャッシュの有効期限が切れた瞬間に、
多数の同時リクエストがキャッシュに侵入し、データベースに直接クエリを実行し、雪崩現象を引き起こします。
$redis->connect('127.0.0.1', 6379); $strKey = 'Test_bihu_score'; //存储数据 $redis->zadd($strKey, '50', json_encode(['name' => 'Tom'])); $redis->zadd($strKey, '70', json_encode(['name' => 'John'])); $redis->zadd($strKey, '90', json_encode(['name' => 'Jerry'])); $redis->zadd($strKey, '30', json_encode(['name' => 'Job'])); $redis->zadd($strKey, '100', json_encode(['name' => 'LiMing'])); $dataOne = $redis->ZREVRANGE($strKey, 0, -1, true); echo "---- {$strKey}由大到小的排序 ---- <br /><br />"; print_r($dataOne); $dataTwo = $redis->ZRANGE($strKey, 0, -1, true); echo "<br /><br />---- {$strKey}由小到大的排序 ---- <br /><br />"; print_r($dataTwo);
単純なトランザクションのための楽観的ロックの実践
説明: 楽観的ロックは、名前が示すように、非常に楽観的です。
データを取りに行くたびに、他人が改変しないだろうと思うのでロックはしません。
watch コマンドは指定されたキーを監視します。実行中に watch を呼び出してから監視対象のキーが変更された場合、トランザクション全体が失敗します。
watch を複数回呼び出して、複数のキーを監視することもできます。このようにして、指定したキーに楽観的ロックを追加できます。
監視キーは接続全体に対して有効であり、トランザクションにも同じことが当てはまることに注意してください。
接続が失われた場合、ウォッチとトランザクションの両方が自動的にクリアされます。
もちろん、exec、discard、および unwatch コマンドは、接続内のすべての監視をクリアします。
りー