Не удается подключиться к локальному Docker, на котором работает сервер Kestrel - PullRequest
0 голосов
/ 27 мая 2018

У меня есть сервер Kestrel, который возвращает Hello World для любого HTTP-запроса.

static class Program
{
    static void Main(string[] args)
    {
        var webHostBuilder = WebHost.CreateDefaultBuilder(args)
                                    .UseSetting("applicationName", "Hello World")
                                    .Configure(builder => {
                                        builder.Run(async context =>
                                                {
                                                    var textBytes = UTF8.GetBytes("Hello World!");
                                                    await context.Response.Body.WriteAsync(textBytes, 0, textBytes.Length, default (CancellationToken));
                                                });
                                        })
                                        .UseUrls("http://+:8000");
        var webHost = webHostBuilder.Build();
        webHost.Run();
    }
}

Я добавил сборки в образ Docker и собрал его с помощью этого DockerFile:

FROM microsoft/dotnet
WORKDIR /app
ADD /application /app
EXPOSE 8000
ENTRYPOINT [ "dotnet", "hello-world-server.dll" ]

Я запустил его с этим:

>docker run hello-world-server --publish-list 8000:8000

Когда я отправляю запрос на http://localhost:8000, я получаю 502.

Я использую контейнеры Windowsв Windows 10.


Полный вывод из сборки и запуска приведен ниже:

C:\...\hello-world-server-docker>docker build -t hello-world-server .
Sending build context to Docker daemon  84.99kB
Step 1/5 : FROM microsoft/dotnet
 ---> d08db1d19023
Step 2/5 : WORKDIR /app
Removing intermediate container 873dea47b78b
 ---> de4b80a52d54
Step 3/5 : ADD /application /app
 ---> ba75fe5b5efc
Step 4/5 : EXPOSE 8000
 ---> Running in 1ac9c977c9b4
Removing intermediate container 1ac9c977c9b4
 ---> 22cb3848d762
Step 5/5 : ENTRYPOINT [ "dotnet", "hello-world-server.dll" ]
 ---> Running in 17f3b01f6ed0
Removing intermediate container 17f3b01f6ed0
 ---> 82c7e3aadfc2
Successfully built 82c7e3aadfc2
Successfully tagged hello-world-server:latest

C:\...\hello-world-server-docker>docker run hello-world-server --publish-list 8000:8000
Hosting environment: Production
Content root path: C:\app
Now listening on: http://[::]:8000
Application started. Press Ctrl+C to shut down.

Когда делается запрос на localhost:8000, на консоли больше не выводитсяKestrel, хотя обычно это было бы нормальное консольное приложение.


Я также пытался запустить его с >docker run hello-world-server --publish 8000:8000.

1 Ответ

0 голосов
/ 27 мая 2018

Я думаю, проблема в команде docker run.--publish-list 8000:8000 как сейчас, является параметром для точки входа в контейнеры.

Команда для запуска контейнера и предоставления порта:

docker run -p 8000:8000 hello-world-server

Каждая опция командной строки для docker run должен быть помещен перед именем изображения.Все после имя изображения является командой для самого контейнера.

...