即使在 .NET Core 控制台应用程序中使用 Console.ReadLine(),docker 容器也会立即退出

docker container exits immediately even with Console.ReadLine() in a .NET Core console application(即使在 .NET Core 控制台应用程序中使用 Console.ReadLine(),docker 容器也会立即退出)
本文介绍了即使在 .NET Core 控制台应用程序中使用 Console.ReadLine(),docker 容器也会立即退出的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试在 docker 容器内运行 .NET Core 1.0.0 控制台应用程序.
当我从机器上的 Demo 文件夹中运行 dotnet run 命令时,它工作正常;但是当使用 docker run -d --name demo Demo 运行时,容器会立即退出.

I am trying to run a .NET Core 1.0.0 console application inside a docker container.
When I run dotnet run command from inside the Demo folder on my machine, it works fine; but when run using docker run -d --name demo Demo, the container exits immediately.

我试过 docker logs demo 来检查日志,它只显示来自 Console.WriteLine 的文本:

I tried docker logs demo to check the logs and it just shows the text from the Console.WriteLine:

演示应用正在运行...

Demo app running...

没有别的了.

我已将项目上传到 https://github.com/learningdockerandnetcore/Demo

项目包含Programs.csDockerfile用于创建Demo镜像,project.json文件.

The project contains Programs.cs, Dockerfile used to create Demo image, and project.json file.

推荐答案

您应该在交互模式下运行您的容器(使用 -i 选项),但请注意后台进程将被关闭当您运行容器时立即运行,因此请确保您的脚本在前台运行,否则它根本无法工作.

You should run your container in Interactive mode (with the -i option), but please note that the background processes will be closed immediately when you run the container, so make sure your script is run in the foreground or it simply won't work.

这篇关于即使在 .NET Core 控制台应用程序中使用 Console.ReadLine(),docker 容器也会立即退出的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)