Hinweis
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, sich anzumelden oder das Verzeichnis zu wechseln.
Für den Zugriff auf diese Seite ist eine Autorisierung erforderlich. Sie können versuchen, das Verzeichnis zu wechseln.
Kurzbeschreibung
Beschreibt, wie Remotebefehle in PowerShell ausgeführt werden.
Lange Beschreibung
Sie können Remotebefehle auf einem einzelnen oder mehreren Remotecomputern mit einer temporären oder dauerhaften Verbindung ausführen. Sie können auch eine interaktive Sitzung mit einem einzelnen Remotecomputer starten.
Hinweis
Um PowerShell-Remoting zu verwenden, müssen Sie die lokalen und Remotecomputer für Remoting konfigurieren. Weitere Informationen finden Sie unter about_Remote_Requirements.
So starten Sie eine interaktive Sitzung
Die einfachste Möglichkeit zum Ausführen von Remotebefehlen besteht darin, eine interaktive Sitzung mit einem Remotecomputer zu starten.
Wenn die Sitzung gestartet wird, werden die von Ihnen eingegebenen Befehle auf dem Remotecomputer ausgeführt, als ob Sie sie direkt auf dem Remotecomputer eingegeben haben. Sie können in jeder interaktiven Sitzung nur eine Verbindung mit einem Computer herstellen.
Verwenden Sie das Cmdlet Enter-PSSession, um eine interaktive Sitzung zu starten. Der folgende Befehl startet eine interaktive Sitzung mit dem Server01-Computer:
Enter-PSSession Server01
PowerShell ändert die Eingabeaufforderung so, dass sie den Namen des Remotecomputers enthält.
Server01\PS>
Jetzt können Sie Befehle auf dem Server01-Computer eingeben.
Geben Sie Folgendes ein, um die interaktive Sitzung zu beenden:
Exit-PSSession
Weitere Informationen finden Sie unter Enter-PSSession.
Ausführen eines Remotebefehls
Verwenden Sie das Cmdlet Invoke-Command, um andere Befehle auf Remotecomputern auszuführen.
Verwenden Sie den ComputerName Parameter von Invoke-Command, um einen einzelnen Befehl oder einige nicht verwandte Befehle auszuführen, um die Remotecomputer anzugeben. Verwenden Sie den ScriptBlock Parameter, um den Befehl anzugeben.
Der folgende Befehl führt beispielsweise einen Get-Culture Befehl auf dem Server01-Computer aus.
Invoke-Command -ComputerName Server01 -ScriptBlock {Get-Culture}
So erstellen Sie eine dauerhafte Verbindung
Wenn Sie den parameter ComputerName des Cmdlets Invoke-Command verwenden, stellt PowerShell eine temporäre Verbindung mit dem Remotecomputer her. Die Verbindung wird geschlossen, wenn der Befehl abgeschlossen ist. Alle in dieser temporären Sitzung definierten Variablen oder Funktionen gehen verloren.
Verwenden Sie das Cmdlet New-PSSession, um eine dauerhafte Verbindung mit einem Remotecomputer zu erstellen. Beispielsweise erstellt der folgende Befehl PSSessions auf den Computern Server01 und Server02 und speichert dann die PSSessions in der $s Variablen.
$s = New-PSSession -ComputerName Server01, Server02
Ausführen von Befehlen in einer PSSession
Mit einer PSSession können Sie eine Reihe von Remotebefehlen ausführen, die Daten freigeben, z. B. Funktionen, Aliase und die Werte von Variablen. Verwenden Sie zum Ausführen von Befehlen in einer PSSession den Parameter Session des Cmdlets Invoke-Command.
Der folgende Befehl verwendet beispielsweise das Cmdlet Invoke-Command, um einen Get-Process Befehl in den PSSessions auf den Computern Server01 und Server02 auszuführen.
Der Befehl speichert die Prozesse in einer $p Variablen in jeder PSSession.
Invoke-Command -Session $s -ScriptBlock {$p = Get-Process}
Da die PSSession eine dauerhafte Verbindung verwendet, können Sie einen anderen Befehl in derselben PSSession ausführen, die die $p Variable verwendet. Der folgende Befehl zählt die Anzahl der prozesse, die in $pgespeichert wurden.
Invoke-Command -Session $s -ScriptBlock {$p.count}
Ausführen eines Remotebefehls auf mehreren Computern
Wenn Sie einen Remotebefehl auf mehreren Computern ausführen möchten, geben Sie alle Computernamen im Wert des ComputerName Parameter von Invoke-Commandein. Trennen Sie die Namen durch Kommas.
Der folgende Befehl führt beispielsweise einen Get-Culture Befehl auf drei Computern aus:
Invoke-Command -ComputerName S1, S2, S3 -ScriptBlock {Get-Culture}
Sie können auch einen Befehl in mehreren PSSessions ausführen. Die folgenden Befehle erstellen PSSessions auf den Computern Server01, Server02 und Server03 und führen dann einen Get-Culture Befehl in jedem der PSSessions aus.
$s = New-PSSession -ComputerName S1, S2, S3
Invoke-Command -Session $s -ScriptBlock {Get-Culture}
Um die Computerliste des lokalen Computers einzuschließen, geben Sie den Namen des lokalen Computers ein, geben Sie einen Punkt (.) ein, oder geben Sie localhostein.
Invoke-Command -ComputerName S1, S2, S3, localhost -ScriptBlock {Get-Culture}
Ausführen eines Skripts auf Remotecomputern
Um ein lokales Skript auf Remotecomputern auszuführen, verwenden Sie den FilePath Parameter von Invoke-Command. Sie müssen keine Dateien kopieren. Der folgende Befehl führt z. B. das skript Sample.ps1 auf den Computern S1 und S2 aus:
Invoke-Command -ComputerName S1, S2 -FilePath C:\Test\Sample.ps1
PowerShell gibt die Ergebnisse des Skripts an den lokalen Computer zurück.
So beenden Sie einen Remotebefehl
Um einen Befehl zu unterbrechen, drücken Sie STRG+c. PowerShell übergibt die Interruptanforderung an den Remotecomputer, auf dem der Remotebefehl beendet wird.
Weitere Informationen
Informationen zu den Systemanforderungen für Remoting finden Sie unter about_Remote_Requirements.
Hilfe zum Formatieren der Remoteausgabe finden Sie unter about_Remote_Output.
Informationen zur Funktionsweise von Remoting, zum Verwalten von Remotedaten, speziellen Konfigurationen, Sicherheitsproblemen und anderen häufig gestellten Fragen finden Sie unter Häufig gestellte Fragen zum PowerShell-Remoting.
Hilfe zum Beheben von Remotingfehlern finden Sie unter about_Remote_Troubleshooting.
Informationen zu PSSessions und beständigen Verbindungen finden Sie unter about_PSSessions.
Informationen zu PowerShell-Hintergrundaufträgen finden Sie unter about_Jobs.