通过Powershell运行远程命令

时间:2018-04-19 18:47:24

标签: powershell

我试图通过脚本在一系列远程系统上调用离散的CLI命令,但我无法获得任何PowerShell命令来接受它们。我没有尝试解释问题的具体细节,而是提供了我在下面尝试做的一些伪代码。

请注意,这只是一个简单的例子。使用stop-service命令不是一个选项。这些是通过CLI使用的显式命令,通过Splunk程序,我需要按此顺序运行。

简而言之,我无法弄清楚如何告诉PowerShell在远程计算机上逐字运行CLI命令。

foreach ($server in $list)
     cd C:\Program Files\SplunkUniversalForwarder\bin
     splunk stop
     splunk clone-prep-clear-config
     splunk start

3 个答案:

答案 0 :(得分:1)

你可以做一些方法。使用WMI c / o Powershell:

Starting,Stopping and Restarting Remote Services with PowerShell

您也可以使用Windows远程处理,但我从这里开始。

答案 1 :(得分:0)

你可以试试......

Foreach($server in $list)
{
    Invoke-command -computername $server -scripblock {
        $splunkpath = 'c:\program files\splunkuniversalforwarder\bin\splunk.exe'
        Start-process -filepath $splunkpath -argumentlist 'stop' -wait -nonewwindow
        Start-process -filepath $splunkpath -argumentlist 'clone-prep-clear-config' -wait -nonewwindow
        Start-process -filepath $splunkpath -argumentlist 'start' -wait -nonewwindow
    }
}

注意:您可能需要从命令中删除-wait和/或-nonewwindow,具体取决于您的流程的行为方式。

还有输出重定向参数检查下面的文档以获取更多信息。

Invoke-command

Start-process

答案 2 :(得分:0)

我今天早上才刚开始。这是我想出的主要内容。

foreach($server in $servers){
Write-Host "From " -nonewline; Write-Host "$server" -ForegroundColor Yellow
Invoke-Command -ComputerName $server -ScriptBlock { C:\SplunkUniversalForwarder\bin\splunk.exe stop } -Credential $cred
Invoke-Command -ComputerName $server -ScriptBlock { C:\SplunkUniversalForwarder\bin\splunk.exe clone-prep-clear-config } -Credential $cred
Invoke-Command -ComputerName $server -ScriptBlock { C:\SplunkUniversalForwarder\bin\splunk.exe start } -Credential $cred

}

我的完整代码如下:


#Author: Christopher Boillot
#Clear config of Splunk Forwarder



[CmdletBinding()]
Param ([Parameter(Mandatory=$False,Position=0)]
         [String[]]$servers = (Get-Content C:\ClearConfig.txt))


Set-Location $PSScriptRoot

#User login
$User = "user.txt" 
$FileExists = Test-Path $User 
If ($FileExists -eq $False) {
Write-Host "Enter your user name. This will be saved as  $User"
read-host | out-file $User
}
$Pass = "securepass.txt" 
$FileExists = Test-Path $Pass 
If ($FileExists -eq $False) {
Write-Host "Enter your password. This will be saved as an encrypted sting as $Pass"
read-host -assecurestring | convertfrom-securestring | out-file $Pass
}

$username = cat $User
$password = cat $Pass | convertto-securestring
$cred = new-object -typename System.Management.Automation.PSCredential `
         -argumentlist $username, $password


#go through each server in list
foreach($server in $servers){



Write-Host "From " -nonewline; Write-Host "$server" -ForegroundColor Yellow
Invoke-Command -ComputerName $server -ScriptBlock { C:\SplunkUniversalForwarder\bin\splunk.exe stop } -Credential $cred
Invoke-Command -ComputerName $server -ScriptBlock { C:\SplunkUniversalForwarder\bin\splunk.exe clone-prep-clear-config } -Credential $cred
Invoke-Command -ComputerName $server -ScriptBlock { C:\SplunkUniversalForwarder\bin\splunk.exe start } -Credential $cred

}