Heim Web-Frontend js-Tutorial Wie Node.js Sequelize die Lese-/Schreibtrennung der Datenbank implementiert

Wie Node.js Sequelize die Lese-/Schreibtrennung der Datenbank implementiert

Dec 09, 2016 pm 01:07 PM
node.js

1. Vorwort

Beim Erstellen einer hochgradig gleichzeitigen Webanwendung muss die Datenbank zusätzlich zur Einführung einer Lastausgleichslösung auf der Anwendungsebene auch hohe Verfügbarkeit und hohe Parallelität unterstützen. Die am häufigsten verwendete Lösung zur Datenbankoptimierung besteht darin, Daten durch Master-Slave-Replikation zu synchronisieren und dann die gleichzeitige Ladekapazität der Datenbank durch Lese-/Schreibtrennung (MySQL-Proxy) zu verbessern.

1. Replikationsoption und Lese-/Schreibtrennung

Sequelize unterstützt die Lese-/Schreibtrennung. Sie können eine Sequelize-Instanz zum Lesen und Schreiben erstellen Eine bequemere Möglichkeit besteht darin, die Lese-/Schreibdatenbank beim Erstellen einer Instanz separat über die Replikationsoption anzugeben.

Um die Lese-/Schreibreplikation in Sequelize zu verwenden, können Sie beim Initialisieren von Sequelize manchmal ein Objekt an seine Replikationsoption übergeben. Dieses Objekt hat zwei Eigenschaften: Lesen und Schreiben. write ist ein einzelnes Objekt (d. h.: Schreibvorgänge werden von einem einzelnen Server verarbeitet), während read ein Array ist, das Objekte enthält (d. h.: Lesevorgänge werden von mehreren Servern verarbeitet). Jeder Lese- und Schreibserver kann die folgenden Attribute enthalten:

· Host – der Host des Datenbankservers

· Port – der Host-Port des Datenbankservers

· Benutzername – Benutzernamen überprüfen

· Passwort – Passwort überprüfen

· Datenbank – Datenbank, die verbunden werden soll

2. Sequelize read/ Beispiel für Schreibtrennung

In einem Cluster mit mehreren Datenbanken, der die Master-Slave-Replikation verwendet, können Sie es im Leseattribut des Replikationsobjekts festlegen. Dieses Attribut ist ein Array, in dem sich eine oder mehrere Serververbindungen befinden können übergeben. Kopie. Der Lesevorgang entspricht dem Betrieb auf dem Slave-Knoten im Datenbankcluster, der alle SELECT-Abfragevorgänge (Lesevorgänge) abwickelt. Das Schreibattribut des Replikationsobjekts ist ein Objekt, das die Serververbindung darstellt. Der Schreibvorgang entspricht dem Primärknoten. Er verarbeitet alle Einfüge-, Aktualisierungs- und Löschvorgänge (Schreibvorgänge).

var sequelize = new Sequelize('database', null, null, {
 dialect: 'mysql',
 port: 3306
 replication: {
  read: [
   { host: '192.168.1.33', username: 'itbilu.com', password: 'pwd' },
   { host: 'localhost', username: 'root', password: null }
  ],
  write: { host: 'localhost', username: 'root', password: null }
 },
 pool: { // 如果需要重写链接池,请在 pool 选项中修改
  maxConnections: 20,
  maxIdleTime: 30000
 },
})
Nach dem Login kopieren

Alle globalen Einstellungen gelten für alle Knotenkopien, sodass keine Notwendigkeit besteht, sie für jede Instanz separat anzugeben. Im obigen Beispiel gelten der Datenbankname und die Portnummer für alle Knotenreplikate, ebenso wie die Optionen für Benutzername und Passwort. Wenn ein Knotenreplikat keine globalen Einstellungen verwendet, muss es in den Replikationsoptionen separat angegeben werden.

Hinweis: Sequelize richtet keine Master-Slave-Replikationsknoten und keine Datensynchronisierung (Replikation) zwischen Knoten ein. Diese Vorgänge werden tatsächlich von MySQL (oder der von Ihnen verwendeten Datenbank) ausgeführt. Sequelize ist nur für das Schreiben oder Lesen von Daten von den Master- und Slave-Knoten verantwortlich.

Sequelize verwendet einen Verbindungspool, um Knotenreplikate zu verwalten.

Die Standardoptionen sind:

{
 maxConnections: 10,
 minConnections: 0,
 maxIdleTime:1000
}
Nach dem Login kopieren


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

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

<🎜>: Bubble Gum Simulator Infinity - So erhalten und verwenden Sie Royal Keys
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusionssystem, erklärt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Flüstern des Hexenbaum
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)

Heiße Themen

Java-Tutorial
1670
14
PHP-Tutorial
1273
29
C#-Tutorial
1256
24
Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Mar 29, 2023 pm 06:02 PM

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Dec 13, 2022 pm 08:00 PM

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Nov 16, 2022 pm 08:34 PM

Node 19 wurde offiziell veröffentlicht. Dieser Artikel wird Ihnen eine detaillierte Erklärung der 6 Hauptfunktionen von Node.js 19 geben. Ich hoffe, er wird Ihnen hilfreich sein!

Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Lassen Sie uns darüber sprechen, wie Sie mit pkg Node.js-Projekte in ausführbare Dateien packen. Dec 02, 2022 pm 09:06 PM

Wie packe ich die ausführbare Datei von nodejs mit pkg? Im folgenden Artikel erfahren Sie, wie Sie mit pkg ein Node-Projekt in eine ausführbare Datei packen. Ich hoffe, dass er Ihnen weiterhilft!

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Lassen Sie uns über die Ereignisschleife in Node sprechen Lassen Sie uns über die Ereignisschleife in Node sprechen Apr 11, 2023 pm 07:08 PM

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!

Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Feb 08, 2023 am 10:09 AM

Der Grund, warum der Knoten den Befehl npm nicht verwenden kann, liegt darin, dass die Umgebungsvariablen nicht richtig konfiguriert sind. Die Lösung ist: 1. Öffnen Sie „Systemeigenschaften“ 2. Suchen Sie nach „Umgebungsvariablen“ -> „Systemvariablen“ und bearbeiten Sie dann die Umgebung Variablen; 3. Suchen Sie den Speicherort des NodeJS-Ordners. 4. Klicken Sie auf „OK“.

See all articles