【问题标题】:Source files are updated, but CMD does not reflect源文件已更新,但 CMD 不反映
【发布时间】:2026-02-06 23:30:01
【问题描述】:

我是 docker 新手,正在尝试将我拥有的应用程序 docker 化。这是我正在使用的 dockerfile:

FROM golang:1.10

WORKDIR /go/src/github.com/myuser/pkg
ADD . .

RUN curl https://raw.githubusercontent.com/golang/dep/master/install.sh | sh
RUN dep ensure

CMD ["go", "run", "cmd/pkg/main.go"]

我遇到的问题是我将使用一些日志语句更新本地计算机上的源文件,重建映像,然后尝试在容器中运行它。但是,CMD (go run cmd/pkg/main.go) 不会反映我所做的更改。

我查看了容器文件系统,发现源文件已更新并与我在本地拥有的文件相匹配。但是当我在容器中运行go run cmd/pkg/main.go 时,我没有看到我添加的日志语句。

我尝试在构建映像时使用--no-cache 选项,但这似乎没有帮助。这是 golang 映像的问题,还是我的 dockerfile 设置的问题?

更新:我发现了问题。该问题与使用dep 进行销售有关。供应商文件夹中包含我的包的过时文件,因为 dep ensure 是从 github 而不是本地提取它们。我将转到支持 go 模块来解决此问题的 go 1.1。

【问题讨论】:

  • 你能分享一下你实际使用的docker builddocker run 命令吗?
  • 当然:docker build . —no-cache -t pkgdocker run —env-file envfile pkg

标签: docker go dockerfile


【解决方案1】:

我看到了几件事:

根据你的 Dockerfile

  1. 也许你在dep ensure之前需要一个dep init
  2. 可能需要检查main.go路径是否正确。

根据 docker 哲学

  1. 以我的拙见,您应该使用docker build -t <your_image_name> . 创建一个映像,执行您的Dockerfile 所在的位置,但没有CMD 行。
  2. 我会在你的docker run -d <your_image_name> go run <cmd/pkg/main.go> 中执行你的go run <your main.go> 或任何你的命令。

如果出现问题,您可以使用 docker ps -a 检查退出的容器,并使用 docker logs <your_CONTAINER_name/id> 检查日志

查看日志的其他方法是使用 bash 访问容器并手动执行 go run

docker run -ti <your_image_name> bash
# go run blablabla

【讨论】:

  • 没有理由删除 CMD。它说,默认情况下,实际运行要打包到 Docker 映像中的程序;但是如果你需要一个交互式 shell,你所拥有的语法就可以正常工作。
  • 原因是更容易调试。当程序稳定时,在生产中,您当然可以毫无问题地使用 CMD,但在开发或测试阶段我建议使用 docker run 执行 CMD/ENTRYPOINT,而不是在 built 阶段。
  • 我已经尝试访问容器并从 bash shell 运行 go run ...,但仍然没有打印日志语句。我查看了文件系统内部,文件路径和文件内容与我的本地 $GOPATH 匹配
最近更新 更多