


Eine ausführliche Einführung zur Optimierung von MySQL unter Linux
In diesem Artikel werden hauptsächlich relevante Informationen zu MySQL-Optimierungsbeispielen in Linux vorgestellt. Freunde in Not können sich auf
Linux-Paar beziehen. Detaillierte Erklärung von MySQL Optimierungsbeispiele
vim /etc/my.cnf Im Folgenden wird nur der Inhalt des Absatzes [mysqld] in der Datei my.cnf aufgeführt. Der Inhalt anderer Absätze hat kaum Auswirkungen auf die Laufleistung von MySQL, also vorerst vernachlässigen.
[mysqld] port = 3306 serverid = 1 socket = /tmp/mysql.sock skip-locking
Vermeiden Sie die externe Sperrung von MySQL, reduzieren Sie das Fehlerrisiko und verbessern Sie die Stabilität.
skip-name-resolve
Verbieten Sie MySQL die DNS-Auflösung für externe Verbindungen. Durch die Verwendung dieser Option kann MySQL Zeit für die DNS-Auflösung sparen. Es ist jedoch zu beachten, dass bei aktivierter Option alle Remote-Host-Verbindungsberechtigungen IP-Adressen verwenden müssen, da MySQL sonst Verbindungsanfragen nicht normal verarbeiten kann!
back_log = 384
Der Wert des back_log-Parameters gibt an, wie viele Anfragen in kurzer Zeit im Stack gespeichert werden können, bevor MySQL vorübergehend nicht mehr auf neue Anfragen reagiert. Wenn das System in kurzer Zeit viele Verbindungen hat, müssen Sie den Wert dieses Parameters erhöhen, der die Größe der Überwachungs-Warteschlange für eingehende TCP/IP-Verbindungen angibt. Verschiedene Betriebssysteme haben ihre eigenen Grenzen für diese Warteschlangengröße. Der Versuch, back_log auf einen höheren Wert als den Grenzwert Ihres Betriebssystems festzulegen, hat keine Auswirkung. Der Standardwert ist 50. Für Linux-Systeme wird empfohlen, den Wert auf eine Ganzzahl kleiner als 512 festzulegen.
key_buffer_size = 256M
key_buffer_size gibt die Puffergröße an, die für index verwendet wird. Erhöhen Sie sie für eine bessere Indexverarbeitungsleistung. Für Server mit einem Arbeitsspeicher von etwa 4 GB kann dieser Parameter auf 256 MB oder 384 MB eingestellt werden. Hinweis: Wenn Sie diesen Parameterwert zu groß einstellen, verringert sich die Gesamteffizienz des Servers!
max_allowed_packet = 4M thread_stack = 256K table_cache = 128K sort_buffer_size = 6M
Fragen Sie die Puffergröße ab, die beim Sortieren verwendet werden kann. Hinweis: Der diesem Parameter zugeordnete Speicher gilt exklusiv für jede Verbindung. Bei 100 Verbindungen beträgt die gesamte zugewiesene Sortierpuffergröße 100 × 6 = 600 MB. Daher wird empfohlen, ihn für einen Server mit einem Speicher von etwa 4 GB auf 6-8 MB einzustellen.
read_buffer_size = 4M
Die Puffergröße, die von Leseabfragevorgängen verwendet werden kann. Wie sort_buffer_size gilt auch der diesem Parameter zugeordnete Speicher exklusiv für jede Verbindung.
join_buffer_size = 8M
Die Puffergröße, die von der gemeinsamen Abfrage verwendet werden kann Wie bei sort_buffer_size gilt auch der diesem Parameter zugeordnete Speicher exklusiv für jede Verbindung.
myisam_sort_buffer_size = 64M table_cache = 512 thread_cache_size = 64 query_cache_size = 64M
Gibt die Größe des MySQL-Abfragepuffers an. Dies kann in der MySQL-Konsole beobachtet werden. Wenn der Wert von Qcache_lowmem_prunes sehr groß ist, weist dies darauf hin, dass die Pufferung häufig nicht ausreicht Wenn der Wert klein ist, wirkt sich dies auf die Effizienz aus. Dann können Sie erwägen, den Cache nicht abzufragen. Wenn der Wert sehr groß ist, bedeutet dies, dass sich viele Fragmente im Puffer befinden.
tmp_table_size = 256M max_connections = 768
Geben Sie die maximale Anzahl von Verbindungsvorgängen an, die MySQL zulässt. Wenn beim Zugriff auf das Forum häufig die Fehlermeldung „Too ManyConnections“ erscheint, müssen Sie den Wert dieses Parameters erhöhen.
max_connect_errors = 10000000 wait_timeout = 10
Geben Sie die maximale Verbindungszeit für eine Anfrage an. Für Server mit etwa 4 GB Speicher kann sie auf 5-10 eingestellt werden.
thread_concurrency = 8
Der Wert dieses Parameters ist die Anzahl der logischen Server-CPUs * 2. In diesem Beispiel verfügt der Server über 2 physische CPUs und jede physische CPU unterstützt H.T-Hyper-Threading. Der tatsächliche Wert lautet also 4 *2=8
skip-networking
Aktivieren Sie diese Option, um die TCP/IP-Verbindungsmethode von MySQL vollständig zu schließen. Wenn der WEB-Server über eine Remote-Verbindung auf den MySQL-Datenbank-Server zugreift, tun Sie dies Aktivieren Sie diese Option nicht! Andernfalls ist die normale Verbindung nicht möglich!
table_cache=1024
Je größer der physische Speicher, desto größer die Einstellung. Der Standardwert ist 2402, passen Sie ihn für eine optimale Einstellung auf 512-1024 an
innodb_additional_mem_pool_size=4M
Der Standardwert ist 2M
innodb_flush_log_at_trx_commit=1
Wenn Sie den Wert auf 0 setzen, müssen Sie warten, bis die innodb_log_buffer_size-Warteschlange voll ist, bevor Sie sie gleichmäßig speichern. Der Standardwert ist 1.
innodb_log_buffer_size=2M
Setzen Sie ihn auf Wie viele CPUs hat Ihr Server? Es wird empfohlen, den Standardwert 8 zu verwenden
innodb_thread_concurrency=8
key_buffer_size=256M #默认为218,调到128最佳 tmp_table_size=64M #默认为16M,调到64-256最挂 read_buffer_size=4M #默认为64K read_rnd_buffer_size=16M #默认为256K sort_buffer_size=32M #默认为256K thread_cache_size=120 #默认为60 query_cache_size=32M
Viele Situationen erfordern spezifische Angaben Analyse
1. Wenn Key_reads zu groß ist, sollten Sie die Key_buffer_size in my.cnf erhöhen und Key_reads/Key_read_requests auf mindestens 1/100 halten.
2. Wenn Qcache_lowmem_prunes sehr groß ist, erhöhen Sie den Wert von Query_cache_size.
Das obige ist der detaillierte Inhalt vonEine ausführliche Einführung zur Optimierung von MySQL unter Linux. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











MySQL und PhpMyAdmin sind leistungsstarke Datenbankverwaltungs -Tools. 1) MySQL wird verwendet, um Datenbanken und Tabellen zu erstellen und DML- und SQL -Abfragen auszuführen. 2) PHPMYADMIN bietet eine intuitive Schnittstelle für Datenbankverwaltung, Tabellenstrukturverwaltung, Datenoperationen und Benutzerberechtigungsverwaltung.

Docker ist wichtig unter Linux, da Linux seine native Plattform ist, die reichhaltige Tools und Community -Unterstützung bietet. 1. Installieren Sie Docker: Verwenden Sie Sudoapt-Getupdate und sudoapt-getinstalldocker-cedocker-ce-clicotainerd.io. 2. Erstellen und Verwalten von Containern: Verwenden Sie Dockerrun-Befehle wie Dockerrun-d-namemyninx-p80: 80Nginx. 3. Schreiben Sie Dockerfile: Optimieren Sie die Bildgröße und verwenden Sie mehrstufige Konstruktionen. 4. Optimierung und Debugging: Verwenden Sie Dockerlogs und Dockerex

In MySQL besteht die Funktion von Fremdschlüssel darin, die Beziehung zwischen Tabellen herzustellen und die Konsistenz und Integrität der Daten zu gewährleisten. Fremdeschlüssel behalten die Wirksamkeit von Daten durch Referenzintegritätsprüfungen und Kaskadierungsvorgänge bei. Achten Sie auf die Leistungsoptimierung und vermeiden Sie bei der Verwendung häufige Fehler.

Der Hauptunterschied zwischen MySQL und Mariadb ist Leistung, Funktionalität und Lizenz: 1. MySQL wird von Oracle entwickelt und Mariadb ist seine Gabel. 2. Mariadb kann in Umgebungen mit hoher Last besser abschneiden. 3.MariADB bietet mehr Speichermotoren und Funktionen. 4.Mysql nimmt eine doppelte Lizenz an, und Mariadb ist vollständig Open Source. Die vorhandene Infrastruktur, Leistungsanforderungen, funktionale Anforderungen und Lizenzkosten sollten bei der Auswahl berücksichtigt werden.

SQL ist eine Standardsprache für die Verwaltung von relationalen Datenbanken, während MySQL ein Datenbankverwaltungssystem ist, das SQL verwendet. SQL definiert Möglichkeiten, mit einer Datenbank zu interagieren, einschließlich CRUD -Operationen, während MySQL den SQL -Standard implementiert und zusätzliche Funktionen wie gespeicherte Prozeduren und Auslöser bereitstellt.

DMA in C bezieht sich auf DirectMemoryAccess, eine direkte Speicherzugriffstechnologie, mit der Hardware -Geräte ohne CPU -Intervention Daten direkt an den Speicher übertragen können. 1) Der DMA -Betrieb ist in hohem Maße von Hardware -Geräten und -Treibern abhängig, und die Implementierungsmethode variiert von System zu System. 2) Direkter Zugriff auf Speicher kann Sicherheitsrisiken mitbringen, und die Richtigkeit und Sicherheit des Codes muss gewährleistet werden. 3) DMA kann die Leistung verbessern, aber eine unsachgemäße Verwendung kann zu einer Verschlechterung der Systemleistung führen. Durch Praxis und Lernen können wir die Fähigkeiten der Verwendung von DMA beherrschen und seine Wirksamkeit in Szenarien wie Hochgeschwindigkeitsdatenübertragung und Echtzeitsignalverarbeitung maximieren.

MySQL und PhpMyAdmin können in den folgenden Schritten effektiv verwaltet werden: 1. Erstellen und Löschen von Datenbank: Klicken Sie einfach in phpMyadmin, um sie zu vervollständigen. 2. Verwalten Sie Tabellen: Sie können Tabellen erstellen, Strukturen ändern und Indizes hinzufügen. 3. Datenbetrieb: Unterstützt das Einsetzen, Aktualisieren, Löschen von Daten und Ausführung von SQL -Abfragen. 4. Daten importieren und exportieren: Unterstützt SQL, CSV, XML und andere Formate. 5. Optimierung und Überwachung: Verwenden Sie den Befehl optimizetable, um Tabellen zu optimieren und Abfrageanalysatoren und Überwachungstools zu verwenden, um Leistungsprobleme zu lösen.

MacosandlinuxbothOFferuniqueTh-Länge: macoSprovidesauser-freundlichemxperiencewithExcellentHardwareIntetegration, whilelinuxcelsinflexibilitätscommunitysupport.macos, IncrentByApple, is nunsleekinterfaceandecosysteminteInteminteminte-System, Whirininux, Areo
