Назад | Перейти на главную страницу

Как удаленно выполнить bat-файл с помощью Psexec из Team City внутри команды powershell

У меня есть команда PowerShell, которая работает в TeamCity. Когда я пытаюсь запустить командный файл удаленно с помощью psexec из этого файла .ps, я вижу, что после запуска удаленного выполнения ничего не происходит. Я пробовал несколько способов, обсуждаемых на нескольких форумах, но без толку.

Main.ps:

Invoke-Command -ScriptBlock {C:\PSInstall.bat}

PSInstall.bat:

C:\Tools\psexec.exe -i -d "\\server2" -u "domain\admin" -p "abcd" -f -w cmd "C:\Install.bat"

Мой журнал сборки:

[11:32:02]C:\BuildAgent\work\603cfc01a3fe22bb\Tools>C:\Tools\psexec.exe -i -d "\\server2" -u "domain\admin" -p "abcd" -f -w cmd "C:\Install.bat" 
[11:32:02]
[11:32:02]PsExec v1.98 - Execute processes remotely
[11:32:02]Copyright (C) 2001-2010 Mark Russinovich
[11:32:02]PsExec executes a program on a remote system, where remotely executed console
[11:32:02]Sysinternals - www.sysinternals.com
[11:32:02]applications execute interactively.

Я застрял на этом этапе, не имея ни малейшего представления о том, что происходит, любая помощь приветствуется. Я уже установил лицензионное соглашение на удаленном компьютере.

В PsExec команда / аргументы, которые вы указали в своем примере, имеют неправильный формат, вместо этого попробуйте:

C:\Tools\PsExec.exe \\server2 -u "domain\admin" -p "abcd" "C:\Install.bat" -i -d -f -w

Кроме того, соединяем все это вместе с примером, адаптированным из того, что я написал ранее. PSExecRetry.log будет содержать вывод PsExec (включая ошибки), хотя StdOut/StdErr вывод следующей команды как есть.

PSExecRetry.ps1 это сценарий PowerShell с некоторой базовой логикой повтора:

#PSExecRetry.ps1

$LogFile = "PSExecRetry.log"
$defaultSleepSecs = 3
$RetryCount = 3
$StopLoop = $false
$retries = 1

try {
    # open the log file
    Start-Transcript -path $LogFile -append
    do {
        try
        {
            $Command = "C:\PSInstall.bat"
            Write-Host "Executing command" $Command ".`r"
            Invoke-Expression -Command $Command

            if ($LastExitcode -ne 0)
            {
                throw "Retry {0} of {1}" -f $retries, $RetryCount
            }
            else
            {
                $StopLoop = $true
            }
        }
        catch
        {
            if ($retries -gt $RetryCount)
            {
                Write-Host("Exception.Message={0}; InvocationInfo.ScriptName={1}" -f $_.Exception.Message, $_.InvocationInfo.ScriptName)
                Write-Host("Giving up after {0} retries.`r" -f $RetryCount)
                $StopLoop = $true
            }
            else
            {
                Write-Host("Exception.Message={0}; InvocationInfo.ScriptName={1}" -f $_.Exception.Message, $_.InvocationInfo.ScriptName)
                Write-Host("Exception, retrying in {0} seconds.`r" -f $defaultSleepSecs)
                Start-Sleep -Seconds $defaultSleepSecs
                $retries = $retries + 1        
            }
        }
    } While ($StopLoop -eq $false)
}
catch
{
    Write-Host("Exception.Message={0}; InvocationInfo.ScriptName={1}" -f $_.Exception.Message, $_.InvocationInfo.ScriptName)
}
finally
{
    Stop-Transcript
}

PSInstall.cmd изменяется следующим образом:

#PSInstall.cmd

C:\PsExec.exe \\server2 -u "domain\admin" -p "abcd" "C:\Install.bat" -i -d -f -w

Install.bat заглушка:

#Install.bat

echo Hello world!