Einführung in die MySQL-Optimierung für die Unternehmensproduktion

Einführung in die MySQL-Optimierung für die Unternehmensproduktion

Im Vergleich zu anderen großen Datenbanken wie Oracle, DB2, SQL Server usw. weist MySQL zwar seine eigenen Mängel auf, was seiner Beliebtheit jedoch keinen Abbruch tut. Für normale Einzelbenutzer sowie kleine und mittlere Unternehmen sind die von MySQL bereitgestellten Funktionen mehr als ausreichend. Und da MySQL eine Open-Source-Software ist, können die Gesamtbetriebskosten erheblich gesenkt werden.

Wie optimiert ein Unternehmen MySQL in der Produktion?

Referenzantwort:

a: Hardwareoptimierung:

1. Verwenden Sie eine 64-Bit-CPU, mindestens 4 CPUs, und je größer der L2-Cache, desto besser
2. Der Speicher sollte groß sein. 32–64 G können 1–2 Instanzen ausführen, und 96–128 G können 3–4 Instanzen ausführen.
3. Verwenden Sie für mechanische Festplatten eine SAS-Festplatte mit einer Rotationsgeschwindigkeit von mehr als 15000 und verwenden Sie nach Möglichkeit eine SSD
4. Verwenden Sie raid10 als RAID-Karte
5. Mehrere Netzwerkkarten, Gigabit oder höher
6. Verwenden Sie keine Virtualisierung für Datenbanken, und die Slave-Hardware sollte besser sein als die des Masters

b: Betriebssystemoptimierung

1. Wählen Sie x86_64 als Betriebssystem und versuchen Sie, das xfs-Dateisystem zu verwenden
2. Optimieren Sie die Festplattenspeicherparameter
3. Kernel-Parameter optimieren
4. Netzwerk optimieren usw.

c: MySQL-Architekturoptimierung

1. Konfigurieren Sie den Server so, dass mehrere Instanzen basierend auf der Speichergröße ausgeführt werden
2. Die Master-Slave-Replikation verwendet den gemischten Modus. Versuchen Sie, keine Synchronisierung über Rechenzentren hinweg durchzuführen. Wenn Sie eine Synchronisierung über Rechenzentren hinweg durchführen müssen, versuchen Sie, Remote-Schreiben und lokales Lesen zu verwenden.
3. Regelmäßiges Überprüfen und Beheben von Datenunterschieden zwischen Master- und Slave-Replikation
4. Geschäftsaufteilung, die Suchfunktion verwendet zur Ausführung keine MySQL-Datenbank; einige Geschäfte mit hoher Parallelität und allgemeiner Sicherheit verwenden NoSQL, wie Memcache, Redis usw.
5. Fügen Sie dem Datenbank-Frontend einen Cache wie Memcache für die Benutzeranmeldung und Produktabfrage hinzu
6. Statisiere dynamische Daten, statisiere die gesamte Datei und statisiere Seitenfragmente
7. Trennung von Lesen und Schreiben im Datenbankcluster, ein Master und mehrere Slaves, Trennung von Lesen und Schreiben im Cluster durch dbproxy
8. Wenn eine einzelne Tabelle 8 Millionen überschreitet, werden die Datenbank und die Tabelle aufgeteilt, z. B. durch manuelles Aufteilen (Anmeldung, Produkt, Bestellung) in Tabellen und Datenbanken.
9. Wählen Sie Backup aus der Datenbank und führen Sie ein Backup der Datenbank in separaten Tabellen und Datenbanken durch

d: Optimierung auf MySQL-Datenbankebene

1. Optimieren Sie die my.cnf-Parameter
2. Optimieren Sie das Design von Datenbanktabellen, einschließlich Zeichensätzen, Zeichenfolgenlänge, Erstellung kurzer Indizes und Mehrfachverwendung zusammengesetzter Indizes.
3. Optimieren Sie SQL-Anweisungen und reduzieren Sie die Anzahl langsamer Anweisungen.

e: Datenbankmanagementprozess und Systemoptimierung

1. Menschlicher Prozess: Entwicklung -> Kernbetrieb und Wartung/DBA
2. Testprozess: Der Intranet-IDC-Test wird online durchgeführt
3. Kundenverwaltung, PHPMYADMIN

f: Sicherheitsoptimierung für MySQL-Datenbanken

1. Der Datenbank ist es untersagt, ein externes Netzwerk einzurichten
2. Optimieren Sie die Datenbankdateiberechtigungen.
3. Beschränken Sie die Berechtigungen autorisierter Benutzer und versuchen Sie, dedizierte Datenbanken und dedizierte Benutzer zu verwenden
4. Beschränken Sie die Betriebsrechte der Entwickler auf die Produktionsdatenbank
5. Verhindern Sie die Einschleusung von SQL-Anweisungen

Zusammenfassen

Dies ist das Ende dieses Artikels zur Einführung in die MySQL-Optimierung in der Unternehmensproduktion. Ich hoffe, er ist für alle hilfreich. Interessierte Freunde können sich hier informieren: Detaillierte Erläuterung des Oracle-Codes zur Leistungsoptimierung von Paging-Abfragen, Analyse der wichtigsten Punkte der ORACLE-Technologie zur SQL-Anweisungsoptimierung, Einführung in die C/C++-Compileroptimierung usw. Wenn Sie Fragen haben, können Sie jederzeit eine Nachricht hinterlassen und der Herausgeber wird Ihnen rechtzeitig antworten.

Das könnte Sie auch interessieren:
  • Ein kurzer Vortrag über das MySQL-Optimierungstool - langsame Abfrage
  • Lösung für das Problem „Tabelle ist bereits aktuell“ bei der Optimierung einer Tabelle in MySQL
  • 21 Best Practices zur Leistungsoptimierung von MySQL-Datenbanken

<<:  So erstellen Sie einen NFS-Dienst in Ubuntu 16.04

>>:  Ubuntu16.04 erstellt eine php5.6-Webserverumgebung

Artikel empfehlen

Theorie: Die zwei Jahre User Experience

<br />Es ist nicht länger als zwei Jahre her...

Eine Codezeile löst verschiedene IE-Kompatibilitätsprobleme (IE6-IE10)

x-ua-compatible wird verwendet, um das Modell für...

Verwenden des radialen Farbverlaufs in CSS zum Erzielen eines Karteneffekts

Vor einigen Tagen erhielt eine Kollegin ein Punkt...

Schritte zum Anpassen des Symbols in Vue

ant-design-vue passt die Verwendung von Ali Iconf...

Ist es einfach, mit Vue3 eine Popup-Komponente zu kapseln?

Inhaltsverzeichnis Zusammenfassung zuerst: 🌲🌲 Vor...

Teilen des JS-nativen Quellcodes des Spiels 2048 (das Neueste im Internet)

Ich habe mich kürzlich mit Algorithmen beschäftig...

So implementieren Sie Hot Deployment und Hot Start in Eclipse/Tomcat

1. Hot Deployment: Das bedeutet, das gesamte Proj...

So verwenden Sie mysqldump für vollständige und zeitpunktbezogene Sicherungen

Mysqldump wird für logische Backups in MySQL verw...

Installieren Sie CentOS 7 auf VMware14 – Grafik-Tutorial

Einführung in CentOS CentOS ist eine Linux-Distri...

Die Verwendung und der Unterschied zwischen JavaScript-Pseudo-Array und Array

Pseudo-Arrays und Arrays In JavaScript sind mit A...

CSS3 realisiert den grafischen Fallanimationseffekt

Sehen Sie zuerst den Effekt Implementierungscode ...

Kommentare auf Webseiten verursachen Textüberlauf im Internet Explorer

Der experimentelle Code lautet wie folgt: </hea...