


Tidak dapat menulis laluan pelekap yang sah untuk bekas docker dalam go
Editor PHP Zimo mendapati bahawa sesetengah pembangun menghadapi masalah semasa menulis bekas docker menggunakan bahasa Go, iaitu, mereka tidak dapat menulis laluan pelekap yang sah untuk bekas itu. Isu ini boleh menyebabkan ralat atau kegagalan semasa operasi membaca dan menulis fail dalam bekas. Bagi pemaju, ini sudah pasti masalah yang mengecewakan. Seterusnya, kami akan meneroka punca isu ini dan kemungkinan penyelesaian untuk membantu pembangun menyelesaikan cabaran ini.
Kandungan soalan
Saya cuba memulakan bekas ujian untuk menguji pangkalan data saya. Saya menggunakan bekas ujian. Berikut ialah coretan cara saya menyediakan bekas:
func createContainer(ctx context.Context) (testcontainers.Container, *pgxpool.Pool, string, error) { var env = map[string]string{ "POSTGRES_PASSWORD": DbPass, "POSTGRES_USER": DbUser, "POSTGRES_DB": DbName, } var port = "5432/tcp" // /Users/<path>:/<container path> path := `/c/Users/pizhlo21/Desktop/Folder/golang/TgBotReminder/internal/db/postgresql/migration:/usr/app` req := testcontainers.GenericContainerRequest{ ContainerRequest: testcontainers.ContainerRequest{ Image: "postgres:latest", ExposedPorts: []string{port}, Env: env, WaitingFor: wait.ForLog("database system is ready to accept connections"), VolumeMounts: map[string]string{"/docker-entrypoint-initdb.d": path}, SkipReaper: true, }, Started: true, } container, err := testcontainers.GenericContainer(ctx, req) if err != nil { return container, nil, "", fmt.Errorf("unable to start container: %v", err) } ...
Tetapi saya mendapat ralat daripada docker: failed to setup testunable to start container: failed to create container: error response from daemon: create /docker-entrypoint-initdb.d: "/docker-entrypoint-initdb.d" 包括本地卷名称的无效字符,仅允许“[a-za-z0-9][a-za-z0-9_.-]”。如果您打算传递主机目录,请使用绝对路径
.
Kadangkala ralat ini kelihatan seperti ini: 无法设置测试无法启动容器:无法创建容器:守护程序的错误响应:“卷”类型的安装配置无效:安装路径无效:'“c” /desktop/folder/golang/tgbotreminder/internal/db/postgresql/migration/000001_init_schema.up"' 挂载路径必须是绝对
Saya mencuba pelbagai laluan seperti:
//c/用户/...
c/用户/...
/%cd%/桌面/...
$home/桌面/文件夹/...
Tetapi tiada apa yang membantu saya.
Bagaimana cara melakukannya dengan betul?
Penyelesaian
tl;dr
Pengganti
volumemounts: map[string]string{"/docker-entrypoint-initdb.d": path},
dan
bindmounts: map[string]string{"/docker-entrypoint-initdb.d": path},
Soalan 1
"/docker-entrypoint-initdb.d" mengandungi aksara tidak sah untuk nama volum tempatan, hanya "[a-za-z0-9][a-za-z0-9_.-]" dibenarkan. p>
Penting untuk diketahui Terdapat tiga jenis pelekap :
-
Volume disimpan dalam sebahagian daripada sistem fail hos yang diuruskan oleh docker (
/var/lib/docker/volumes/
pada linux). Proses bukan dok tidak seharusnya mengubah suai bahagian sistem fail ini. Jilid ialah cara terbaik untuk menyimpan data dalam docker. - Pemasangan bundle boleh disimpan di mana sahaja pada sistem hos. Mereka mungkin juga fail sistem atau direktori yang penting. Mereka boleh diubah suai pada bila-bila masa oleh proses bukan Docker pada hos docker atau bekas docker.
-
tmpfs
Lekapan disimpan hanya dalam memori sistem hos dan tidak pernah ditulis ke sistem fail sistem hos.
volumemounts
digunakan untuk menentukan lekapan volum. Daripada github.com/testcontainers/<a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="94e0f1e7e0f7fbfae0f5fdfaf1e6e7b9f3fbd4e2a4baa5"> Nilai entri dalam <code>volumemounts
menyimpan volumemounts
用于指定卷挂载。从 github.com/testcontainers/<a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="94e0f1e7e0f7fbfae0f5fdfaf1e6e7b9f3fbd4e2a4baa5a6baa4">[email protected]</a>
的值volumemounts
中的条目存储卷名称,该条目仅允许 [a-za-z0-9][a-za-z0-9_.-]
,这就是您看到错误消息的原因。顺便说一句,要看到上面的错误消息,您的代码必须是这样的(请注意 /docker-entrypoint-initdb.d
nama volum
[a-za-z0-9][a-za-z0-9_.- ]
, itulah sebabnya anda melihat mesej ralat. BTW, untuk melihat mesej ralat di atas, kod anda mesti kelihatan seperti ini (perhatikan bahawa /docker-entrypoint-initdb.d
ialah nilai dan bukan kunci):
volumemounts: map[string]string{path: "/docker-entrypoint-initdb.d"},
Soalan 2Konfigurasi pelekap tidak sah untuk jenis "volume": Laluan pelekap tidak sah: laluan pelekap "c/desktop/folder/golang/tgbotreminder/internal/db/postgresql/migration/000001_init_schema.up" mestilah mutlak
Untuk melihat mesej ralat ini, kod anda mesti kelihatan seperti ini:
volumemounts: map[string]string{`"/c/desktop/folder/golang/tgbotreminder/internal/db/postgresql/migration/000001_init_schema.up"`: "/docker-entrypoint-initdb.d"},
github.com/testcontainers/ <a href="/cdn-cgi/l/email-protection" class="__cf_email__" __cf_email__ data-cfemail="4443021373027272b2a302a30252a2a2a2a2113632132b21132b21132b21132b2b2a2b2a2b2a2b2b2b2binging a>
, volumemounts
中条目的键存储挂载路径。由于挂载路径包含双引号("> sebagai </a>
), jadi ia tidak sah. Daemon docker terlebih dahulu mengesahkan laluan mount. Itulah sebabnya anda melihat mesej ralat.
github.com/testcontainers/testcontainers-go
Pertimbangkan untuk menaik taraf
Dalam versi v0.13.0containerrequest.bindmounts
和 containerrequest.volumemounts
替换为 containerrequest.mounts
, . Ini kerana "struktur data berasaskan peta agak mengelirukan. Perubahan ini mengelakkan kekeliruan dengan memperkenalkan jenis khusus untuk semua komponen untuk mendapatkan bantuan daripada IDE dan pengkompil". (Lihat pr#386
升级到 github.com/testcontainers/<a href="/cdn-cgi/l/email-protection" class="__cf_email__" data-cfemail="9aeeffe9eef9f5f4eefbf3f4ffe8e9b7fdf5daecaab4a8abb4aa">[电子邮件受保护]</a>
后,可以使用以下方式指定绑定安装:
Mounts: testcontainers.Mounts( testcontainers.BindMount(path, "/docker-entrypoint-initdb.d"), ),
Atas ialah kandungan terperinci Tidak dapat menulis laluan pelekap yang sah untuk bekas docker dalam go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Perbezaan utama antara Golang dan Python adalah model konvensional, sistem jenis, prestasi dan kelajuan pelaksanaan. 1. Golang menggunakan model CSP, yang sesuai untuk tugas serentak yang tinggi; Python bergantung pada multi-threading dan gil, yang sesuai untuk tugas I/O-intensif. 2. Golang adalah jenis statik, dan Python adalah jenis dinamik. 3. Golang mengumpulkan kelajuan pelaksanaan bahasa adalah cepat, dan pembangunan bahasa yang ditafsirkan Python adalah pantas.

Golang biasanya lebih perlahan daripada C, tetapi Golang mempunyai lebih banyak kelebihan dalam pengaturcaraan serentak dan kecekapan pembangunan: 1) Koleksi sampah Golang dan model konkurensi menjadikannya berfungsi dengan baik dalam senario konvensyen yang tinggi; 2) C memperoleh prestasi yang lebih tinggi melalui pengurusan memori manual dan pengoptimuman perkakasan, tetapi mempunyai kerumitan pembangunan yang lebih tinggi.

Golang digunakan secara meluas dalam pengkomputeran awan dan devOps, dan kelebihannya terletak pada kesederhanaan, kecekapan dan keupayaan pengaturcaraan serentak. 1) Dalam pengkomputeran awan, Golang dengan cekap mengendalikan permintaan serentak melalui mekanisme goroutine dan saluran. 2) Di DevOps, kompilasi cepat Golang dan ciri-ciri silang platform menjadikannya pilihan pertama untuk alat automasi.

Golang dan C masing -masing mempunyai kelebihan sendiri dalam kecekapan prestasi. 1) Golang meningkatkan kecekapan melalui pengumpulan goroutine dan sampah, tetapi boleh memperkenalkan masa jeda. 2) C menyedari prestasi tinggi melalui pengurusan memori manual dan pengoptimuman, tetapi pemaju perlu menangani kebocoran memori dan isu -isu lain. Apabila memilih, anda perlu mempertimbangkan keperluan projek dan timbunan teknologi pasukan.

Golang lebih sesuai untuk tugas -tugas kesesuaian yang tinggi, sementara Python mempunyai lebih banyak kelebihan dalam fleksibiliti. 1.Golang dengan cekap mengendalikan kesesuaian melalui goroutine dan saluran. 2. Pilihannya harus berdasarkan keperluan khusus.

Perbezaan prestasi antara Golang dan C terutamanya ditunjukkan dalam pengurusan ingatan, pengoptimuman kompilasi dan kecekapan runtime. 1) Mekanisme pengumpulan sampah Golang adalah mudah tetapi boleh menjejaskan prestasi, 2) Pengurusan memori manual C dan pengoptimuman pengkompil lebih cekap dalam pengkomputeran rekursif.

PilihgolangforhighperformanceandConcurrency, IdealForBackEndServicesandnetworkprogramming; SelectPythonForrapidDevelopment, datascience, danMachinelearningDuetoitSversativilityAndextiveLibraries.

Golang dan Python masing -masing mempunyai kelebihan mereka sendiri: Golang sesuai untuk prestasi tinggi dan pengaturcaraan serentak, sementara Python sesuai untuk sains data dan pembangunan web. Golang terkenal dengan model keserasiannya dan prestasi yang cekap, sementara Python terkenal dengan sintaks ringkas dan ekosistem perpustakaan yang kaya.


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

SecLists
SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.