在远程计算机运行PowerShell命令sql
检查PowerShell Remoting是否启用ide
在Windows Server 2008 R2上以管理员身份运行PowerShell,而后输入测试
Enter-PSSession -ComputerName localhost
返回以下截图:spa
说明该版本默认是没有启用PowerShell Remoting功能。blog
在Windows Server 2012 R2上,返回以下截图:ip
在Windows Server 2016上,返回以下截图:get
说明在2012和2016上,默认启用了PowerShell Remoting功能。it
启用PowerShell Remotingio
在Windows Server 2008 R2上,以管理员身份运行PowerShell,而后输入如下脚本:class
Enable-PSRemoting -Force
这个命令会启动WinRM服务,设置为在你的系统上自动启动,并建立一条容许传入链接的防火墙策略。
验证是否启动成功:
配置信任主机
若是你的主机不在域环境,而是在工做组环境,能够配置可以远程访问该主机的可信任列表。
Set-Item wsman:\localhost\client\trustedhosts *
你也能够将*替换为可信任的局域网主机192.168.11.*
而后,重启WinRM服务使之生效:
Restart-Service WinRM
测试链接
从访问远程主机的客户端,经过Test-WsMan测试你的配置。这个命令测试远程主机上WinRM服务是否在运行。若是成功完成,你会知道WinRM启用了,能够彼此通讯。
Test-WsMan szsql05
若是命令成功完成,你会看到远程计算机的WinRM服务信息。若是命令失败,会看到错误信息。
执行远程命令
使用Invoke-Command在远程系统上运行命令。语法以下:
Invoke-Command -ComputerName COMPUTER -ScriptBlock { COMMAND } -credential USERNAME
COMPUTER为计算机的名字;
COMMAND是你要运行的命令;
USERNAME是你想在远程计算机上运行命令的用户名。你会提示输入该用户名的密码。
例如,以用户dx\xucy查看远程计算机szsql05上C盘根目录下的内容,你能够输入以下命令:
Invoke-Command -ComputerName szsql05 -ScriptBlock { Get-ChildItem C:\ } -credential dx\xucy
输入域帐号密码后:
开始一个远程会话
使用Enter-PSSession启动一个远程PowerShell会话,这里你能够运行多个命令,而不仅运行一个命令:
Enter-PSSession -ComputerName COMPUTER -Credential USER