


Wie kann ich die CMD- und ENTRYPOINT-Skripte gleichzeitig ausführen, wenn sie sich in unterschiedlichen Images befinden?
Bei der Orchestrierung von Containern stoßen wir häufig auf Situationen, in denen wir mehrere Skripte gleichzeitig ausführen müssen. Insbesondere wenn sich die CMD- und ENTRYPOINT-Skripte in unterschiedlichen Images befinden, wird die gleichzeitige Ausführung zu einem Problem, das gelöst werden muss. In diesem Fall können wir den Zweck erreichen, beide Skripte gleichzeitig auszuführen, indem wir einen mehrstufigen Build verwenden. Zuerst müssen wir ein Skript in ein Image schreiben, das sowohl das CMD- als auch das ENTRYPOINT-Skript ausführt. Anschließend können wir die mehrstufige Build-Funktion der Dockerfile verwenden, um dieses Skript in das endgültige Image zu kopieren und es beim Start des Containers auszuführen. Auf diese Weise können wir die Notwendigkeit erkennen, CMD- und ENTRYPOINT-Skripte gleichzeitig auszuführen und so die Flexibilität und Skalierbarkeit des Containers zu verbessern.
Frageninhalt
Ich verwende mehrstufige Docker-Builds und versuche, meiner Docker-Go-Anwendung Live-Reload-Funktionalität hinzuzufügen. Ich habe im zweiten Bild einen entrypoint.sh, der seine eigene Konfiguration hat.
Das Problem besteht nun darin, dass der Befehl cmd ["air", "-c", ".air.toml"]
被 entrypoint ["/entrypoint.sh"]
脚本覆盖第二张图片,所以只有 entrypoint
启动了,cmd
im ersten Bild nicht ausgeführt wird.
Ich kann sie nicht zu einem einzigen Befehl wie diesem kombinieren
entrypoint ["/entrypoint.sh", "air", "-c", ".air.toml"]
Weil im zweiten Bild die Golang-Sprache und die entsprechenden Bibliotheken nicht installiert sind.
Ist es irgendwie möglich, cmd
和 entrypoint
parallel zu laufen? Danke.
Docker-Datei
from golang:1.17.2 copy . /go/src/sample workdir /go/src/sample run go install github.com/go-delve/delve/cmd/dlv@latest run go install github.com/cosmtrek/air@latest cmd ["air", "-c", ".air.toml"] from eclipse-temurin:17-focal copy entrypoint.sh /entrypoint.sh run chmod +x /entrypoint.sh entrypoint ["/entrypoint.sh"]
docker-compose.yml
version: '3' services: go: build: context: ./backend dockerfile: Dockerfile volumes: - ./backend:/go/src/backend working_dir: /go/src/backend ports: - 8080:8080
Workaround
Lesen Sie die an den Einstiegspunkt (d. h. cmd) übergebenen Parameter.
Nachstehend finden Sie beispielsweise Ihr Einstiegspunktskript. Sie können auf Parameter zugreifen und etwas mit ihnen machen, sie also ausführen.
#!/bin/bash # dome something in your entrypoint # execute the original command # substituting the current process id # so that command is run with pid 1 exec "$@"
Stellen Sie in Ihrem Docker-Image sicher, dass Sie über den erforderlichen Befehl verfügen, nämlich
entrypoint ["/entryppoint.sh"] cmd ["echo", "command"]
Abgesehen von diesem technischen Aspekt scheinen Sie anzudeuten, dass Sie cmd ausführen möchten, das davon abhängt, dass go verfügbar ist, ohne dass go verfügbar ist. kommt nicht in Frage. Sie müssen sicherstellen, dass das, was Sie ausführen möchten, und seine Abhängigkeiten verfügbar sind.
Möglicherweise können Sie die Luftbinärdatei aus der ersten Stufe kopieren. Etwas wie das.
COPY --from=0 /go/bin/air /usr/local/bin/air
Vielleicht möchten Sie cgo_enabled=0
来编译 air
verwenden.
Ich gehe jedoch davon aus, dass Sie den im Image vorhandenen Go-Compiler benötigen, damit das Hot-Reload ordnungsgemäß funktioniert, da Ihre Anwendung neu kompiliert werden muss, wenn sich der Code ändert. Vielleicht sollten Sie hier also nicht einmal mehrphasig verwenden.
Das sagen wir mal. Das Hot-Reloading in Containern scheint ein bisschen wie ein Anti-Pattern zu sein. Container sind oft eine Möglichkeit, Artefakte zu verteilen.
Das obige ist der detaillierte Inhalt vonWie kann ich die CMD- und ENTRYPOINT-Skripte gleichzeitig ausführen, wenn sie sich in unterschiedlichen Images befinden?. 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.

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

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. � ...

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 werden die Verwaltungs -Go -Modulabhängigkeiten über Go.mod erörtert, die Spezifikationen, Aktualisierungen und Konfliktlösung abdecken. Es betont Best Practices wie semantische Versioning und reguläre Updates.

In diesem Artikel werden eine Vielzahl von Methoden und Tools eingeführt, um PostgreSQL -Datenbanken im Debian -System zu überwachen, um die Datenbankleistung vollständig zu erfassen. 1. verwenden Sie PostgreSQL, um die Überwachungsansicht zu erstellen. PostgreSQL selbst bietet mehrere Ansichten für die Überwachung von Datenbankaktivitäten: PG_STAT_ACTIVITY: Zeigt Datenbankaktivitäten in Echtzeit an, einschließlich Verbindungen, Abfragen, Transaktionen und anderen Informationen. PG_STAT_REPLIKATION: Monitore Replikationsstatus, insbesondere für Stream -Replikationscluster. PG_STAT_DATABASE: Bietet Datenbankstatistiken wie Datenbankgröße, Transaktionsausschüsse/Rollback -Zeiten und andere Schlüsselindikatoren. 2. Verwenden Sie das Log -Analyse -Tool PGBADG
