启动容器进程导致“ exec:\” / app \”:权限被拒绝”:未知

时间:2019-09-05 09:16:21

标签: docker go alpine

当我尝试使用docker构建golang时

Docker的映像构建成功,但是在使用docker run进行运行时发生以下错误

docker: Error response from daemon: OCI runtime create failed: container_linux.go:345: starting container process caused "exec: \"/app\": permission denied": unknown.

我认为此错误不会导致用户添加,因此我如下添加了组和用户

RUN groupadd -g 10001 myapp \
    && useradd -u 10001 -g myapp myapp

但没有解决。

这是我的源docker文件

FROM golang:1.12.9 as builder

ADD . /go/src/appname/

WORKDIR /go/src/appname/

ENV GO111MODULE=on

COPY go.mod .
COPY go.sum .

RUN go mod download
COPY . .

RUN  CGO_ENABLED=0 GOOS=linux GOARCH=amd64 make build target=prod

FROM alpine

RUN apk update \
  && apk add --no-cache

COPY --from=builder /go/src/ /app

ENTRYPOINT [ "/app" ]

谢谢

3 个答案:

答案 0 :(得分:1)

您将在此步骤中将整个源文件夹复制到目录/app中:

COPY --from=builder /go/src/ /app

然后尝试执行目录:

ENTRYPOINT [ "/app" ]

相反,您需要在复制步骤中复制go build输出的已编译二进制文件。

答案 1 :(得分:0)

您需要为二进制文件指定输出目录。


RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -o /app .


然后复制应用程序目录

COPY --from=builder /app ./
RUN chmod +x ./app
ENTRYPOINT ["./app"]

答案 2 :(得分:0)

感谢大家的建议,我解决了这个问题

我不能只在正确指定了构建二进制文件的情况下进行复制

之前

COPY --from=builder /go/src/ /app

之后

COPY --from=builder /go/src/build/build_app_name /app

谢谢!