Maison > base de données > Redis > Combien de types de verrous Redis possède-t-il ?

Combien de types de verrous Redis possède-t-il ?

anonymity
Libérer: 2019-06-05 10:00:24
original
3204 Les gens l'ont consulté

Classification de verrouillage Redis

Les tables de commandes de verrouillage qui peuvent être utilisées par Redis sont INCR, SETNX, SET

Combien de types de verrous Redis possède-t-il ?

La première commande de verrouillage INCR

L'idée de​​ce genre de verrouillage est que si la clé n'existe pas, alors la valeur de la clé sera initialisée à 0 d'abord, puis l'opération INCR sera effectuée plus un.

Ensuite, lorsque d'autres utilisateurs effectuent l'opération INCR pour en ajouter un, si le nombre renvoyé est supérieur à 1, cela signifie que le verrou est utilisé.

    1、 客户端A请求服务器获取key的值为1表示获取了锁
    2、 客户端B也去请求服务器获取key的值为2表示获取锁失败
    3、 客户端A执行代码完成,删除锁
    4、 客户端B在等待一段时间后在去请求的时候获取key的值为1表示获取锁成功
    5、 客户端B执行代码完成,删除锁
    $redis->incr($key);
    $redis->expire($key, $ttl); //设置生成时间为1秒
Copier après la connexion

Le deuxième type de serrure SETNX

L'idée de ce type de verrouillage est que si la clé n'existe pas, réglez la clé sur valeur

Si la clé existe déjà, SETNX n'effectue aucune action

    1、 客户端A请求服务器设置key的值,如果设置成功就表示加锁成功
    2、 客户端B也去请求服务器设置key的值,如果返回失败,那么就代表加锁失败
    3、 客户端A执行代码完成,删除锁
    4、 客户端B在等待一段时间后在去请求设置key的值,设置成功
    5、 客户端B执行代码完成,删除锁
    $redis->setNX($key, $value);
    $redis->expire($key, $ttl);
Copier après la connexion

Le troisième type de verrouillage SET

Les deux ci-dessus Les méthodes ont un problème, vous le constaterez, toutes doivent définir l'expiration de la clé. Alors pourquoi devons-nous définir l’expiration des clés ? Si l'exécution de la requête se termine de manière inattendue pour une raison quelconque, entraînant la création du verrou mais pas sa suppression, le verrou existera toujours, de sorte que le cache ne sera jamais mis à jour à l'avenir. Il faut donc ajouter un délai d'expiration au verrou pour éviter les accidents.

Mais le définir avec Expire n'est pas une opération atomique. Par conséquent, les transactions peuvent également être utilisées pour garantir l'atomicité, mais il y a encore quelques problèmes, c'est pourquoi le responsable en a cité un autre. L'utilisation de la commande SET elle-même inclut la fonction de définition du délai d'expiration à partir de la version 2.6.12.

    1、 客户端A请求服务器设置key的值,如果设置成功就表示加锁成功
    2、 客户端B也去请求服务器设置key的值,如果返回失败,那么就代表加锁失败
    3、 客户端A执行代码完成,删除锁
    4、 客户端B在等待一段时间后在去请求设置key的值,设置成功
    5、 客户端B执行代码完成,删除锁
    $redis->set($key, $value, array('nx', 'ex' => $ttl));  //ex表示秒
Copier après la connexion

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