في docker-compose build
Dockerfile تم اقتطاعه بمقدار الرموز السيريلية الموجودة فيه.
على سبيل المثال ، إذا حصلت على 7 رموز سيريلية في Dockerfile ، فإن الرموز السبعة الأخيرة لنهاية الملف تصبح "مقطوعة".
ناتج docker-compose version
docker-compose version 1.25.0, build unknown
docker-py version: 4.1.0
CPython version: 3.8.1
OpenSSL version: OpenSSL 1.1.1d 10 Sep 2019
ناتج docker version
Client:
Version: 19.03.5-ce
API version: 1.40
Go version: go1.13.4
Git commit: 633a0ea838
Built: Fri Nov 15 03:19:09 2019
OS/Arch: linux/amd64
Experimental: false
Server:
Engine:
Version: 19.03.5-ce
API version: 1.40 (minimum version 1.12)
Go version: go1.13.4
Git commit: 633a0ea838
Built: Fri Nov 15 03:17:51 2019
OS/Arch: linux/amd64
Experimental: false
containerd:
Version: v1.3.2.m
GitCommit: d50db0a42053864a270f648048f9a8b4f24eced3.m
runc:
Version: 1.0.0-rc9
GitCommit: d736ef14f0288d6993a1845745d6756cfc9ddd5a
docker-init:
Version: 0.18.0
GitCommit: fec3683
ناتج docker-compose config
see in the "steps to reproduce"
إنشاء دليل context
(فارغ) ، docker-compose.yml
و Dockerfile
version: '3.7'
services:
test-pass:
build:
context: .
dockerfile: Dockerfile
test-fail:
build:
context: context
# path relative to the context
dockerfile: ../Dockerfile
FROM alpine
# шшш и ффф
RUN touch test
تشغيل docker-compose build test-fail
docker-compose build test-fail
Building test-fail
Step 1/2 : FROM alpine
---> cdf98d1859c1
Step 2/2 : RUN touc
---> Running in fc83cc1f2b69
/bin/sh: touc: not found
ERROR: Service 'test-fail' failed to build: The command '/bin/sh -c touc' returned a non-zero code: 127
اختفت السلسلة h test\n
(7 رموز).
لا تظهر هذه المشكلة إذا كان Dockerfile موجودًا في مجلد السياق (انظر إلى خدمة اجتياز الاختبار).
لا تظهر هذه المشكلة باستخدام docker build
.
النتيجة المتوقعة هي صورة تم إنشاؤها بنجاح ، مثل استخدام docker build
:
docker build -f Dockerfile context
Sending build context to Docker daemon 1.583kB
Step 1/2 : FROM alpine
---> cdf98d1859c1
Step 2/2 : RUN touch test
---> Using cache
---> bb6362bff392
Successfully built bb6362bff392
N/A
نشكرك على الإبلاغ عن هذه المشكلة مع عينة استنساخ واضحة والتحقيق الأولي في ظروف التعطل. سأحقق في هذه المسألة الأسبوع المقبل
كحل بديل ، يمكنك تمكين منشئ CLI الأصلي من خلال تعيين COMPOSE_DOCKER_CLI_BUILD=true
(أتوقع أن تصبح هذه القيمة الافتراضية في إصدار مستقبلي)
سبب المشكلة (afaict) هو https://github.com/docker/docker-py/blob/master/docker/utils/build.py#L107 -L109
يتم حساب حجم tar كـ len(contents)
== عدد الأحرف ، بينما يتم تعيين إدخال tar الفعلي بواسطة contents.encode('utf-8')
، والذي سيتم بعد ذلك اقتطاعه حيث سيتم ترميز بعض الأحرف على N> 1 بايت.