标准“u init”linux.go:190:exec用户进程导致”;没有这样的文件或目录;Docker与go basic web应用程序

标准“u init”linux.go:190:exec用户进程导致”;没有这样的文件或目录;Docker与go basic web应用程序,docker,go,dockerfile,Docker,Go,Dockerfile,最基本的web应用程序是在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) }

最基本的web应用程序是在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)


}
镜像成功构建

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
但当我运行docker时,它显示错误

ubuntu@ip:~/go/src/hello$ docker run webapp
standard_init_linux.go:190: exec user process caused "no such file or directory"
请指导是什么问题,我是新来的码头工人

与环境有关的资料

ubuntu@ip:~/go/src/hello$ ls
Dockerfile  webapp
ubuntu@ip:~/go/src/hello$ echo $GOPATH
/home/ubuntu/go

代码是使用go build webapp编译的。go命令

尝试更改Dockerfile中的行


复制webapp/webapp

未找到文件可能意味着文件丢失、脚本缺少解释器或可执行文件缺少库。在本例中,默认情况下,净导入将libc作为动态链接二进制文件引入。在二进制文件上使用
ldd
应该可以看到这一点

要修复它,您需要传递一些额外的标志:

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

上面的内容来自:

我使用了这个,它很有效

env GOARCH=386 GOOS=linux go build webapp.go

在我的例子中,
CGO\u ENABLED=0
是解决此问题的关键

Cgo允许在Go源代码中使用内联C代码,请参阅更多:

我认为默认情况下,Cgo会将您的应用程序动态链接到libc,即使您不使用任何内联C。
当您从头开始将应用程序打包到Docker image
时,libc将丢失

这是我的工作文件:

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"]

就我而言,en env还不够: 运行CGO_ENABLED=0 GOOS=linux GOARCH=amd64

我还必须在构建中添加标记和ldflags: 运行go build-a-tags netgo-ldflags'-w'-o/go/bin/myService*.go

构建:

#构建
CGO_ENABLED=0 go build-o myapp main.go
dockerfile:

#FROM alpine:3.10
FROM scratch
COPY . /

EXPOSE 8080

CMD ["/myapp", "-c", "app.ini"]

请包括您的编译命令。BMitch代码是使用go build webapp.go命令编译的
#FROM alpine:3.10
FROM scratch
COPY . /

EXPOSE 8080

CMD ["/myapp", "-c", "app.ini"]