Inhaltsverzeichnis
1. Vorwort
1、目标与收获
Node
(2) Dienstkonfiguration
1. Die anfängliche Konfigurationsdatei des Redis-Instanzknotens
2. Die anfängliche Konfigurationsdatei des Knotens verwendet die Standardkonfigurationsdatei als Vorlage.
Beim Testen oder Lernen wird empfohlen, den Vordergrundprozessverwaltungsdienst zu verwenden, um die Simulation einzelner Punkte zu erleichtern von Fehlern, Anzeigen von Protokollen und Beobachten der Master-Slave-Umschaltung.
(1) Grundlegende Integration
Der Inhalt der Basisintegration besteht darin, mithilfe eines Java-Clients eine Verbindung zum hochverfügbaren Redis-Dienst im Sentinel-Modus herzustellen, um die Anforderungen für den normalen Betrieb von Einzelknoten-Fehlerdiensten zu erfüllen.
1. Globale Konfigurationsdatei
2. Die integrierte Konfiguration ist in das SpringBoot-System integriert. Der Kern besteht darin, eine LettuceConnectionFactory-Verbindungsfabrik zu erstellen, die problemlos in andere Frameworks unter Spring vererbt werden kann System.
Die Basisintegration implementiert nur den Prozess des hochverfügbaren Redis-Dienstes. In der Produktionsumgebung müssen noch andere Konfigurationen hinzugefügt werden: Ändern Sie die Seriennummer der benutzerdefinierten Verbindungsdatenbank Poolkonfiguration; Lese- und Schreibtrennung.
2、集成配置
Heim Datenbank Redis Beispielanalyse der Hochverfügbarkeit im Redis-Sentry-Modus

Beispielanalyse der Hochverfügbarkeit im Redis-Sentry-Modus

Jun 02, 2023 pm 10:38 PM
redis

    1. Vorwort

    Redis Hochverfügbarkeit verfügt über zwei Modi: Sentinel-Modus und Cluster-Modus. Dieser Artikel erstellt einen -Host basierend auf Sentinel-Modus Zwei von drei SentinelsRedis-Hochverfügbarkeitsdienst. 哨兵模式集群模式,本文基于哨兵模式搭建一主两从三哨兵Redis高可用服务。

    1、目标与收获

    一主两从三哨兵

    1. Ziele und Vorteile
    • Ein Master, zwei Slaves und drei SentinelsDer Redis-Dienst kann grundsätzlich die Hochverfügbarkeitsanforderungen kleiner und mittlerer Projekte erfüllen . Durch diesen Artikel werden die folgenden Ziele erreicht:

    • Planung und Konstruktion des Sentinel-Modus-Dienstes

    • Der Sentinel-Modus-Dienst ist zuverlässiger als der eigenständige Versionsdienst und eignet sich für die Lese- und Schreibtrennung, die Menge Die Datenmenge ist nicht groß und erfordert Zuverlässigkeit und Stabilität der Szene.

    • Client-Integration und Trennung von Lesen und Schreiben

    Stellen Sie über das Spring-Framework eine Verbindung zum Sentry-Modus her, um allgemeine Vorgänge in der Produktionsumgebung abzuschließen.

    2. Hafenplanung

    Beispielanalyse der Hochverfügbarkeit im Redis-Sentry-ModusHafenplanung ist der erste Schritt zur Vervollständigung dieser Lösung.

    2. Einzelmaschinensimulation

    Bei der Einzelmaschinensimulation werden Vorgänge auf einer physischen oder virtuellen Maschine simuliert, um den Zwischenprozess der ursprünglichen Lösung so weit wie möglich wiederherzustellen. Sie wird normalerweise beim Lernen verwendet Entwicklungsstadium.

    Um den Vorgang zu vereinfachen, trifft der Redis-Dienst die folgenden Konventionen: Die Daten werden nicht auf der Festplatte gespeichert. Die Konfigurationsdateien des Vordergrundknotens verwenden die Standardkonfigurationsdatei als Vorlage.
    (1) Dienstplanung

    1. Redis-Instanz Der Dienst weiß eindeutig, welcher Knoten der Masterknoten ist, wenn er zum ersten Mal ausgeführt wird und ein Master-Slave-Wechsel auftritt Es kann nicht angezeigt werden, um welchen Knoten es sich handelt. Der Knoten ist der Masterknoten und muss indirekt über die Befehlszeile abgefragt werden. KnotenHostPortRolleExtra-Konfigurationnode01127.0.0.16380Dienst als beim ersten Start node02127.0 .0.16381Diente als Sklave, als er zum ersten Mal gestartet wurde. Nachbildung von 127.0.0.1 6380 Zum ersten Mal gestartetReplik von 127.0.0.1 6380Es gibt keine Master-Slave-Unterscheidung zwischen Sentinel-Dienstknoten und alle Knoten sind gleichberechtigt. Wenn im Hauptdienst eine Ausnahme auftritt, löst der Sentinel-Dienst die Abstimmungsstrategie aus und wählt Kandidaten aus den Slave-Knoten der Redis-Instanz als neuen Hauptdienst aus.
    Zusätzliche Konfiguration bezieht sich auf die neue Konfiguration in der Knotenkonfigurationsdatei, wenn die Redis-Dienstinstanz zum ersten Mal gestartet wird. 2. Sentinel-Dienst

    Node

    Host

    PortZusätzliche Konfigurationnode01127.0.0.126380Sentinel Monitor Mymaster. 127 .0.0. 1 6380 2node02127.0. 0.126381Sentinel Monitor Mymaster 127.0.0.1 6380 2

    (2) Dienstkonfiguration

    1. Die anfängliche Konfigurationsdatei des Redis-Instanzknotens

    verwendet die Standardkonfigurationsdatei als Vorlage.

    Nachdem Knoten01 und Knoten02 die Konfigurationsdatei initialisiert haben, wird die Master-Slave-Beziehung zwischen den Knoten angezeigt und die folgende Konfiguration hinzugefügt:

    replicaof 127.0.0.1 6380
    Nach dem Login kopieren
    2. Die anfängliche Konfigurationsdatei des Knotens verwendet die Standardkonfigurationsdatei als Vorlage.

    Fügen Sie nach der Initialisierung der Konfigurationsdateien von Knoten01, Knoten02 und Knoten03 die folgende Konfiguration hinzu:

    sentinel monitor mymaster 127.0.0.1 6381 2
    Nach dem Login kopieren

    (3) Dienstverwaltung

    Beim Testen oder Lernen wird empfohlen, den Vordergrundprozessverwaltungsdienst zu verwenden, um die Simulation einzelner Punkte zu erleichtern von Fehlern, Anzeigen von Protokollen und Beobachten der Master-Slave-Umschaltung.

    Es wird empfohlen, den Supervisor-Verwaltungsdienst unter Produktionsbedingungen zu verwenden, der nicht nur einfach zu verwalten ist, sondern den Dienst auch nach einer abnormalen Beendigung automatisch neu starten kann. In Hochverfügbarkeitsszenarien werden drei physische Maschinen verwendet.

    1 Redis-Instanz Mit der Produktion müssen neue Funktionen hinzugefügt werden.

    (1) Grundlegende Integration
    Der Inhalt der Basisintegration besteht darin, mithilfe eines Java-Clients eine Verbindung zum hochverfügbaren Redis-Dienst im Sentinel-Modus herzustellen, um die Anforderungen für den normalen Betrieb von Einzelknoten-Fehlerdiensten zu erfüllen.

    1. Globale Konfigurationsdatei

    Die der globalen Konfigurationsdatei hinzugefügten Konfigurationsinformationen sind: Der Parameter master ist der Name des Sentinel-Dienstes, hier ist der Standardwert; > Parameter ist die Sentinel-Service-Liste (nicht Redis-Instanz-Service-Liste); der database-Parameter ist die Datenbank.

    /usr/local/redis/bin/redis-server /usr/local/redis/conf/ms/redis80.conf --port 6380 --save '' --daemonize no 
    /usr/local/redis/bin/redis-server /usr/local/redis/conf/ms/redis81.conf --port 6381 --save '' --daemonize no
    /usr/local/redis/bin/redis-server /usr/local/redis/conf/ms/redis82.conf --port 6382 --save '' --daemonize no
    Nach dem Login kopieren

    2. Die integrierte Konfiguration ist in das SpringBoot-System integriert. Der Kern besteht darin, eine LettuceConnectionFactory-Verbindungsfabrik zu erstellen, die problemlos in andere Frameworks unter Spring vererbt werden kann System.

    /usr/local/redis/bin/redis-sentinel /usr/local/redis/conf/ms/sentinel280.conf --port 26380 --daemonize no
    /usr/local/redis/bin/redis-sentinel /usr/local/redis/conf/ms/sentinel281.conf --port 26381 --daemonize no
    /usr/local/redis/bin/redis-sentinel /usr/local/redis/conf/ms/sentinel282.conf --port 26382 --daemonize no
    Nach dem Login kopieren

    (2) Lese- und Schreibtrennung

    Die Basisintegration implementiert nur den Prozess des hochverfügbaren Redis-Dienstes. In der Produktionsumgebung müssen noch andere Konfigurationen hinzugefügt werden: Ändern Sie die Seriennummer der benutzerdefinierten Verbindungsdatenbank Poolkonfiguration; Lese- und Schreibtrennung.

    Unter der Voraussetzung einer hohen Verfügbarkeit wird die Funktion der Trennung von Lesen und Schreiben abgeleitet. Die Hauptbibliothek schließt die Leseanforderung ab (die Slave-Bibliothek lässt kein Schreiben zu). master参数为哨兵服务名,此处为默认值;nodes参数为哨兵服务列表(不是Redis实例服务列表);database参数为数据库。

    spring:
      redis:
        database: 0
        sentinel:
          nodes: 192.168.181.171:26380,192.168.181.171:26381,192.168.181.171:26382
          master: mymaster
    Nach dem Login kopieren
    2、集成配置

    集成进SpringBoot体系,最核心的是创建LettuceConnectionFactory

    @Configuration
    public class RedisSentinelConfig {
        @Autowired
        private RedisProperties redisProperties;
        
        @Bean
        public RedisConnectionFactory lettuceConnectionFactory() {
            RedisProperties.Sentinel sentinel = redisProperties.getSentinel();
            HashSet<String> nodes = new HashSet<>(sentinel.getNodes());
            String master = sentinel.getMaster();
            RedisSentinelConfiguration config = new RedisSentinelConfiguration(master, nodes);
            config.setDatabase(redisProperties.getDatabase());
            return new LettuceConnectionFactory(config);
        }
    }
    Nach dem Login kopieren

    Das obige ist der detaillierte Inhalt vonBeispielanalyse der Hochverfügbarkeit im Redis-Sentry-Modus. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Erklärung dieser Website
    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

    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

    AI Hentai Generator

    AI Hentai Generator

    Erstellen Sie kostenlos Ai Hentai.

    Heißer Artikel

    R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Beste grafische Einstellungen
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
    WWE 2K25: Wie man alles in Myrise freischaltet
    3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

    Heiße Werkzeuge

    Notepad++7.3.1

    Notepad++7.3.1

    Einfach zu bedienender und kostenloser Code-Editor

    SublimeText3 chinesische Version

    SublimeText3 chinesische Version

    Chinesische Version, sehr einfach zu bedienen

    Senden Sie Studio 13.0.1

    Senden Sie Studio 13.0.1

    Leistungsstarke integrierte PHP-Entwicklungsumgebung

    Dreamweaver CS6

    Dreamweaver CS6

    Visuelle Webentwicklungstools

    SublimeText3 Mac-Version

    SublimeText3 Mac-Version

    Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

    So erstellen Sie den Redis -Clustermodus So erstellen Sie den Redis -Clustermodus Apr 10, 2025 pm 10:15 PM

    Der Redis -Cluster -Modus bietet Redis -Instanzen durch Sharding, die Skalierbarkeit und Verfügbarkeit verbessert. Die Bauschritte sind wie folgt: Erstellen Sie ungerade Redis -Instanzen mit verschiedenen Ports; Erstellen Sie 3 Sentinel -Instanzen, Monitor -Redis -Instanzen und Failover; Konfigurieren von Sentinel -Konfigurationsdateien, Informationen zur Überwachung von Redis -Instanzinformationen und Failover -Einstellungen hinzufügen. Konfigurieren von Redis -Instanzkonfigurationsdateien, aktivieren Sie den Cluster -Modus und geben Sie den Cluster -Informationsdateipfad an. Erstellen Sie die Datei nodes.conf, die Informationen zu jeder Redis -Instanz enthält. Starten Sie den Cluster, führen Sie den Befehl erstellen aus, um einen Cluster zu erstellen und die Anzahl der Replikate anzugeben. Melden Sie sich im Cluster an, um den Befehl cluster info auszuführen, um den Clusterstatus zu überprüfen. machen

    So implementieren Sie die zugrunde liegenden Redis So implementieren Sie die zugrunde liegenden Redis Apr 10, 2025 pm 07:21 PM

    Redis verwendet Hash -Tabellen, um Daten zu speichern und unterstützt Datenstrukturen wie Zeichenfolgen, Listen, Hash -Tabellen, Sammlungen und geordnete Sammlungen. Ernähren sich weiterhin über Daten über Snapshots (RDB) und appendiert Mechanismen nur Schreibmechanismen. Redis verwendet die Master-Slave-Replikation, um die Datenverfügbarkeit zu verbessern. Redis verwendet eine Ereignisschleife mit einer Thread, um Verbindungen und Befehle zu verarbeiten, um die Datenatomizität und Konsistenz zu gewährleisten. Redis legt die Ablaufzeit für den Schlüssel fest und verwendet den faulen Löschmechanismus, um den Ablaufschlüssel zu löschen.

    Was tun, wenn Redis-Server nicht gefunden werden kann Was tun, wenn Redis-Server nicht gefunden werden kann Apr 10, 2025 pm 06:54 PM

    Schritte zur Lösung des Problems, das Redis-Server nicht finden kann: Überprüfen Sie die Installation, um sicherzustellen, dass Redis korrekt installiert ist. Setzen Sie die Umgebungsvariablen Redis_host und Redis_port; Starten Sie den Redis-Server Redis-Server; Überprüfen Sie, ob der Server Redis-Cli Ping ausführt.

    Wie wird der Redis -Cluster implementiert? Wie wird der Redis -Cluster implementiert? Apr 10, 2025 pm 05:27 PM

    Redis Cluster ist ein verteiltes Bereitstellungsmodell, das die horizontale Expansion von Redis-Instanzen ermöglicht und durch Kommunikation zwischen Noten, Hash-Slot-Abteilung Schlüsselraum, Knotenwahlen, Master-Slave-Replikation und Befehlsumleitung implementiert wird: Inter-Node-Kommunikation: Virtuelle Netzwerkkommunikation wird durch Cluster-Bus realisiert. Hash -Slot: Teilen Sie den Schlüsselraum in Hash -Slots, um den für den Schlüssel verantwortlichen Knoten zu bestimmen. Knotenwahlen: Es sind mindestens drei Master -Knoten erforderlich, und nur ein aktiver Masterknoten wird durch den Wahlmechanismus sichergestellt. Master-Slave-Replikation: Der Masterknoten ist für das Schreiben von Anforderungen verantwortlich und der Slaveknoten ist für das Lesen von Anforderungen und Datenreplikation verantwortlich. Befehlsumleitung: Der Client stellt eine Verbindung zum für den Schlüssel verantwortlichen Knoten her, und der Knoten leitet falsche Anforderungen weiter. Fehlerbehebung: Fehlererkennung, Off-Linie markieren und neu

    Wie ist der Schlüssel für die Redis -Abfrage eindeutig Wie ist der Schlüssel für die Redis -Abfrage eindeutig Apr 10, 2025 pm 07:03 PM

    Redis verwendet fünf Strategien, um die Einzigartigkeit von Schlüssel zu gewährleisten: 1. Namespace -Trennung; 2. Hash -Datenstruktur; 3.. Datenstruktur festlegen; 4. Sonderzeichen von Stringschlüssel; 5. Lua -Skriptüberprüfung. Die Auswahl spezifischer Strategien hängt von Datenorganisationen, Leistung und Skalierbarkeit ab.

    So sehen Sie alle Schlüssel in Redis So sehen Sie alle Schlüssel in Redis Apr 10, 2025 pm 07:15 PM

    Um alle Schlüssel in Redis anzuzeigen, gibt es drei Möglichkeiten: Verwenden Sie den Befehl keys, um alle Schlüssel zurückzugeben, die dem angegebenen Muster übereinstimmen. Verwenden Sie den Befehl scan, um über die Schlüssel zu iterieren und eine Reihe von Schlüssel zurückzugeben. Verwenden Sie den Befehl Info, um die Gesamtzahl der Schlüssel zu erhalten.

    So verwenden Sie Redis Zset So verwenden Sie Redis Zset Apr 10, 2025 pm 07:27 PM

    Redis bestellte Sets (ZSETs) werden verwendet, um bestellte Elemente und Sortieren nach zugehörigen Bewertungen zu speichern. Die Schritte zur Verwendung von ZSET umfassen: 1. Erstellen Sie ein Zset; 2. Fügen Sie ein Mitglied hinzu; 3.. Holen Sie sich eine Mitgliederbewertung; 4. Holen Sie sich eine Rangliste; 5. Holen Sie sich ein Mitglied in der Rangliste; 6. Ein Mitglied löschen; 7. Holen Sie sich die Anzahl der Elemente; 8. Holen Sie sich die Anzahl der Mitglieder im Score -Bereich.

    So sehen Sie die Versionsnummer der Redis So sehen Sie die Versionsnummer der Redis Apr 10, 2025 pm 05:57 PM

    Um die Redis -Versionsnummer anzuzeigen, können Sie die folgenden drei Methoden verwenden: (1) Geben Sie den Info -Befehl ein, (2) Starten Sie den Server mit der Option --version und (3) die Konfigurationsdatei anzeigen.

    See all articles