Update-Module
Lädt die neueste Version der angegebenen Module aus einem Onlinekatalog auf den lokalen Computer herunter und installiert diese
Syntax
Update-Module
[[-Name] <String[]>]
[-RequiredVersion <String>]
[-MaximumVersion <String>]
[-Credential <PSCredential>]
[-Scope <String>]
[-Proxy <Uri>]
[-ProxyCredential <PSCredential>]
[-Force]
[-AllowPrerelease]
[-AcceptLicense]
[-PassThru]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Beschreibung
Das Update-Module
Cmdlet installiert die neueste Version eines Moduls aus einem Onlinekatalog. Sie werden aufgefordert, das Update zu bestätigen, bevor es installiert wird. Updates werden nur für Module installiert, die auf dem lokalen Computer mit Install-Module
installiert wurden. Update-Module
sucht nach $env:PSModulePath
installierten Modulen.
Update-Module
ohne angegebene Parameter werden alle installierten Module aktualisiert. Verwenden Sie zum Angeben eines zu aktualisierenden Moduls den Parameter Name . Sie können mit dem Parameter RequiredVersion auf die spezifische Version eines Moduls aktualisieren.
Die Parameter, die Modulversionsnummern annehmen, erwarten Zeichenfolgen, die als Versionsnummern formatiert sind.
- Standardversionsnummern weisen das Format auf
x.y.z
, wobei x, y und z Zahlen sind. - Vorabversionen weisen das Format
x.y.z-<prerelease_label>
auf, wobei der<prerelease_label>
dieser Version eine beliebige Zeichenfolge zugewiesen ist.
Wenn ein installiertes Modul bereits die neueste Version ist, wird das Modul nicht aktualisiert. Wenn das Modul in $env:PSModulePath
nicht gefunden wird, wird ein Fehler angezeigt.
Verwenden Sie Get-InstalledModule
zum Anzeigen der installierten Module .
Beispiele
Beispiel 1: Aktualisieren aller Module
In diesem Beispiel werden alle installierten Module auf die neueste Version in einem Onlinekatalog aktualisiert.
Update-Module
Beispiel 2: Aktualisieren eines Moduls anhand des Namens
In diesem Beispiel wird ein bestimmtes Modul auf die neueste Version in einem Onlinekatalog aktualisiert.
Update-Module -Name SpeculationControl
Update-Module
verwendet den Parameter Name , um ein bestimmtes Modul zu aktualisieren, SpeculationControl.
Beispiel 3: Anzeigen von Was-wäre-wäre-wenn-Update-Module Ausführungen
In diesem Beispiel wird ein Was-wäre-wenn-Szenario ausgeführt, um zu zeigen, was geschieht, wenn Update-Module
ausgeführt wird. Der Befehl wird nicht ausgeführt.
Update-Module -WhatIf
What if: Performing the operation "Update-Module" on target "Version '2.8.0' of module
'Carbon', updating to version '2.8.1'".
What if: Performing the operation "Update-Module" on target "Version '1.0.10' of module
'SpeculationControl', updating to version '1.0.14'".
Update-Module
verwendet den WhatIf-Parameter , der anzeigt, was passieren würde, wenn Update-Module
ausgeführt würde.
Beispiel 4: Aktualisieren eines Moduls auf eine angegebene Version
In diesem Beispiel wird ein Modul auf eine bestimmte Version aktualisiert. Die Version muss im Onlinekatalog vorhanden sein, andernfalls wird ein Fehler angezeigt.
Update-Module -Name SpeculationControl -RequiredVersion 1.0.14
Update-Module
verwendet den Parameter Name , um das Modul "SpeculationControl" anzugeben. Der Parameter RequiredVersion gibt die Version 1.0.14 an.
Beispiel 5: Aktualisieren eines Moduls ohne Bestätigung
In diesem Beispiel wird keine Bestätigung zum Aktualisieren des Moduls auf die neueste Version aus einem Onlinekatalog angefordert. Wenn das Modul bereits installiert ist, wird das Modul mit dem Force-Parameter neu installiert.
Update-Module -Name SpeculationControl -Force
Update-Module
verwendet den Parameter Name , um das Modul "SpeculationControl" anzugeben. Der Force-Parameter aktualisiert das Modul, ohne eine Benutzerbestätigung anzufordern.
Parameter
-AcceptLicense
Akzeptieren Sie den Lizenzvertrag automatisch während der Installation, wenn dies für das Paket erforderlich ist.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-AllowPrerelease
Ermöglicht ihnen das Aktualisieren eines Moduls mit dem neueren Modul, das als Vorabversion gekennzeichnet ist.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Confirm
Fordert Sie zur Bestätigung auf, bevor Sie ausführen Update-Module
.
Type: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Credential
Gibt ein Benutzerkonto an, das über die Berechtigung zum Aktualisieren eines Moduls verfügt.
Type: | PSCredential |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Force
Erzwingt eine Aktualisierung jedes angegebenen Moduls, ohne dass eine Bestätigung angefordert werden muss. Wenn das Modul bereits installiert ist, erzwingt die Neuinstallation des Moduls.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-MaximumVersion
Gibt die maximale Version eines einzelnen zu aktualisierenden Moduls an. Sie können diesen Parameter nicht hinzufügen, wenn Sie versuchen, mehrere Module zu aktualisieren. Die Parameter MaximumVersion und RequiredVersion können nicht im gleichen Befehl verwendet werden.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Name
Gibt die Namen eines oder mehrerer zu aktualisierenden Module an. Update-Module
sucht nach $env:PSModulePath
den zu aktualisierenden Modulen. Wenn in $env:PSModulePath
für den angegebenen Modulnamen keine Übereinstimmungen gefunden werden, tritt ein Fehler auf.
In Modulnamen werden Wildcards akzeptiert. Wenn Sie dem angegebenen Namen Wildcardzeichen hinzufügen und keine Übereinstimmungen gefunden werden, tritt kein Fehler auf.
Type: | String[] |
Position: | 0 |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | True |
-PassThru
Gibt ein Objekt zurück, das das Element darstellt, mit dem Sie arbeiten. Standardmäßig wird von diesem Cmdlet keine Ausgabe generiert.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Proxy
Gibt einen Proxyserver für die Anforderung an, anstatt eine direkte Verbindung mit einer Internetressource herzustellen.
Type: | Uri |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-ProxyCredential
Gibt ein Benutzerkonto an, das über die Berechtigung zum Verwenden des Proxyservers verfügt, der durch den Proxy-Parameter angegeben wird.
Type: | PSCredential |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-RequiredVersion
Gibt die genaue Version an, auf die das vorhandene installierte Modul aktualisiert wird. Die von RequiredVersion angegebene Version muss im Onlinekatalog vorhanden sein, andernfalls wird ein Fehler angezeigt. Wenn mehrere Module in einem einzelnen Befehl aktualisiert werden, können Sie RequiredVersion nicht verwenden.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Scope
Gibt den Bereich der Installation des Moduls an. Die zulässigen Werte für diesen Parameter sind AllUsers und CurrentUser. Wenn Bereich nicht angegeben ist, wird das Update im CurrentUser-Bereich installiert.
Der Bereich AllUsers erfordert erhöhte Berechtigungen und installiert Module an einem Speicherort, auf den alle Benutzer des Computers zugreifen können:
$env:ProgramFiles\PowerShell\Modules
CurrentUser erfordert keine erhöhten Berechtigungen und installiert Module an einem Speicherort, auf den nur der aktuelle Benutzer des Computers zugreifen kann:
$HOME\Documents\PowerShell\Modules
Wenn kein Bereich definiert ist, wird der Standardwert basierend auf der PowerShellGet-Version festgelegt.
- In PowerShellGet-Versionen 2.0.0 und höher ist der Standardwert CurrentUser. Für die Installation ist keine Rechteerweiterung erforderlich.
- In PowerShellGet 1.x-Versionen ist die Standardeinstellung AllUsers, was für die Installation erhöhte Rechte erfordert.
Type: | String |
Accepted values: | CurrentUser, AllUsers |
Position: | Named |
Default value: | CurrentUser |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-WhatIf
Zeigt, was bei Ausführungen passieren Update-Module
würde. Das Cmdlet wird nicht ausgeführt.
Type: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Eingaben
String[]
Ausgaben
Hinweise
PowerShell enthält die folgenden Aliase für Update-Module
:
- Alle Plattformen:
upmo
Für PowerShell Version 6.0 und höher ist der Standardinstallationsbereich immer CurrentUser.
Modulupdates für CurrentUser, $HOME\Documents\PowerShell\Modules
, benötigen keine erhöhten Berechtigungen. Modulupdates für AllUsers, $env:ProgramFiles\PowerShell\Modules
benötigen erhöhte Berechtigungen.
Wichtig
Ab April 2020 unterstützt der PowerShell-Katalog die TLS-Versionen (Transport Layer Security) 1.0 und 1.1 nicht mehr. Wenn Sie nicht TLS 1.2 oder höher verwenden, erhalten Sie beim Versuch des Zugriffs auf den PowerShell-Katalog eine Fehlermeldung. Mit dem folgenden Befehl können Sie sicherstellen, dass Sie TLS 1.2 verwenden:
[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12
Weitere Informationen finden Sie im PowerShell-Blog in der Ankündigung.
Update-Module
wird unter PowerShell 3.0 oder höheren Versionen von PowerShell, unter Windows 7 oder Windows 2008 R2 und höheren Versionen von Windows ausgeführt.
Wenn das Modul, das Sie mit dem Parameter Name angeben, nicht mit Install-Module
installiert wurde, tritt ein Fehler auf.
Sie können nur für Module ausführen Update-Module
, die Sie aus dem Onlinekatalog installiert haben, indem Sie ausführen Install-Module
.
Wenn Update-Module
versucht wird, verwendete Binärdateien zu aktualisieren, gibt einen Fehler zurück, Update-Module
der die Problemprozesse identifiziert. Der Benutzer wird informiert, nach dem Beenden der Prozesse einen Wiederholungsversuch Update-Module
auszuführen.