При наличии двоичного файла, скомпилированного с помощью Go с использованием GOOS=linux
и GOARCH=amd64
, развернутого в контейнере docker
на основе alpine:3.3
, двоичный файл не будет работать, если хостом механизма докера является Ubuntu (15.10):
sh: /bin/artisan: not found
Этот же двоичный файл (скомпилированный для той же ОС и той же архитектуры) будет отлично работать, если узел механизма докеров — busybox
(который является базовым для alpine
), развернутый в виртуальной машине VirtualBox в Mac OS X.
Этот же двоичный файл также будет отлично работать, если контейнер основан на одном из образов Ubuntu.
Есть идеи, чего не хватает этому двоичному файлу?
Это то, что я сделал для воспроизведения (успешный запуск в VirtualBox/busybox на OS X не показан):
Сборка (сборка явно с флагами, даже если арка совпадает):
➜ artisan git:(master) ✗ GOOS=linux GOARCH=amd64 go build
Проверьте, может ли он работать на хосте:
➜ artisan git:(master) ✗ ./artisan
10:14:04.925 [ERROR] artisan: need a command, one of server, provision or build
Скопируйте в папку докера, соберите, запустите:
➜ artisan git:(master) ✗ cp artisan docker/build/bin/
➜ artisan git:(master) ✗ cd docker
➜ docker git:(master) ✗ cat Dockerfile
FROM docker:1.10
COPY build/ /
➜ docker git:(master) ✗ docker build -t artisan .
Sending build context to Docker daemon 10.15 MB
Step 1 : FROM docker:1.10
...
➜ docker git:(master) ✗ docker run -it artisan sh
/ # /bin/artisan
sh: /bin/artisan: not found
Теперь меняем базу изображения на phusion/baseimage
:
➜ docker git:(master) ✗ cat Dockerfile
#FROM docker:1.10
FROM phusion/baseimage
COPY build/ /
➜ docker git:(master) ✗ docker build -t artisan .
Sending build context to Docker daemon 10.15 MB
Step 1 : FROM phusion/baseimage
...
➜ docker git:(master) ✗ docker run -it artisan sh
# /bin/artisan
08:16:39.424 [ERROR] artisan: need a command, one of server, provision or build
go build -tags netgo -a -v std
с CGO_ENABLED=1? Я думаю, что это могут быть проблемы с сетевым пакетом, вызывающим динамическое связывание. - person Martin Gallagher   schedule 29.03.2016CGO_ENABLED=1 go build -tags netgo -a -v
. Если я правильно понимаю, в отличие от CGO_ENABLED=0, это также сохранит функциональность TLS в сетевом пакете, которая в противном случае была бы потеряна, верно? Можно ли как-то посмотреть, что скомпоновано в бинарник статически, а что осталось для динамического линкования? - person Oleg Sklyar   schedule 29.03.2016ldd output.bin
для каждого варианта сборки, чтобы увидеть, действительно ли они статически скомпилирован или если происходит какое-либо динамическое связывание. - person Martin Gallagher   schedule 29.03.2016