Heim  >  Artikel  >  Betrieb und Instandhaltung  >  Analysieren und lösen Sie das Problem des verstümmelten MySQL-Codes in Docker

Analysieren und lösen Sie das Problem des verstümmelten MySQL-Codes in Docker

PHPz
PHPzOriginal
2023-04-25 09:19:201545Durchsuche

Docker ist eine beliebte Containerisierungsplattform, die die Anwendungsbereitstellung und -verwaltung einfacher und effizienter macht. Die MySQL-Datenbank ist ein integraler Bestandteil vieler Anwendungen. Bei der Verwendung von MySQL in Docker stößt man jedoch manchmal auf verstümmelte Zeichen, was nicht nur die Richtigkeit der Daten beeinträchtigt, sondern auch den Entwicklern unnötigen Ärger bereitet.

In diesem Artikel werden das verstümmelte Problem von MySQL in Docker und mögliche Lösungen vorgestellt.

1. Das Problem des verstümmelten Codes von MySQL in Docker

Verstümmelter Code bedeutet, dass die auf dem Client abgefragten Daten nicht den Erwartungen entsprechen und es einige nicht erkennbare Zeichen oder Verhaltensweisen gibt.

Dieses Problem tritt sehr häufig auf, wenn MySQL in Docker ausgeführt wird. Insbesondere wenn die Kodierungsmethode der MySQL-Datenbank auf UTF-8 eingestellt ist, können die folgenden Situationen auftreten:

1 Beim Einfügen von Daten werden die normalen chinesischen oder anderen Sprachzeichen der Daten zu zufälligen Zeichen.

2. Wenn der Client Daten abfragt, enthalten die zurückgegebenen Daten eine große Anzahl verstümmelter Zeichen.

Eigentlich werden diese Probleme nicht durch Docker oder MySQL selbst verursacht, sondern durch einige falsche Einstellungen und Konfigurationen.

2. Lösung für MySQL in Docker

1. Überprüfen Sie den Zeichensatz der Datenquelle. Die Hauptursache für verstümmelte Zeichen ist, dass der Zeichensatz der Datenbank nicht mit dem Zeichensatz der Datenquelle übereinstimmt. Wir müssen bestätigen, ob der Zeichensatz der Datenquelle UTF-8 ist, um die Korrektheit der Datenübertragung zwischen verschiedenen Systemen sicherzustellen.

Überprüfen Sie den MySQL-Standardzeichensatz in MySQL mit dem folgenden Befehl:

show variables like 'character%';

Character_set_client, Character_set_connection und Character_set_results in den angezeigten Ergebnissen sollten alle utf8mb4 sein. Andernfalls kann es zu verstümmelten Zeichen kommen.

Um MySQL in Docker auszuführen, müssen Sie der Dockerfile- oder Docker-Compose-Konfigurationsdatei die folgenden Parameter hinzufügen:

...
environment:
  MYSQL_ROOT_PASSWORD: root
  MYSQL_DATABASE: test
  MYSQL_USER: test
  MYSQL_PASSWORD: test
  MYSQL_CHARSET: utf8mb4
  MYSQL_COLLATION: utf8mb4_unicode_ci
...

Unter diesen sind MYSQL_CHARSET und MYSQL_COLLATION der Zeichensatz bzw. die Sortiermethode.

2. Ändern Sie die MySQL-Konfigurationsdatei

Wenn Sie MySQL in Docker ausführen, können Sie auch die MySQL-Konfigurationsdatei ändern, um den richtigen Zeichensatz und die richtige Sortiermethode zu erreichen.

Geben Sie die MySQL-Konfigurationsdatei my.cnf ein und fügen Sie unten die folgende Konfiguration hinzu:

[mysql]
default-character-set=utf8mb4

[mysqld]
collation-server = utf8mb4_unicode_ci
init-connect='SET NAMES utf8mb4'
character-set-server = utf8mb4
skip-character-set-client-handshake

Um MySQL in Docker auszuführen, müssen Sie zuerst my.cnf in den Container kopieren:

...
volumes:
  - ./my.cnf:/etc/mysql/conf.d/my.cnf
...

3. Überprüfen Sie den MySQL-Client-Charakter set

Wenn Sie MySQL in Docker ausführen, müssen Sie sicherstellen, dass der Zeichensatz des Clients (z. B. des Betriebssystems und der MySQL-Client-Tools usw.) ebenfalls UTF-8 ist.

Unter Linux können Sie den Zeichensatz des aktuellen Systems mit dem folgenden Befehl anzeigen:

$ echo $LANG

Wenn LANG andere Zeichensätze zurückgibt, müssen Sie die LANG-Umgebungsvariable zu Ihrer Shell-Konfigurationsdatei hinzufügen:

$ echo "export LANG='en_US.utf8'" >> ~/.bashrc

In Windows-Systemen , Sie müssen sicherstellen, dass der Zeichensatz des Client-Tools (wie Navicat usw.) ebenfalls UTF-8 ist.

4. MySQL-Spaltenattribute festlegen

In MySQL wirken sich auch der Zeichensatz und die Sortierregeln in den Spaltenattributen auf die Richtigkeit der Abfrageergebnisse aus. Standardmäßig übernehmen die Spalteneigenschaften einer neuen MySQL-Tabelle die Standardeinstellungen des MySQL-Servers. Wenn der Zeichensatz und die Sortierung des MySQL-Servers nicht übereinstimmen, kann es zu verstümmelten Zeichen kommen.

Um dieses Problem zu lösen, können Sie die Spaltenattribute manuell auf Folgendes setzen:

CREATE TABLE test (
  name VARCHAR(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL DEFAULT '',
...
);

Beim Erstellen der Tabelle finden Sie oben einige Lösungen für das verstümmelte Problem von MySQL in Docker. Entwickler können entsprechend ihren eigenen Bedürfnissen und der tatsächlichen Situation eine Methode wählen, die zu ihnen passt. In einer Produktionsumgebung müssen die Anwendungsbereitstellung und -konfiguration sorgfältig getestet und überprüft werden, um die Systemstabilität und -zuverlässigkeit sicherzustellen.

Das obige ist der detaillierte Inhalt vonAnalysieren und lösen Sie das Problem des verstümmelten MySQL-Codes in Docker. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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