我正在尝试运行一个非常简单的控制台应用程序作为一个windows docker容器。我有一个如下所示的docker文件,使用的是"dotnet-framework:4.7.2-runtime-windowsservercore-1803“基础图像。
FROM microsoft/dotnet-framework:4.7.2-runtime-windowsservercore-1803
ARG source
WORKDIR /app
COPY ${source:-obj/Docker/publish} .
ENTRYPOINT "DockerConsoleApp.exe"控制台应用程序仅每5秒将"Hello World“输出到日志文件。
static void Main(string[] args)
{
while (true)
{
try
{
Thread.Sleep(5000);
_logger.Info("Hello Wolrd");
}
catch (Exception e)
{
//handle the exception
Console.Error.WriteLine(e);
}
}
}我正在使用下面的docker组合文件
version: '3.4'
services:
dockerconsoleapp:
image: dockerconsoleapp:dev
build:
context: .\
args:
source: obj\Docker\publish
volumes:
- C:\Users\user\source\repos\DockerConsoleApp\DockerConsoleApp:C:\app
- C:\Program Files (x86)\Microsoft Visual Studio\2019\Professional\Common7\IDE\Remote Debugger:C:\remote_debugger:ro
- C:\Users\user\source\repos\DockerConsoleApp\VolumeTest:C:\app\logs问题是,只要我手动构建或运行"docker-compose up -d“,容器就会创建,然后立即消亡。考虑到应用程序是在入口点调用的,我认为容器应该保持正常运行,并且应用程序应该继续运行,除非手动停止。
发布于 2019-06-26 22:18:50
您的容器很可能是由于ENTRYPOINT中的异常或ENTRYPOINT本身无效而死的。您可以检查docker logs以找出原因。
发布于 2019-06-27 15:51:48
最后,修复方法是将dockerfile中的入口点更改为CMD。见下文。
FROM microsoft/dotnet-framework:4.7.2-runtime-windowsservercore-1803
ARG source
WORKDIR /app
COPY ${source:-obj/Docker/publish} .
CMD ["DockerConsoleApp.exe"]我让它运行了一夜,现在容器已经运行了15个小时。
https://stackoverflow.com/questions/56774005
复制相似问题