Запуск PowerShell из команды запуска MSdeploy не завершается

StackOverflow https://stackoverflow.com/questions/4238192

  •  26-09-2019
  •  | 
  •  

Вопрос

Я пытаюсь заставить MSDeploy выполнить сценарий PowerShell на удаленном сервере.Вот как я запускаю MSDeploy:

msdeploy \
  -verb:sync \ 
  -source:runCommand='C:\temp\HelloWorld.bat', \
  waitInterval=15000,waitAttempts=1 \
  -dest:auto,computername=$WebDeployService$Credentials -verbose

HelloWorld.bat содержит:

echo "Hello world!"
powershell.exe C:\temp\WebDeploy\Package\HelloWorld.ps1
echo "Done"

HelloWorld.ps1 содержит только:

Write-Host "Hello world from PowerShell!"

Однако похоже, что PowerShell никогда не завершает работу.Это результат запуска msdeploy:

Verbose: Performing synchronization pass #1.
Verbose: Source runCommand (C:\temp\HelloWorld.bat) does not match destination (C:\temp\HelloWorld.bat) differing in attributes (isSource['True','False']). Update pending.
Info: Updating runCommand (C:\temp\HelloWorld.bat).
Info:

Info: C:\temp>echo "Hello world!"
"Hello world!"

C:\temp\WebDeploy>powershell.exe C:\temp\HelloWorld.ps1

Info: Hello world from Powershell!
Info:

Warning: The process 'C:\Windows\system32\cmd.exe' (command line '/c "C:\Users\peter\AppData\Local\Temp\gaskgh55.b2q.bat
"') is still running. Waiting for 15000 ms (attempt 1 of 1).
Error: The process 'C:\Windows\system32\cmd.exe' (command line '/c "C:\Users\peter\AppData\Local\Temp\gaskgh55.b2q.bat"'
) was terminated because it exceeded the wait time.
Error count: 1.

Кто-нибудь знает решение?

Это было полезно?

Решение

Ваш сценарий и проблема похожи на эту сообщенную проблему:PowerShell.exe может зависнуть при перенаправлении STDIN

Если это так, попробуйте этот обходной путь:использовать -inputformat none:

powershell.exe -inputformat none C:\temp\WebDeploy\Package\HelloWorld.ps1

Я попробовал это с помощью «поддельной программы msdeploy», которая вызывает файл .bat следующим образом:

using System.Diagnostics;
class Program
{
    static void Main(string[] args)
    {
        ProcessStartInfo si = new ProcessStartInfo();
        si.FileName = "cmd.exe";
        si.Arguments = "/c " + args[0];
        si.RedirectStandardInput = true;
        si.UseShellExecute = false;
        var process = Process.Start(si);
        process.WaitForExit();
    }
}

В этой демонстрации есть та же проблема, которую вы описываете, и обходной путь помогает.Если msdeploy вызывает файл .bat таким же или похожим способом, то, надеюсь, это решение.

Другие советы

powershell.exe -file ScriptFile.ps < CON

Это решает проблему, не прибегая к недокументированным функциям.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top