suchen
HeimDatenbankRedisRedis-Betriebs- und Wartungsprotokoll für langsame Abfragen

Um Redis gut nutzen zu können, müssen Sie nicht nur wissen, wie man die API verwendet, sondern auch wissen, wie Sie die Blockierung von Redis verhindern und die Blockierung überprüfen und analysieren können. Lassen Sie uns heute mit Ihnen darüber sprechen, wie Sie Redis-Blockierungen entdecken – blockierte Befehle durch langsame Abfragen finden.

Wie MySQL verfügt auch Redis über langsame Abfragedatensätze. Wenn die Befehlsausführungszeit den eingestellten Wert überschreitet, wird der Befehl in der Liste der langsamen Abfragen aufgezeichnet. Mit langsamen Abfragen können wir unsere Programme verbessern. Verhindern Sie, dass Redis blockiert.

Konfiguration

Es gibt zwei Konfigurationsparameter für langsame Abfragen:

  • slowlog-log- slower-than

  • slowlog-max-len

slowlog-log-slower-than wird verwendet, um einen Schwellenwert in Mikrosekunden festzulegen Der Wert ist 10000, also 10 Millisekunden.

  • Wenn der Wert auf weniger als 0 eingestellt ist, werden keine Befehle aufgezeichnet.

  • Wenn der Wert gleich 0 ist, werden alle Befehle aufgezeichnet wird aufgezeichnet.

slowlog-max-len gibt die maximale Anzahl von Datensätzen an. Der Standardwert ist 128. Stellen Sie ihn beispielsweise auf 10 ein. Wenn die 11. langsame Abfrage eingefügt wird, werden die Daten an der Stelle angezeigt Der Kopf der Warteschlange ist außerhalb der Reihe.

Diese beiden Konfigurationen unterstützen auch die dynamische Konfiguration. Wenn das Projekt gerade erst begonnen hat und die Anzahl der Besuche nicht sehr groß ist, kann der Wert von „slow-log-slower-than“ größer eingestellt werden. Wenn die Anzahl der Besuche zunimmt, müssen Sie den Wert möglicherweise auf einen kleineren Wert ändern. Wir möchten den Redis-Dienst jedoch nicht stoppen, sodass wir die Konfiguration dynamisch ändern können.

127.0.0.1:6379> config set slowlog-log-slower-than 1000
OK  
# 在线修改配置
127.0.0.1:6379> config rewrite
OK
# 将修改的配置持久化到配置文件中

Vorschläge für Betrieb und Wartung: Wenn die Anzahl der Besuche groß ist, empfehlen wir im Allgemeinen, slowlog-log-slower-than auf 1000 oder weniger einzustellen. Wenn dieser Wert 1000 beträgt, bedeutet dies, dass Redis bis zu 1000 Parallelität unterstützen kann.

Langsame Abfrageansicht

Die langsame Abfrageansicht von Redis unterscheidet sich von der MySQL-Ansicht. Für die Redis-Ansicht gibt es spezielle Befehle.

Langsames Abfrageprotokoll abrufen

slowlog get [n], n stellt die Anzahl der Einträge dar, der Standardwert ist 10

127.0.0.1:6379> slowlog get
1) 1) (integer) 18004
   2) (integer) 1589424642
   3) (integer) 50
   4) 1) "slowlog"
      2) "get"
   5) "127.0.0.1:58364"
   6) ""
2) 1) (integer) 18003
   2) (integer) 1589423805
   3) (integer) 47
   4) 1) "slowlog"
      2) "get"
   5) "127.0.0.1:58364"
   6) ""
……
  • Der erste Parameter ist die Protokoll-ID-Nummer

  • Der zweite Parameter ist der Zeitstempel des Auftretens

  • Der dritte Parameter ist die Ausführungszeit des Befehls (subtil)

  • Der letzte ist der Befehl und die Parameter.

Ermitteln Sie die Länge einer langsamen Abfrage

slowlog len

127.0.0.1:6379> slowlog len
(integer) 128

Löschen Sie die Liste der langsamen Abfragen

127.0.0.1:6379> slowlog reset
OK

Persistenz des langsamen Abfrageprotokolls in MySQL

Aufgrund der Länge von Redis ist begrenzt, sodass es bei vielen langsamen Abfragen zu Verlusten kommt. Wir können regelmäßig zu Redis gehen, um die Liste der langsamen Abfragedatensätze zu entfernen und sie in MySQL beizubehalten, um dies zu verhindern.

Der Pseudocode lautet wie folgt:

while (true) {
    $slowlen = $redis->slowlog('len');
    $slowlogs = $redis->slowlog('get',$slowlen);
    $insSql  = "INSERT INTO 
        slowlog(exec_time,run_time,command) VALUES";
     
    if (is_array($slowlogs) && count($slowlogs)) {
     
        foreach ($slowlogs as $slowlog) {
            $execTime = $slowlog[2];
            $runTime  = $slowlog[1];
            $command  = implode(' ', $slowlog[3]);
     
            $insSql .= "('$execTime', '$runTime','$command'),";
        }
     
        $flag = mysqli_query($mysqli, substr($insSql, 0, -1));
     
        if ($flag) {
            $redis->slowlog('reset');
        }
    }
    
    unsleep(10000);
}

Der obige Code kann die Beständigkeit langsamer Abfragen in MYSQL realisieren.

Das obige ist der detaillierte Inhalt vonRedis-Betriebs- und Wartungsprotokoll für langsame Abfragen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Redis: Jenseits SQL - Die NoSQL -PerspektiveRedis: Jenseits SQL - Die NoSQL -PerspektiveMay 08, 2025 am 12:25 AM

Redis geht aufgrund seiner hohen Leistung und Flexibilität über die SQL -Datenbanken hinaus. 1) Redis erreicht extrem schnelle Lesen und Schreiben von Geschwindigkeit über Speicherspeicher. 2) Es unterstützt eine Vielzahl von Datenstrukturen wie Listen und Sammlungen, die für die komplexe Datenverarbeitung geeignet sind. 3) Einfach-Thread-Modell vereinfacht die Entwicklung, aber eine hohe Parallelität kann zu einem Engpass werden.

Redis: Ein Vergleich mit herkömmlichen DatenbankservernRedis: Ein Vergleich mit herkömmlichen DatenbankservernMay 07, 2025 am 12:09 AM

Redis ist traditionellen Datenbanken in hoher Parallelitäts- und Latenz -Szenarien überlegen, ist jedoch nicht für komplexe Abfragen und Transaktionsverarbeitung geeignet. 1.Redis verwendet Speicherspeicher-, Schnelllese- und Schreibgeschwindigkeit, geeignet für Anforderungen an eine hohe Parallelität und niedrige Latenz. 2. Traditionelle Datenbanken basieren auf Festplatten, unterstützen komplexe Abfragen und Transaktionsverarbeitung und haben eine starke Datenkonsistenz und -dauer. 3.. Redis ist als Ergänzung oder Ersatz für herkömmliche Datenbanken geeignet, muss jedoch nach bestimmten Geschäftsbedürfnissen ausgewählt werden.

Redis: Einführung in einen leistungsstarken In-Memory-DatenspeicherRedis: Einführung in einen leistungsstarken In-Memory-DatenspeicherMay 06, 2025 am 12:08 AM

Redisisahigh-Performancein-MemoryDatastructurestorethatexcelsinSpeedandversatility.1) IssupportsvariousDatastructureslikestrings, Listen und Sets

Ist Redis in erster Linie eine Datenbank?Ist Redis in erster Linie eine Datenbank?May 05, 2025 am 12:07 AM

Redis ist in erster Linie eine Datenbank, aber mehr als nur eine Datenbank. 1. Als Datenbank unterstützt Wiedererlangung die Persistenz und eignet sich für leistungsstarke Bedürfnisse. 2. Als Cache verbessert Redis die Reaktionsgeschwindigkeit der Anwendung. 3. Als Message Broker unterstützt Redis den Veröffentlichungs-Subscribe-Modus, der für die Echtzeitkommunikation geeignet ist.

Redis: Datenbank, Server oder etwas anderes?Redis: Datenbank, Server oder etwas anderes?May 04, 2025 am 12:08 AM

RedisisamultifacetedtoolthatervesaSadatabase, Server, und More.itfunctionsasanin-MemoryDatastructurestore, SupportSVariousDatastructures und Canbusesedasacache, MessageBroker, SessionStorage und ForforbutedLocking.

Redis: Enthüllung seines Zwecks und der wichtigsten AnwendungenRedis: Enthüllung seines Zwecks und der wichtigsten AnwendungenMay 03, 2025 am 12:11 AM

Redisisanopen-Source, In-MemoryDatastructurEnusedasadatabase, Cache und MessageBroker, ExcellingInSpeedandversatility

Redis: Eine Anleitung zu SchlüsselwertdatenspeichernRedis: Eine Anleitung zu SchlüsselwertdatenspeichernMay 02, 2025 am 12:10 AM

Redis ist ein Open -Source -Speicherdatenstrukturspeicher, der als Datenbank, Cache und Message Broker verwendet wird und für Szenarien geeignet ist, in denen eine schnelle Reaktion und eine hohe Parallelität erforderlich sind. 1.Redis verwendet Speicher, um Daten zu speichern, und bietet mikrosekundenüberlesene und schreibgeschwindige. 2. Es unterstützt eine Vielzahl von Datenstrukturen wie Zeichenfolgen, Listen, Sammlungen usw.. 4. Verwenden Sie ein Single-Thread-Modell und die Multiplexing-Technologie, um Anforderungen effizient zu bearbeiten. 5. Leistungsoptimierungsstrategien umfassen den LRU -Algorithmus und der Clustermodus.

Redis: Caching, Sitzungsmanagement und mehrRedis: Caching, Sitzungsmanagement und mehrMay 01, 2025 am 12:03 AM

Die Funktionen von Redis enthalten hauptsächlich Cache, Sitzungsmanagement und andere Funktionen: 1) Die Cache-Funktion speichert Daten über den Speicher, um die Lesegeschwindigkeit zu verbessern, und eignet sich für hochfrequente Zugriffsszenarien wie E-Commerce-Websites. 2) Die Sitzungsverwaltungsfunktion teilt Sitzungsdaten in einem verteilten System und reinigt sie automatisch über einen Mechanismus für Ablaufzeiten. 3) Andere Funktionen wie Publish-Subscribe-Modus, verteilte Sperren und Zähler, geeignet für Echtzeit-Nachrichten-Push- und Multi-Thread-Systeme und andere Szenarien.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Nordhold: Fusionssystem, erklärt
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
3 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

SublimeText3 Englische Version

SublimeText3 Englische Version

Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

EditPlus chinesische Crack-Version

EditPlus chinesische Crack-Version

Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software