如何将参数传递给Powershell脚本并在远程计算机上运行它

时间:2015-02-19 10:16:26

标签: powershell remote-execution

我正在尝试将2个参数传递给PS脚本,该脚本将修补远程计算机上的SQL Server。这是我使用的代码:

$Patcher = "\\remoteShareLocation\SQLpatcher.ps1"
$ver = "SQL2012"
$inst = "NEWINST"

Invoke-Command -ComputerName RMTMACHINE -credential dmn\usrname -ScriptBlock {$Patcher $ver $inst}

这会要求提供凭据,但不会运行并显示任何输出。语法有什么问题吗?请问任何替代cmdlet吗?

2 个答案:

答案 0 :(得分:4)

如果您有PowerShell V3或更高版本,则可以使用using前缀将本地变量“传输”到远程主机:

Invoke-Command -ComputerName RMTMACHINE -credential $cred -ScriptBlock {$using:Patcher $using:ver $using:inst}

对于olders版本,请查看invoke-command

-argumentlist参数

答案 1 :(得分:0)

尝试

$cred = Get-Credential
Invoke-Command -ComputerName RMTMACHINE -credential $cred -ScriptBlock {$Patcher $ver $inst}

或创建一个这样的凭证对象:

$username = "username"
$password = "password" | ConvertTo-SecureString -asPlainText -Force
$cred = New-Object System.Management.Automation.PSCredential($username,$password)

您需要传递凭据对象而不是Domain \ username。

要远程运行脚本文件,请查看https://stackoverflow.com/a/10446318/4550393