Wie kann ich von einer Go-Anwendung in Docker aus eine Verbindung zu einem MySQL-Server herstellen, wenn „Verbindung abgelehnt' auftritt?

Linda Hamilton
Freigeben: 2024-10-30 05:33:28
Original
482 Leute haben es durchsucht

How to Connect to a MySQL Server from a Go Application in Docker When Encountering

Fehler: Verbindung abgelehnt, wenn von Go in Docker aus eine Verbindung zum MySQL-Server hergestellt wird

Beim Versuch, von einer Go-Anwendung, die in Docker ausgeführt wird, eine Verbindung zu einem MySQL-Server herzustellen, kann es zu Problemen kommen der folgende Fehler:

dial tcp 127.0.0.1:3306: connect: connection refused
Nach dem Login kopieren

Ursache:

Standardmäßig werden Docker-Container in isolierten Netzwerkräumen ausgeführt, sodass es für darin ausgeführte Anwendungen unmöglich ist, direkt auf den Host zuzugreifen Der lokale Host der Maschine.

Lösung:

Um dieses Problem zu beheben, verwenden Sie den speziellen Hostnamen docker.for.mac.localhost anstelle von localhost. Diese Adresse ermöglicht die Kommunikation mit den Diensten des Host-Computers durch Verwendung des Docker-Netzwerks:

  1. Aktualisieren Sie die Verbindungszeichenfolge im Go-Code:
<code class="go">db, err = sql.Open("mysql", dbUser+":"+dbPassword+"@tcp(docker.for.mac.localhost:3306)/"+dbName)</code>
Nach dem Login kopieren
  1. Bei Verwendung Docker Compose, fügen Sie die folgende Zeile zur Datei docker-compose.yml unter der Dienstdefinition für den Datenbankcontainer hinzu:
<code class="yml">ports:
  - "3306:3306"</code>
Nach dem Login kopieren

Dadurch wird der Port 3306 des Hostcomputers zugeordnet an den Port 3306 des Containers, sodass die Go-Anwendung eine Verbindung über den richtigen Port herstellen kann.

Das obige ist der detaillierte Inhalt vonWie kann ich von einer Go-Anwendung in Docker aus eine Verbindung zu einem MySQL-Server herstellen, wenn „Verbindung abgelehnt' auftritt?. 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
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!