


Warum gibt mein Docker-Scratch-Image beim Ausführen einer benutzerdefinierten Binärdatei „keine solche Datei oder kein solches Verzeichnis' zurück?
„Keine solche Datei oder kein solches Verzeichnis“ mit Docker Scratch Image
Beim Versuch, einen Docker-Container mit einem Scratch-Image und einer benutzerdefinierten Binärdatei zu erstellen , können Benutzer auf den folgenden Fehler stoßen: „standard_init_linux.go:207: exec-Benutzerprozess verursacht „keine solche Datei oder kein solches Verzeichnis““. Dieser Fehler weist darauf hin, dass die Binärdatei nicht im Container gefunden oder ausgeführt werden kann.
Das Problem ergibt sich aus der Verwendung der „FROM Scratch“-Anweisung in der Docker-Datei. Ein Scratch-Image ist ein minimales Image, das nur wesentliche Werkzeuge enthält, was zu einem leichten und effizienten Container führt. Dies bedeutet jedoch auch, dass dem Container bestimmte Bibliotheken und Abhängigkeiten fehlen, die möglicherweise für die Ausführung der Binärdatei erforderlich sind.
Um dieses Problem zu beheben, können Benutzer einen von zwei Ansätzen wählen:
-
CGO deaktivieren: CGO ermöglicht Go-Programmen die Schnittstelle mit C-Code, kann jedoch zu einer dynamischen Verknüpfung der Binärdatei mit Systembibliotheken führen. Durch Deaktivieren von CGO können Benutzer sicherstellen, dass die Binärdatei statisch verknüpft ist, wodurch die Abhängigkeit von bestimmten Bibliotheken beseitigt wird.
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build \ -ldflags="-w -s" -o $PROJ_BIN_PATH ./cmd/...
Nach dem Login kopieren -
Bibliotheken kopieren: Wenn CGO unerlässlich ist für In der Binärdatei können Benutzer die erforderlichen Bibliotheken mithilfe der Anweisung „COPY --from“ manuell in das Scratch-Image kopieren. Dadurch wird sichergestellt, dass die Binärdatei zur Laufzeit Zugriff auf die erforderlichen Abhängigkeiten hat.
COPY --from=build-image /usr/lib/libc.so.6 /usr/lib/libc.so.6
Nach dem Login kopieren
Der gewählte spezifische Ansatz hängt von den Anforderungen der Binärdatei und dem gewünschten Grad der Containerisolation ab. Durch die Behebung des Problems mit dynamischer Verknüpfung oder Abhängigkeitsverfügbarkeit können Benutzer erfolgreich Container basierend auf Scratch-Images mit benutzerdefinierten Binärdateien erstellen und ausführen.
Das obige ist der detaillierte Inhalt vonWarum gibt mein Docker-Scratch-Image beim Ausführen einer benutzerdefinierten Binärdatei „keine solche Datei oder kein solches Verzeichnis' zurück?. 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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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.

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

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

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Bei der Verwendung von Goland für GO -Sprachentwicklung begegnen viele Entwickler benutzerdefinierte Struktur -Tags ...

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

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

In diesem Artikel wird vorgestellt, wie MongoDB im Debian -System konfiguriert wird, um eine automatische Expansion zu erzielen. Die Hauptschritte umfassen das Einrichten der MongoDB -Replikat -Set und die Überwachung des Speicherplatzes. 1. MongoDB Installation Erstens stellen Sie sicher, dass MongoDB im Debian -System installiert ist. Installieren Sie den folgenden Befehl: sudoaptupdatesudoaptinstall-emongoDB-org 2. Konfigurieren von MongoDB Replika-Set MongoDB Replikate sorgt für eine hohe Verfügbarkeit und Datenreduktion, was die Grundlage für die Erreichung der automatischen Kapazitätserweiterung darstellt. Start MongoDB Service: SudosystemctlstartMongodsudosysys
