Heim > Datenbank > MySQL-Tutorial > Warum schlägt meine MySQL-Verbindung mit Fehler 2006 („MySQL Server Has Gone Away') fehl und wie kann ich das Problem beheben?

Warum schlägt meine MySQL-Verbindung mit Fehler 2006 („MySQL Server Has Gone Away') fehl und wie kann ich das Problem beheben?

Susan Sarandon
Freigeben: 2024-12-14 04:37:14
Original
164 Leute haben es durchsucht

Why Does My MySQL Connection Fail with Error 2006 (

Verstehen und Beheben des MySQL-Fehlers 2006: „MySQL Server Has Gone Away“

Beim Ausführen eines Servers, der Dateien und Berichte verarbeitet Beim Senden der Ergebnisse an einen Remote-MySQL-Server kann es vorkommen, dass Benutzer auf die Fehlermeldung „2006, MySQL-Server ist verschwunden“ stoßen. Dies weist darauf hin, dass die Verbindung zum Server unerwartet und vorzeitig beendet wurde.

Entgegen allgemeiner Annahmen hängt das Problem normalerweise nicht mit der Einstellung „wait_timeout“ zusammen. Stattdessen liegt die Lösung in einem anderen MySQL-Parameter: max_allowed_packet.

max_allowed_packet: Der Schlüssel zur Auflösung

Die Standardeinstellung für max_allowed_packet, die oft so niedrig ist wie 4 MB (4194304 Bytes) können für die Verarbeitung großer Datenpakete unzureichend sein. Wenn die Datennutzlast diesen Grenzwert überschreitet, trennt der Server die Verbindung, was den Fehler „MySQL-Server ist verschwunden“ verursacht.

Um dieses Problem zu beheben, erhöhen Sie den Wert „max_allowed_packet“ im Abschnitt [mysqld] der Datei /etc/my. cnf-Konfigurationsdatei auf Ihrem Server. Normalerweise reicht eine Einstellung von 8 oder 16 MB aus.

Zum Beispiel:

[mysqld]
...
max_allowed_packet=16M
...
Nach dem Login kopieren

Alternativ können Sie den folgenden Befehl verwenden, um den Parameter dynamisch festzulegen (Änderungen gehen beim Neustart verloren):

SET GLOBAL max_allowed_packet=104857600;
Nach dem Login kopieren

Zusätzlich Hinweise:

  • Stellen Sie sicher, dass die Datei my.cnf auf Windows-Systemen mit ANSI-Kodierung (nicht UTF-8) gespeichert wird.
  • Unter Windows die Datei my.ini Möglicherweise muss stattdessen die Datei bearbeitet werden.
  • Wenn der Fehler nach der Anpassung von max_allowed_packet weiterhin besteht, sollten Sie erwägen, andere MySQL-Parameter wie read_timeout und zu überprüfen wait_timeout.

Das obige ist der detaillierte Inhalt vonWarum schlägt meine MySQL-Verbindung mit Fehler 2006 („MySQL Server Has Gone Away') fehl und wie kann ich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage