【问题标题】:To understand ENTRYPOINT in docker了解 Docker 中的 ENTRYPOINT
【发布时间】:2016-04-02 13:27:08
【问题描述】:

我打算将我的 asp.net core 1.0 代码从 Windows 环境推送到远程 Linux docker 容器。基本上,容器会将应用程序作为服务器托管。

现在我在不同的博客中看到了 ENTRYPOINT 的不同配置。

  1. ENTRYPOINT ["./kestrel"]http://blog.dudak.me/2015/deploying-aspnet-5-applications-to-docker-containers/
  2. ENTRYPOINT ["dnx", "-p", "project.json", "web"]Cannot run asp.net 5 from docker
  3. ENTRYPOINT ["dnx", "./src/HelloMvc6", "kestrel"]https://alexanderzeitler.com/articles/Running-ASP.NET-5-beta4-in-Docker-with-DNX-runtime/
  4. ENTRYPOINT ["./web"] 如果使用 http://www.hanselman.com/blog/PublishingAnASPNET5AppToDockerOnLinuxWithVisualStudio.aspx

我是 docker 新手。我不知道其中的区别,也不确定可以使用哪一个。

【问题讨论】:

  • 您刚刚发布了随机命令列表。我建议从the documentation 开始,然后针对不清楚的事情提出具体问题。
  • Entrypoint 只是 docker 启动时运行的命令。您列出的示例或多或少相同。 No. 1 和 4 kestrelweb 本身就是一个 shell 脚本,如果你打开它,你会发现相同的 dnx .... 命令。您可能想研究如何正确使用此命令。
  • @warmoverflow,第 4 号。为什么使用web?这是一个特殊的词吗?我找不到那个文件。这是一个命令。

标签: docker asp.net-core


【解决方案1】:

这些是来自project.json 的各种命令或调用project.json 中命令的脚本。

如果您查看a project.json file,您会看到如下命令列表:

"commands": {
  "gen": "Microsoft.Extensions.CodeGeneration",
  "run": "run server.urls=http://localhost:5003",
  "web": "Microsoft.AspNet.Server.Kestrel",
  "kestrel": "Microsoft.AspNet.Hosting --server Microsoft.AspNet.Server.Kestrel --server.urls http://localhost:5004",
  "weblistener": "Microsoft.AspNet.Hosting --server Microsoft.AspNet.Server.WebListener --server.urls http://localhost:5002"
},

此外,当您发布应用程序时,将生成一个带有命令名称的脚本。例如,对于 kestrel,dnx 将生成 kestrel (unix) 和 kestrel.cmd (windows),它们只需使用参数 kestrel 调用 dnx

-p 传递给dnx 指定要运行的项目。在较新版本的dnx 中,您不需要-p;相反,传递的第一个参数是项目路径。

所以,在你的情况下:

  1. ENTRYPOINT ["./kestrel"] 是调用 dnx . kestreldnx kestrel 的脚本。
  2. ENTRYPOINT ["dnx", "-p", "project.json", "web"] 使用参数 -p project.json web(网络命令)调用 dnx
  3. ENTRYPOINT ["dnx", "./src/HelloMvc6", "kestrel"] 与 2 相同,但使用了 kestrel 命令。
  4. ENTRYPOINT ["./web"]同1,调用调用web命令的脚本。

【讨论】:

  • 谢谢。一个跟随问题。从here,它使用了另一个ENTRYPOINT ["/bin/bash", "-c", "dnx-watch web"]。当我们将 asp.net 部署到 docker 容器时,我们应该使用这个还是从我原来的 ENTRYPOINT 列表中的 1、2、3 和 4 中选择一个?
  • dnx-watch 通常是一个开发场景,因为你也需要部署源代码。当您开发和更改代码时,这很好,因为您的应用程序将在文件更改时重新启动,但在文件不更改的生产场景中,您不需要它。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-07-04
  • 1970-01-01
  • 2022-01-09
  • 2018-02-23
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多