Wie verbinde ich mich mit Docker-Compose mit CockroachDB?
Der PHP-Editor Strawberry zeigt Ihnen, wie Sie mit Docker-Compose eine Verbindung zu CockroachDB herstellen. Docker-Compose ist ein Tool zum Definieren und Ausführen mehrerer Docker-Container, und CockroachDB ist ein verteiltes relationales Datenbankverwaltungssystem. Durch die Verwendung von Docker-Compose können wir CockroachDB-Container einfach erstellen, verwalten und mit anderen Containern verbinden. In diesem Artikel erklären wir detailliert, wie Sie Ihre Docker-Compose-Datei für die Verbindung mit CockroachDB konfigurieren und geben einige praktische Tipps und Überlegungen. Unabhängig davon, ob Sie Anfänger oder erfahrener Entwickler sind, bietet Ihnen dieser Artikel nützliche Anleitungen, die Ihnen den schnellen Einstieg in die Verwendung von Docker-Compose zum Herstellen einer Verbindung mit CockroachDB erleichtern.
Frageninhalt
Ich habe eine Docker-Compose-Datei, in der ich die Datenbank bereitstelle und die Anwendung lokal starte
services: node_1: container_name: node_1 image: cockroachdb/cockroach:latest command: start --insecure ports: - "26258:26258" - "8081:8081" networks: - network_cockroachdb node_2: container_name: node_2 image: cockroachdb/cockroach:latest hostname: node_2 ports: - "26257:26257" - "8080:8080" command: start --insecure --join=node_1 networks: - network_cockroachdb network_mode: 'host' app: build: . ports: - "12121:12121" environment: app_port: '12121' db_host: "node_2" db_port: 26257 db_user: root db_password: 123 db_database: mydb depends_on: - node_2 links: - node_2 networks: - network_cockroachdb networks: network_cockroachdb: driver: bridge
Zur Datei gehen:
func main() { port, _ := strconv.Atoi(os.Getenv("db_port")) dbConfig := storage.ConnectionConfig{ Host: os.Getenv("db_host"), Port: port, User: os.Getenv("db_user"), Password: os.Getenv("db_password"), DBName: os.Getenv("db_database"), SSLMode: "verify-full", } log.Println("url: ", dbConfig.String()) db, err := storage.NewCockroachDB(context.Background(), dbConfig) if err != nil { log.Fatal(err) } }
Eine Verbindung zur Datenbank wird hergestellt. Doch die Verbindung schlug fehl und der falsche Port wurde weitergeleitet: Statt 26257 war es 26258. Wie kann dieses Problem gelöst werden?
Lösung
Nicht verwenden
links
; diese Funktion ist seit vielen Jahren veraltet und wird nur aus Gründen der Abwärtskompatibilität beibehalten. Docker verwaltet DNS für Container, sodass Sie beim Herstellen einer Verbindung nur den Dienstnamen als Hostnamen verwenden müssen.Sie können mit
network_mode 结合使用:host
keine Portweiterleitung durchführen.Ihre Verwendung von
depends_on
ist praktisch ein No-Op; Ihre Anwendung wird höchstwahrscheinlich versuchen, eine Verbindung zur Datenbank herzustellen, bevor die Datenbank für die Verarbeitung der Verbindung bereit ist.Tatsächlich akzeptiert Ihr Datenbankcluster keine Verbindungen, bis Sie ihn ausführen
cockroach init
, sodass Sie definitiv auf dieses Problem stoßen.Ihre Compose-Datei kann nicht gestartet werden
node_1
mit der folgenden Fehlermeldung:* ERROR: ERROR: no --join flags provided to 'cockroach start' * HINT: Consider using 'cockroach init' or 'cockroach start-single-node' instead * ERROR: no --join flags provided to 'cockroach start' HINT: Consider using 'cockroach init' or 'cockroach start-single-node' instead Failed running "start"
Nach dem Login kopierenIhre
node_1
Portweiterleitung ist falsch; nichts im Container lauscht auf Port 8081. Vielleicht möchten Sie so etwas wie:ports: - 8081:8080
Nach dem Login kopieren
Schließlich haben Sie nicht angegeben, woher das storage
-Modul in Ihrem Beispielcode stammt, daher kann ich es nicht zum Testen verwenden. Ich habe dieses Testprogramm geschrieben, das eine Schleife enthält, die darauf wartet, dass die Datenbank die Verbindung akzeptiert:
package main import ( "context" "fmt" "log" "os" "time" pgx "github.com/jackc/pgx/v4" ) func main() { connectionString := os.Getenv("db_uri") if connectionString == "" { connectionString = fmt.Sprintf("postgresql://%s@%s:%s/%s?sslmode=disable", os.Getenv("db_user"), os.Getenv("db_host"), os.Getenv("db_port"), os.Getenv("db_database"), ) } var conn *pgx.Conn var err error for { conn, err = pgx.Connect(context.Background(), connectionString) if err == nil { break } log.Printf("connection failed (%v); will retry...", err) time.Sleep(1 * time.Second) } log.Printf("connected to database") var value int if err := conn.QueryRow(context.Background(), "select 1").Scan(&value); err != nil { panic(err) } fmt.Printf("All done.\n") }
Wenn wir alle oben genannten Probleme lösen und die Compose-Datei bereinigen, erhalten wir am Ende:
services: node_1: image: cockroachdb/cockroach:latest ports: - "8080:8080" command: - start - --insecure - --join=node_1,node_2 node_2: image: cockroachdb/cockroach:latest ports: - "8081:8080" command: - start - --insecure - --join=node_1,node_2 app: build: . environment: db_host: "node_2" db_port: 26257 db_user: root db_password: 123 db_database: mydb
Bitte beachten Sie, dass diese Konfiguration den Datenbank-Port absichtlich nicht auf dem Host veröffentlicht, da dieser nicht erforderlich ist, damit Anwendungen auf die Datenbank zugreifen können.
Wenn wir diese Konfiguration docker 编写
, sehen wir Folgendes vom Datenbankdienst:
* INFO: initial startup completed. * Node will now attempt to join a running cluster, or wait for `cockroach init`. * Client connections will be accepted after this completes successfully. * Check the log file(s) for progress.
Und Folgendes in der Musterbewerbung (wir erwarten):
2023/09/01 12:53:20 connection failed (failed to connect to `host=node_2 user=root database=mydb`: dial error (dial tcp 10.89.1.46:26257: connect: connection refused)); will retry...
Wir müssen die Datenbank initialisieren:
docker compose exec node_1 ./cockroach init --insecure --host=node_1
Danach sehen wir Folgendes vom Datenbankdienst:
CockroachDB node starting at 2023-09-01 12:54:38.494304014 +0000 UTC m=+77.639236046 (took 77.4s) [...]
Beispielanwendung kann Abfragen verbinden und ausführen:
2023/09/01 12:54:38 connected to database All done.
Die Web-Benutzeroberfläche für diese Knoten wird auf dem Host-Port verfügbar gemacht 8080
和 8081
.
Abschließend möchten Sie möglicherweise Volumes erstellen, um Ihre Datenbankdaten zu speichern. Siehe z. B. dieses DokumentMontagevolumina.
Das obige ist der detaillierte Inhalt vonWie verbinde ich mich mit Docker-Compose mit CockroachDB?. 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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

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



OpenSSL bietet als Open -Source -Bibliothek, die in der sicheren Kommunikation weit verbreitet sind, Verschlüsselungsalgorithmen, Tasten und Zertifikatverwaltungsfunktionen. In seiner historischen Version sind jedoch einige Sicherheitslücken bekannt, von denen einige äußerst schädlich sind. Dieser Artikel konzentriert sich auf gemeinsame Schwachstellen und Antwortmaßnahmen für OpenSSL in Debian -Systemen. DebianopensL Bekannte Schwachstellen: OpenSSL hat mehrere schwerwiegende Schwachstellen erlebt, wie z. Ein Angreifer kann diese Sicherheitsanfälligkeit für nicht autorisierte Lesen sensibler Informationen auf dem Server verwenden, einschließlich Verschlüsselungsschlüssel usw.

In dem Artikel wird erläutert, wie das PPROF -Tool zur Analyse der GO -Leistung verwendet wird, einschließlich der Aktivierung des Profils, des Sammelns von Daten und der Identifizierung gängiger Engpässe wie CPU- und Speicherprobleme.Character Count: 159

In dem Artikel werden Schreiben von Unit -Tests in GO erörtert, die Best Practices, Spottechniken und Tools für ein effizientes Testmanagement abdecken.

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

In dem Artikel wird der Befehl go fMT in Go -Programmierung erörtert, in dem Code formatiert werden, um offizielle Richtlinien für den Stil einzuhalten. Es zeigt die Bedeutung von GO FMT für die Aufrechterhaltung der Debatten mit Codekonsistenz, Lesbarkeit und Reduzierung von Stildebatten. Best Practices fo

Wie kann man im Beegoorm -Framework die mit dem Modell zugeordnete Datenbank angeben? In vielen BeEGO -Projekten müssen mehrere Datenbanken gleichzeitig betrieben werden. Bei Verwendung von BeEGO ...
