Maison > Article > base de données > Tampon d'exploitation et de maintenance Redis
Peut-être que de nombreux développeurs pensent que Redis est très simple et qu'il suffit de maîtriser certaines API. En fait, une mauvaise utilisation entraînera de nombreux problèmes. Aujourd'hui, parlons de la mise en mémoire tampon Redis. Redis fournit des tampons d'entrée et des tampons de sortie au client, et fournit les API correspondantes pour afficher les tampons de surveillance.
Tampon d'entrée
Redis fournit un tampon d'entrée pour chaque client. Sa fonction est d'envoyer le tampon d'entrée du client. enregistré, puis Redis extrait la commande du tampon d'entrée et l'exécute.
La taille du tampon d'entrée fournie par Redis pour le client est limitée et ne peut pas dépasser 1 Go de mémoire. Si elle dépasse, Redis fermera le client.
Risques de débordement de tampon
Le tampon d'entrée maximum de chaque client ne peut pas dépasser 1G. S'il dépasse, le client le désactivera. entraînera des problèmes avec l’application.
La taille du tampon d'entrée ne peut pas être contrôlée par maxmory. Lorsque maxmory est défini sur 8G, lorsque Redis a stocké des données 4G et que la taille totale du tampon d'entrée de tous les clients est de 5G, une perte de données peut survenir. Obsolescence des valeurs clés, MOO et autres situations.
La raison du débordement de tampon est que la vitesse de traitement de Redis ne peut pas suivre la vitesse d'entrée du tampon. Une situation courante est que le tampon d'entrée contient un grand nombre de bigkeys ou que Redis est bloqué.
Surveillance
Il existe deux façons de surveiller le tampon d'entrée
La première méthode est Utilisez la commande client list pour afficher les informations de tous les clients actuellement connectés
La deuxième méthode consiste à afficher les informations globales via la commande info clients.
127.0.0.1:6379> client list id=113430 addr=127.0.0.1:57244 fd=7 name= age=3115 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=26 qbuf-free=32742 obl=0 oll=0 omem=0 events=r cmd=client id=113432 addr=127.0.0.1:57250 fd=9 name= age=3099 idle=342 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=0 oll=0 omem=0 events=r cmd=set ……
Parmi eux, liés au tampon d'entrée, il y a qbuf et qbuf-free, qui représentent respectivement la taille du tampon d'entrée et la taille du tampon d'entrée restant.
127.0.0.1:6379> info clients # Clients connected_clients:4 client_recent_max_input_buffer:2 client_recent_max_output_buffer:0 blocked_clients:0
client_recent_max_input_buffer indique la taille du tampon d'entrée maximum.
Ces deux méthodes ont leurs propres avantages et inconvénients :
la liste de clients peut surveiller avec précision la situation de chaque client, mais la vitesse d'exécution est lente et peut provoquer un blocage Redis .
info clients s'exécute rapidement, mais les données analysées sont relativement simples et ne peuvent pas être précises pour chaque client, et elles ne peuvent pas afficher la taille totale du tampon d'entrée du client, seulement la plus grande.
Tampon de sortie
Redis fournit également un tampon de sortie Comme le tampon d'entrée, le tampon de sortie Il l'est également. non contrôlé par maxmory.
Mais contrairement au tampon d'entrée, le tampon de sortie peut être limité via le fichier de configuration.
client-output-buffer-limit type hardlimit softlimit secords
type représente le type de client
hardlimit est la valeur maximale du tampon de sortie. S'il dépasse la limite, il sera immédiatement fermé
sortlimit et secords Lorsque la limite de tri est dépassée pendant quelques secondes. le client sera arrêté.
La configuration par défaut de Redis est la suivante :
client-output-buffer-limit normal 0 0 0 client-output-buffer-limit replica 256mb 64mb 60 client-output-buffer-limit pubsub 32mb 8mb 60
Surveillance
et méthodes de surveillance du tampon de sortie De même, la liste des clients et les informations clients seront également utilisées.
Les éléments liés à la mise en mémoire tampon de sortie dans la liste des clients sont obl, oll et omem, en regardant principalement omem, qui représente la taille du tampon de sortie.
client_recent_max_output_buffer dans info clients indique la taille maximale du tampon de sortie.
Leurs avantages et inconvénients sont les mêmes que ceux mentionnés précédemment, je n’entrerai donc pas dans les détails ici.
De plus, voici une autre commande pour fermer la connexion client.
client kill ip:port
Lorsqu'une anomalie est détectée sur le client, vous pouvez utiliser cette commande pour fermer la connexion anormale.
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!