Heim >Backend-Entwicklung >Golang >Wie integriere ich Golang-Migrate mit Docker Compose für Datenbankmigrationen?

Wie integriere ich Golang-Migrate mit Docker Compose für Datenbankmigrationen?

Barbara Streisand
Barbara StreisandOriginal
2024-12-06 04:05:22777Durchsuche

How to Integrate Golang-Migrate with Docker Compose for Database Migrations?

Docker-Compose-Integration für Golang-Migrate

Golang-Migrate erleichtert die Verwaltung der Datenbankmigration. Um alle Migrationen aus einem Verzeichnis durchzuführen, wird der folgende Befehl empfohlen:

docker run -v {{ migration dir }}:/migrations --network host migrate/migrate
-path=/migrations/ -database postgres://localhost:5432/database up 2

Dieser Befehl stimmt jedoch nicht mit der Syntax des aktualisierten Docker-Compose überein. In diesem Artikel wird erläutert, wie Sie diesen Befehl ändern, um ihn an die neuere Docker-Compose-Syntax anzupassen und eine Verbindung zu einer Datenbank in einem anderen Container herzustellen.

Lösung für die neue Docker-Compose-Syntax

Das folgende docker-compose.yml-Snippet erreicht die gewünschte Funktionalität:

    db:
        image: postgres
        networks:
            new:
                aliases:
                    - database
        environment:
            POSTGRES_DB: mydbname
            POSTGRES_USER: mydbuser
            POSTGRES_PASSWORD: mydbpwd
        ports:
            - "5432"
    migrate:
        image: migrate/migrate
        networks:
            - new
        volumes:
            - .:/migrations
        command: ["-path", "/migrations", "-database",  "postgres://mydbuser:mydbpwd@database:5432/mydbname?sslmode=disable", "up", "3"]
        links: 
            - db
networks:
      new:

Anstelle der Verwendung von Mit der Option --network host wird ein benutzerdefiniertes Netzwerk mit dem Namen new definiert. Dienste innerhalb dieses Netzwerks können über definierte Aliase aufeinander zugreifen (z. B. Zugriff auf den Datenbankdienst über den Datenbank-Alias). Dadurch können Sie den Alias ​​als Ersatz für localhost in Verbindungszeichenfolgen verwenden.

Verbindung zu einer externen Datenbank

Diese Verbindungszeichenfolge wird verwendet, um eine Verbindung zu einer herzustellen Datenbank, die in einem anderen Container ausgeführt wird:

"postgres://mydbuser:mydbpwd@database:5432/mydbname?sslmode=disable"

In diesem Beispiel stellt der Datenbankalias den externen Datenbankcontainer dar.

Das obige ist der detaillierte Inhalt vonWie integriere ich Golang-Migrate mit Docker Compose für Datenbankmigrationen?. 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