standard_init_linux.go: 190: пользовательский процесс exec вызвал Docker "нет такого файла или каталога" с веб-приложением go basic - PullRequest
0 голосов
/ 04 октября 2018

Основное веб-приложение создается в Go

package main

import(
   "fmt"
   "net/http"
   "os"
)

func hostHandler(w http.ResponseWriter, r *http.Request){
    name, err :=os.Hostname()

    if err != nil {
           panic(err)
        }

        fmt.Fprintf(w, "<h1>HOSTNAME: %s</h1><br>",name)
        fmt.Fprintf(w, "<h1>ENVIRONMENT VARS: </h1><br>")
        fmt.Fprintf(w, "<ul>")

        for _, evar := range os.Environ(){
            fmt.Fprintf(w, "<li>%s</li>",evar)
        }
        fmt.Fprintf(w, "</ul>")

}

func rootHandler(w http.ResponseWriter, r *http.Request){

    fmt.Fprintf(w, "<h1>Awesome site in Go!</h1><br>")
    fmt.Fprintf(w, "<a href='/host/'>Host info</a><br>")

}

func main() {

        http.HandleFunc("/", rootHandler)
        http.HandleFunc("/host/", hostHandler)
        http.ListenAndServe(":8080", nil)


}

Файл Docker для него

FROM scratch
WORKDIR /home/ubuntu/go
COPY webapp /
EXPOSE 8080
CMD ["/webapp"]

Образ успешно создается

ubuntu@ip-172-31-32-125:~/go/src/hello$ docker build -t "webapp" .
Sending build context to Docker daemon  6.152MB
Step 1/5 : FROM scratch
 --->
Step 2/5 : WORKDIR /home/ubuntu/go
 ---> Using cache
 ---> 8810a06c58c7
Step 3/5 : COPY webapp /
 ---> Using cache
 ---> d75222363d3a
Step 4/5 : EXPOSE 8080
 ---> Using cache
 ---> 45de0853de8e
Step 5/5 : CMD ["/webapp"]
 ---> Using cache
 ---> e9f9031f3632
Successfully built e9f9031f3632
Successfully tagged webapp:latest

Но когдая запускаю докер с его ошибкой показа.

ubuntu@ip-172-31-32-125:~/go/src/hello$ docker run webapp
standard_init_linux.go:190: exec user process caused "no such file or directory"

Пожалуйста, объясните, в чем проблема, я новичок в докере и вперед.

Информация, связанная с окружающей средой

ubuntu@ip-172-31-32-125:~/go/src/hello$ ls
Dockerfile  webapp
ubuntu@ip-172-31-32-125:~/go/src/hello$ echo $GOPATH
/home/ubuntu/go

Код был скомпилирован с помощью go build webapp.go команда

Ответы [ 4 ]

0 голосов
/ 08 февраля 2019

В моем случае CGO_ENABLED=0 был ключом к решению этой проблемы.

Cgo позволяет использовать встроенный код C в исходниках Go, см. Подробнее: https://golang.org/cmd/cgo/

Я считаю, что по умолчанию Cgo динамически связывает ваше приложение с libc , даже если вы не используете встроенный C.
И libc отсутствует, когда вы упаковываете ваше приложение в образ Docker FROM scratch

Вот мой рабочий Dockerfile :

FROM golang:1.9.2-alpine AS builder
WORKDIR /go/src/app
COPY . .
RUN CGO_ENABLED=0 go install


FROM scratch
WORKDIR /opt
COPY --from=builder /go/bin/app .
ENTRYPOINT ["/opt/app"]
0 голосов
/ 04 октября 2018

Файл не найден, это может означать, что файл отсутствует, в сценарии отсутствует интерпретатор или в исполняемом файле отсутствует библиотека.В этом случае сетевой импорт по умолчанию использует libc в виде динамически связанного двоичного файла.Вы должны увидеть это с ldd в вашем двоичном файле.

Чтобы исправить это, вам нужно будет передать несколько дополнительных флагов:

CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -tags netgo -ldflags '-w' -o mybin *.go

Выше приведено следующее: https://medium.com/@diogok/on-golang-static-binaries-cross-compiling-and-plugins-1aed33499671

0 голосов
/ 28 октября 2018

Я использовал это, и он работает

env GOARCH=386 GOOS=linux go build webapp.go
0 голосов
/ 04 октября 2018

Попробуйте изменить строку в вашем Dockerfile

COPY webapp /webapp

...