


Bagaimanakah saya boleh menjalankan skrip CMD dan ENTRYPOINT secara serentak jika ia berada dalam imej yang berbeza?
Semasa mengatur kontena, kita sering menghadapi situasi di mana kita perlu menjalankan berbilang skrip pada masa yang sama. Terutama apabila skrip CMD dan ENTRYPOINT berada dalam imej yang berbeza, cara menjalankannya secara serentak menjadi masalah yang perlu diselesaikan. Dalam kes ini, kita boleh mencapai tujuan menjalankan kedua-dua skrip secara serentak dengan menggunakan binaan berbilang peringkat. Pertama, kita perlu menulis skrip dalam imej yang akan menjalankan kedua-dua skrip CMD dan ENTRYPOINT. Kami kemudiannya boleh menggunakan ciri binaan berbilang peringkat Dockerfile untuk menyalin skrip ini ke dalam imej akhir dan melaksanakannya apabila bekas bermula. Dengan cara ini, kami dapat menyedari keperluan untuk menjalankan skrip CMD dan ENTRYPOINT pada masa yang sama, meningkatkan fleksibiliti dan kebolehskalaan bekas.
Kandungan soalan
Saya menggunakan binaan berbilang peringkat docker dan cuba menambahkan fungsi muat semula secara langsung pada aplikasi go dockerized saya. Saya mempunyai entrypoint.sh dalam gambar kedua, yang mempunyai konfigurasi tersendiri.
Sekarang, masalahnya ialah arahan cmd ["air", "-c", ".air.toml"]
被 entrypoint ["/entrypoint.sh"]
脚本覆盖第二张图片,所以只有 entrypoint
启动了,cmd
dalam imej pertama tidak berjalan.
Saya tidak boleh menggabungkannya menjadi arahan unik seperti ini
entrypoint ["/entrypoint.sh", "air", "-c", ".air.toml"]
Kerana imej kedua tidak mempunyai bahasa golang dan perpustakaan yang sepadan dipasang.
Adakah mungkin untuk berlari cmd
和 entrypoint
secara selari entah bagaimana? Terima kasih.
dockerfile
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
Penyelesaian
Baca parameter yang dihantar ke titik masuk (iaitu cmd).
Sebagai contoh, di bawah ialah skrip titik masuk anda. Anda boleh mengakses parameter dan melakukan sesuatu dengannya, iaitu melaksanakannya.
#!/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 "$@"
Dalam imej docker anda, pastikan anda mempunyai arahan yang diperlukan, iaitu
entrypoint ["/entryppoint.sh"] cmd ["echo", "command"]
Di luar aspek teknikal ini, anda nampaknya membayangkan bahawa anda ingin menjalankan cmd yang bergantung pada go tersedia, tanpa go tersedia. ia keluar dari soalan. Anda perlu memastikan bahawa perkara yang anda cuba laksanakan dan kebergantungannya tersedia.
Anda mungkin boleh menyalin binari udara dari peringkat pertama. Sesuatu seperti ini.
COPY --from=0 /go/bin/air /usr/local/bin/air
Anda mungkin ingin menggunakan cgo_enabled=0
来编译 air
.
Walau bagaimanapun, saya menganggap bahawa anda memerlukan pengkompil go hadir dalam imej untuk muat semula panas berfungsi dengan baik, kerana aplikasi anda perlu dikompilasi semula apabila kod berubah. Jadi mungkin anda tidak sepatutnya menggunakan berbilang fasa di sini.
Itu, katakan. Muat semula panas dalam bekas kelihatan seperti anti-corak. Bekas selalunya merupakan cara untuk mengedarkan artifak.
Atas ialah kandungan terperinci Bagaimanakah saya boleh menjalankan skrip CMD dan ENTRYPOINT secara serentak jika ia berada dalam imej yang berbeza?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Masalah Threading Giliran di GO Crawler Colly meneroka masalah menggunakan Perpustakaan Colly Crawler dalam bahasa Go, pemaju sering menghadapi masalah dengan benang dan permintaan beratur. � ...

Laluan Pembelajaran Backend: Perjalanan Eksplorasi dari Front-End ke Back-End sebagai pemula back-end yang berubah dari pembangunan front-end, anda sudah mempunyai asas Nodejs, ...

Artikel ini membincangkan menguruskan kebergantungan modul Go melalui Go.Mod, meliputi spesifikasi, kemas kini, dan resolusi konflik. Ia menekankan amalan terbaik seperti versi semantik dan kemas kini biasa.

Artikel ini memperkenalkan pelbagai kaedah dan alat untuk memantau pangkalan data PostgreSQL di bawah sistem Debian, membantu anda memahami pemantauan prestasi pangkalan data sepenuhnya. 1. Gunakan PostgreSQL untuk membina pemantauan PostgreSQL sendiri menyediakan pelbagai pandangan untuk pemantauan aktiviti pangkalan data: PG_STAT_ACTIVITY: Memaparkan aktiviti pangkalan data dalam masa nyata, termasuk sambungan, pertanyaan, urus niaga dan maklumat lain. PG_STAT_REPLITI: Memantau status replikasi, terutamanya sesuai untuk kluster replikasi aliran. PG_STAT_DATABASE: Menyediakan statistik pangkalan data, seperti saiz pangkalan data, masa komitmen/masa rollback transaksi dan petunjuk utama lain. 2. Gunakan alat analisis log pgbadg
