Docker контейнер не работает с ошибкой системного вызова Windows - PullRequest
0 голосов
/ 04 мая 2019

Я пытаюсь запустить контейнер dotnet/core/sdk в конвейерах Azure.Чтобы все выстроилось в очередь, я создал сценарий PowerShell, который эффективно извлекает контейнер и удаляет необходимые файлы внутри него перед его запуском:

$compositeImage = "mcr.microsoft.com/dotnet/core/sdk:3.0.100-preview4-nanoserver-1809"
docker pull $compositeImage

$targetContainer = ""

Write-Host "Creating container for pre-provisioning..."

($targetContainer = docker create --name builder $compositeImage)

Write-Host $targetContainer

docker ps -a
Write-Host "Copying samples to container..."
$workPath = "C:\Users\dendeli\Documents\Expression"
$scriptPath = "C:\Users\dendeli\Downloads\test2\test2.ps1"

Write-Host "Samples path: " + $workPath
Write-Host "Script path:" + $scriptPath

Write-Host "Executing copy..."
docker cp $workPath builder:__samples

Write-Host "Executing script copy..."
docker cp $scriptPath builder:buildsamples.ps1

Write-Host "Committing changes..."
docker commit builder "mcr.microsoft.com/dotnet/core/sdk"

docker run --name newbuilder --rm "mcr.microsoft.com/dotnet/core/sdk" powershell

Проблема возникает в конце, когда я выполняю docker run,Если я исключаю команду для передачи (powershell), все работает нормально, и я вижу такой вывод:

Microsoft Windows [Version 10.0.XYZ]
(c) 2018 Microsoft Corporation. All rights reserved.

C:\>

Однако, с добавленной командой я запускаю блокировщик - он выдает ошибки:

C:\Program Files\Docker\Docker\Resources\bin\docker.exe: Error response from daemon: container 879f2fff5aeaf19ace367d3f713242519238a96944b35b2598f2a3b6010a19fb encountered an error during CreateProcess: failure in a Windows system call: The system cannot find the file specified. (0x2)
[Event Detail:  Provider: 00000000-0000-0000-0000-000000000000]
[Event Detail:  Provider: 00000000-0000-0000-0000-000000000000]
[Event Detail: onecore\vm\compute\management\orchestration\vmhostedcontainer\processmanagement.cpp(173)\vmcomputeagent.exe!00007FF686739ADB: (caller: 00007FF6866EDF1A) Exception(2) tid(380) 80070002 The system cannot find the file specified.
    CallContext:[\Bridge_ProcessMessage\VmHostedContainer_ExecuteProcess]
 Provider: 00000000-0000-0000-0000-000000000000] extra info: {"CommandLine":"powershell","User":"ContainerUser","WorkingDirectory":"C:\\","Environment":{"ASPNETCORE_URLS":"http://+:80","DOTNET_RUNNING_IN_CONTAINER":"true","DOTNET_USE_POLLING_FILE_WATCHER":"true","NUGET_XMLDOC_MODE":"skip"},"CreateStdInPipe":true,"CreateStdOutPipe":true,"CreateStdErrPipe":true,"ConsoleSize":[0,0]}.

Что мне здесь не хватает?

1 Ответ

1 голос
/ 06 мая 2019
C:\> docker container run -it --rm mcr.microsoft.com/dotnet/core/sdk:3.0.100-preview4-nanoserver-1803

Microsoft Windows [Version 10.0.17134.706]
(c) 2018 Microsoft Corporation. All rights reserved.

C:\>powershell
'powershell' is not recognized as an internal or external command,
operable program or batch file.

Для Powershell 5.1 вам понадобится сетевая инфраструктура для ее запуска, что не имеет смысла в контейнере, содержащем ядро ​​dotnet.

pwsh работает (Powershell Core).

C:\>pwsh
PowerShell 6.2.0
Copyright (c) Microsoft Corporation. All rights reserved.

https://aka.ms/pscore6-docs
Type 'help' to get help.

PS C:\>
...