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