Maison > développement back-end > tutoriel php > Partage de scénarios d'utilisation courants de Redis

Partage de scénarios d'utilisation courants de Redis

小云云
Libérer: 2023-03-21 07:36:01
original
1807 Les gens l'ont consulté

Cet article partage principalement avec vous des scénarios d'utilisation courants de Redis et des pratiques simples de mise en cache de chaînes. J'espère qu'il pourra aider tout le monde.

$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); //输出数据
Copier après la connexion

Pratique simple de file d'attente

$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([&#39;uid&#39; => 3,&#39;name&#39; => &#39;John&#39;]));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);
Copier après la connexion

Pratique simple de publication et d'abonnement

//以下是 pub.php 文件的内容 cli下运行ini_set(&#39;default_socket_timeout&#39;, -1);
$redis->connect(&#39;127.0.0.1&#39;, 6379);
$strChannel = &#39;Test_bihu_channel&#39;;//发布$redis->publish($strChannel, "来自{$strChannel}频道的推送");echo "---- {$strChannel} ---- 频道消息推送成功~ <br/>";
$redis->close();
Copier après la connexion

Pratique simple de compteur

//以下是 sub.php 文件内容 cli下运行ini_set(&#39;default_socket_timeout&#39;, -1);
$redis->connect(&#39;127.0.0.1&#39;, 6379);
$strChannel = &#39;Test_bihu_channel&#39;;//订阅echo "---- 订阅{$strChannel}这个频道,等待消息推送...----  <br/><br/>";
$redis->subscribe([$strChannel], &#39;callBackFun&#39;);function callBackFun($redis, $channel, $msg){
    print_r([        &#39;redis&#39;   => $redis,        &#39;channel&#39; => $channel,        &#39;msg&#39;     => $msg
    ]);
}
Copier après la connexion

Pratique de classement

$redis->connect(&#39;127.0.0.1&#39;, 6379);
$strKey = &#39;Test_bihu_comments&#39;;//设置初始值$redis->set($strKey, 0);

$redis->INCR($strKey);  //+1$redis->INCR($strKey);  //+1$redis->INCR($strKey);  //+1$strNowCount = $redis->get($strKey);echo "---- 当前数量为{$strNowCount}。 ---- ";
Copier après la connexion
$redis->connect(&#39;127.0.0.1&#39;, 6379);
$strKey = &#39;Test_bihu_score&#39;;//存储数据$redis->zadd($strKey, &#39;50&#39;, json_encode([&#39;name&#39; => &#39;Tom&#39;]));
$redis->zadd($strKey, &#39;70&#39;, json_encode([&#39;name&#39; => &#39;John&#39;]));
$redis->zadd($strKey, &#39;90&#39;, json_encode([&#39;name&#39; => &#39;Jerry&#39;]));
$redis->zadd($strKey, &#39;30&#39;, json_encode([&#39;name&#39; => &#39;Job&#39;]));
$redis->zadd($strKey, &#39;100&#39;, json_encode([&#39;name&#39; => &#39;LiMing&#39;]));

$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);
Copier après la connexion

Explication : Pessimistic Lock, comme son nom l'indique, est très pessimiste.

Chaque fois que je vais chercher les données, je pense que d'autres vont les modifier, donc je les verrouille à chaque fois que je récupère les données.

Scénario : Si le cache est utilisé dans le projet et qu'un délai d'attente est défini pour le cache.

Lorsque la quantité de concurrence est relativement importante, s'il n'y a pas de mécanisme de verrouillage, alors au moment où le cache expire,

Un grand nombre de requêtes simultanées pénétreront dans le cache et interrogeront directement la base de données , provoquant un effet d'avalanche.

/**
 * 获取锁
 * @param  String  $key    锁标识
 * @param  Int     $expire 锁过期时间
 * @return Boolean
 */public function lock($key = &#39;&#39;, $expire = 5) {
    $is_lock = $this->_redis->setnx($key, time()+$expire);    //不能获取锁
    if(!$is_lock){        //判断锁是否过期
        $lock_time = $this->_redis->get($key);        //锁已过期,删除锁,重新获取
        if (time() > $lock_time) {
            unlock($key);
            $is_lock = $this->_redis->setnx($key, time() + $expire);
        }
    }    return $is_lock? true : false;
}/**
 * 释放锁
 * @param  String  $key 锁标识
 * @return Boolean
 */public function unlock($key = &#39;&#39;){    return $this->_redis->del($key);
}// 定义锁标识$key = &#39;Test_bihu_lock&#39;;// 获取锁$is_lock = lock($key, 10);if ($is_lock) {    echo &#39;get lock success<br>&#39;;    echo &#39;do sth..<br>&#39;;
    sleep(5);    echo &#39;success<br>&#39;;
    unlock($key);
} else { //获取锁失败
    echo &#39;request too frequently<br>&#39;;
}
Copier après la connexion

Pratique de verrouillage optimiste pour les transactions simples

Explication : Le verrouillage optimiste, comme son nom l'indique, est très optimiste.

Chaque fois que je vais chercher les données, je pense que les autres ne les modifieront pas, donc je ne les verrouillerai pas.

La commande watch surveillera la clé donnée. Si la clé surveillée a changé depuis l'appel de watch pendant l'exécution, la transaction entière échouera.

Vous pouvez également appeler watch plusieurs fois pour surveiller plusieurs touches. De cette manière, un verrouillage optimiste peut être ajouté à la clé spécifiée.

Notez que la clé de montre est valable pour toute la connexion, et il en va de même pour les transactions.

Si la connexion est perdue, les montres et les transactions seront automatiquement effacées.

Bien sûr, les commandes exec, throw et unwatch effaceront toute surveillance de la connexion.

$strKey = &#39;Test_bihu_age&#39;;

$redis->set($strKey,10);

$age = $redis->get($strKey);echo "---- Current Age:{$age} ---- <br/><br/>";

$redis->watch($strKey);// 开启事务$redis->multi();//在这个时候新开了一个新会话执行$redis->set($strKey,30);  //新会话echo "---- Current Age:{$age} ---- <br/><br/>"; //30$redis->set($strKey,20);

$redis->exec();

$age = $redis->get($strKey);echo "---- Current Age:{$age} ---- <br/><br/>"; //30//当exec时候如果监视的key从调用watch后发生过变化,则整个事务会失败
Copier après la connexion

Recommandations associées :

Code de la méthode Redis du lien PHP
Un exemple simple de partage de php+redis

Quelques façons d'utiliser Redis en PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal