Import-PSSession
Importa i comandi da un'altra sessione alla sessione corrente.
Sintassi
Import-PSSession
[-Prefix <String>]
[-DisableNameChecking]
[[-CommandName] <String[]>]
[-AllowClobber]
[-ArgumentList <Object[]>]
[-CommandType <CommandTypes>]
[-Module <String[]>]
[-FullyQualifiedModule <ModuleSpecification[]>]
[[-FormatTypeName] <String[]>]
[-Certificate <X509Certificate2>]
[-Session] <PSSession>
[<CommonParameters>]
Descrizione
Il Import-PSSession
cmdlet importa i comandi , ad esempio cmdlet, funzioni e alias, da una sessione PSSession in un computer locale o remoto nella sessione corrente. È possibile importare qualsiasi comando che il Get-Command
cmdlet possa trovare nella sessione PSSession.
Usare un Import-PSSession
comando per importare comandi da una shell personalizzata, ad esempio una shell di Microsoft Exchange Server o da una sessione che include moduli di Windows PowerShell e snap-in o altri elementi non presenti nella sessione corrente.
Per importare i comandi, usare prima di tutto il New-PSSession
cmdlet per creare una sessione PSSession. Usare quindi il Import-PSSession
cmdlet per importare i comandi. Per impostazione predefinita, Import-PSSession
importa tutti i comandi ad eccezione dei comandi con gli stessi nomi dei comandi nella sessione corrente. Per importare tutti i comandi, usare il parametro AllowClobber .
È possibile usare i comandi importati analogamente a qualsiasi comando della sessione. Quando si usa un comando importato, la parte importata del comando viene eseguita implicitamente nella sessione dalla quale è stata importata. Tuttavia, le operazioni remote vengono gestite interamente da Windows PowerShell. Non è necessario che l'utente sia a conoscenza della loro esecuzione, tuttavia deve ricordarsi di tenere aperta la connessione all'altra sessione (sessione PSSession). Se la si chiude, i comandi importati non saranno più disponibili.
Poiché i comandi importati potrebbero richiedere più tempo rispetto ai comandi locali, Import-PSSession
aggiunge un parametro AsJob a ogni comando importato. Questo parametro consente di eseguire il comando come processo in background di Windows PowerShell. Per altre informazioni, vedere About Jobs (Informazioni sui processi).
Quando si usa Import-PSSession
, Windows PowerShell aggiunge i comandi importati a un modulo temporaneo esistente solo nella sessione e restituisce un oggetto che rappresenta il modulo. Per creare un modulo permanente che è possibile usare nelle sessioni future, usare il Export-PSSession
cmdlet .
Il Import-PSSession
cmdlet usa la funzionalità di comunicazione remota implicita di Windows PowerShell. Quando si importano i comandi nella sessione corrente, vengono eseguiti implicitamente nella sessione originale o in una sessione simile nel computer di origine.
A partire da Windows PowerShell 3.0, è possibile usare il Import-Module
cmdlet per importare moduli da una sessione remota nella sessione corrente. Questa funzionalità usa la comunicazione remota implicita. Equivale a usare Import-PSSession
per importare i moduli selezionati da una sessione remota nella sessione corrente.
Esempio
Esempio 1: Importare tutti i comandi da una sessione PSSession
$S = New-PSSession -ComputerName Server01
Import-PSSession -Session $S
Questo comando importa tutti i comandi da una sessione PSSession nel computer Server01 alla sessione corrente, ad eccezione dei comandi che hanno gli stessi nomi di quelli della sessione corrente.
Poiché questo comando non usa il parametro CommandName , importa anche tutti i dati di formattazione necessari per i comandi importati.
Esempio 2: Importare comandi che terminano con una stringa specifica
$S = New-PSSession https://ps.testlabs.com/powershell
Import-PSSession -Session $S -CommandName *-test -FormatTypeName *
New-Test -Name Test1
Get-Test test1 | Run-Test
Questi comandi importano comandi con nomi che finiscono con "-test" da una sessione PSSession alla sessione locale, quindi visualizzano come usare un cmdlet importato.
Il primo comando usa il New-PSSession
cmdlet per creare una sessione PSSession. Salva la sessione PSSession nella $S
variabile .
Il secondo comando usa il Import-PSSession
cmdlet per importare i comandi dalla sessione PSSession in $S
nella sessione corrente. Usa il parametro CommandName per specificare i comandi con il sostantivo Test e il parametro FormatTypeName per importare i dati di formattazione per i comandi Test.
Il terzo e il quarto comando usano i comandi importati nella sessione corrente. Poiché i comandi importati vengono effettivamente aggiunti alla sessione corrente, per eseguirli viene usata la sintassi locale. Non è necessario usare il Invoke-Command
cmdlet per eseguire un comando importato.
Esempio 3: Importare i cmdlet da una sessione PSSession
$S1 = New-PSSession -ComputerName s1
$S2 = New-PSSession -ComputerName s2
Import-PSSession -Session s1 -Type cmdlet -Name New-Test, Get-Test -FormatTypeName *
Import-PSSession -Session s2 -Type Cmdlet -Name Set-Test -FormatTypeName *
New-Test Test1 | Set-Test -RunType Full
Questo esempio mostra che è possibile usare i cmdlet importati analogamente ai cmdlet locali.
Questi comandi importano i New-Test
cmdlet e Get-Test
da una sessione PSSession nel computer Server01 e il Set-Test
cmdlet da una sessione PSSession nel computer Server02.
Anche se i cmdlet sono stati importati da diverse sessioni PSSession, è possibile inviare tramite pipe un oggetto da un cmdlet all'altro senza errori.
Esempio 4: Eseguire un comando importato come processo in background
$S = New-PSSession -ComputerName Server01
Import-PSSession -Session $S -CommandName *-test* -FormatTypeName *
$batch = New-Test -Name Batch -AsJob
Receive-Job $batch
Questo esempio mostra come eseguire un comando importato come processo in background.
Poiché i comandi importati potrebbero richiedere più tempo rispetto ai comandi locali, Import-PSSession
aggiunge un parametro AsJob a ogni comando importato. Il parametro AsJob consente di eseguire il comando come processo in background.
Il primo comando crea una sessione PSSession nel computer Server01 e salva l'oggetto PSSession nella $S
variabile .
Il secondo comando usa Import-PSSession
per importare i cmdlet test dalla sessione PSSession in $S
nella sessione corrente.
Il terzo comando usa il parametro AsJob del cmdlet importato New-Test
per eseguire un New-Test
comando come processo in background. Il comando salva l'oggetto processo che New-Test
restituisce nella $batch
variabile .
Il quarto comando usa il Receive-Job
cmdlet per ottenere i risultati del processo nella $batch
variabile .
Esempio 5: Importare cmdlet e funzioni da un modulo di Windows PowerShell
$S = New-PSSession -ComputerName Server01
Invoke-Command -Session $S {Import-Module TestManagement}
Import-PSSession -Session $S -Module TestManagement
Questo esempio mostra come importare i cmdlet e le funzioni da un modulo di Windows PowerShell in un computer remoto nella sessione corrente.
Il primo comando crea una sessione PSSession nel computer Server01 e la salva nella $S
variabile .
Il secondo comando usa il Invoke-Command
cmdlet per eseguire un Import-Module
comando nella sessione PSSession in $S
.
In genere, il modulo viene aggiunto a tutte le sessioni da un Import-Module
comando in un profilo di Windows PowerShell, ma i profili non vengono eseguiti nelle sessioni PSSession.
Il terzo comando usa il parametro Module di Import-PSSession
per importare i cmdlet e le funzioni nel modulo nella sessione corrente.
Esempio 6: Creare un modulo in un file temporaneo
PS C:\> Import-PSSession $S -CommandName Get-Date, SearchHelp -FormatTypeName * -AllowClobber
Name : tmp_79468106-4e1d-4d90-af97-1154f9317239_tcw1zunz.ttf
Path : C:\Users\User01\AppData\Local\Temp\tmp_79468106-4e1d-4d90-af97-1154f9317239_tcw1
zunz.ttf\tmp_79468106-4e1d-4d90-af97-1154f9317239_
tcw1zunz.ttf.psm1
Description : Implicit remoting for http://server01.corp.fabrikam.com/wsman
Guid : 79468106-4e1d-4d90-af97-1154f9317239
Version : 1.0
ModuleBase : C:\Users\User01\AppData\Local\Temp\tmp_79468106-4e1d-4d90-af97-1154f9317239_tcw1
zunz.ttf
ModuleType : Script
PrivateData : {ImplicitRemoting}
AccessMode : ReadWrite
ExportedAliases : {}
ExportedCmdlets : {}
ExportedFunctions : {[Get-Date, Get-Date], [SearchHelp, SearchHelp]}
ExportedVariables : {}
NestedModules : {}
Questo esempio mostra che Import-PSSession
crea un modulo in un file temporaneo su disco. Mostra anche che tutti i comandi vengono convertiti in funzioni prima di essere importati nella sessione corrente.
Il comando usa il Import-PSSession
cmdlet per importare un Get-Date
cmdlet e una funzione SearchHelp nella sessione corrente.
Il Import-PSSession
cmdlet restituisce un oggetto PSModuleInfo che rappresenta il modulo temporaneo. Il valore della proprietà Path mostra che Import-PSSession
è stato creato un file di modulo script (psm1) in un percorso temporaneo. La proprietà ExportedFunctions mostra che il Get-Date
cmdlet e la funzione SearchHelp sono stati entrambi importati come funzioni.
Esempio 7: Eseguire un comando nascosto da un comando importato
PS C:\> Import-PSSession $S -CommandName Get-Date -FormatTypeName * -AllowClobber
PS C:\> Get-Command Get-Date -All
CommandType Name Definition
----------- ---- ----------
Function Get-Date ...
Cmdlet Get-Date Get-Date [[-Date] <DateTime>] [-Year <Int32>] [-Month <Int32>]
PS C:\> Get-Date
09074
PS C:\> (Get-Command -Type Cmdlet -Name Get-Date).PSSnapin.Name
Microsoft.PowerShell.Utility
PS C:\> Microsoft.PowerShell.Utility\Get-Date
Sunday, March 15, 2009 2:08:26 PM
Questo esempio mostra come eseguire un comando nascosto da un comando importato.
Il primo comando importa un Get-Date
cmdlet dalla sessione PSSession nella $S
variabile . Poiché la sessione corrente include un Get-Date
cmdlet, il parametro AllowClobber è obbligatorio nel comando .
Il secondo comando usa il parametro All del Get-Command
cmdlet per ottenere tutti i Get-Date
comandi nella sessione corrente. L'output mostra che la sessione include il cmdlet originale Get-Date
e una Get-Date
funzione. La Get-Date
funzione esegue il cmdlet importato Get-Date
in PSSession in $S
.
Il terzo comando esegue un Get-Date
comando. Poiché le funzioni hanno la precedenza sui cmdlet, Windows PowerShell esegue la funzione importata Get-Date
, che restituisce una data julian.
Il quarto e il quinto comando mostrano come usare un nome completo per eseguire un comando nascosto da un comando importato.
Il quarto comando ottiene il nome dello snap-in di Windows PowerShell che ha aggiunto il cmdlet originale Get-Date
alla sessione corrente.
Il quinto comando usa il nome completo dello snap-in del Get-Date
cmdlet per eseguire un Get-Date
comando.
Per altre informazioni sulla precedenza dei comandi e sui comandi nascosti, vedere about_Command_Precedence.
Esempio 8: Importare comandi con una stringa specifica nei nomi
PS C:\> Import-PSSession -Session $S -CommandName **Item** -AllowClobber
Questo comando importa i comandi i cui nomi includono Item dalla sessione PSSession in $S
. Poiché il comando include il parametro CommandName ma non il parametro FormatTypeData , viene importato solo il comando .
Usare questo comando quando si usa Import-PSSession
per eseguire un comando in un computer remoto e si dispone già dei dati di formattazione per il comando nella sessione corrente.
Esempio 9: Usare il parametro Module per individuare i comandi importati nella sessione
PS C:\> $M = Import-PSSession -Session $S -CommandName *bits* -FormatTypeName *bits*
PS C:\> Get-Command -Module $M
CommandType Name
----------- ----
Function Add-BitsFile
Function Complete-BitsTransfer
Function Get-BitsTransfer
Function Remove-BitsTransfer
Function Resume-BitsTransfer
Function Set-BitsTransfer
Function Start-BitsTransfer
Function Suspend-BitsTransfer
Questo comando illustra come usare il parametro Module di Get-Command
per scoprire quali comandi sono stati importati nella sessione da un Import-PSSession
comando.
Il primo comando usa il Import-PSSession
cmdlet per importare i comandi i cui nomi includono "bit" dalla sessione PSSession nella $S
variabile. Il Import-PSSession
comando restituisce un modulo temporaneo e il comando salva il modulo nella $m
variabile .
Il secondo comando usa il Get-Command
cmdlet per ottenere i comandi esportati dal modulo nella $M
variabile .
Il parametro Module accetta un valore stringa, progettato per il nome del modulo. Tuttavia, quando si invia un oggetto modulo, Windows PowerShell usa il metodo ToString nell'oggetto modulo, che restituisce il nome del modulo.
Il Get-Command
comando è l'equivalente di Get-Command $M.Name
".
Parametri
-AllowClobber
Indica che questo cmdlet importa i comandi specificati, anche se hanno gli stessi nomi dei comandi nella sessione corrente.
Se si importa un comando con lo stesso nome del comando nella sessione corrente, il comando importato nasconde o sostituisce i comandi originali. Per altre informazioni, vedere about_Command_Precedence.
Per impostazione predefinita, Import-PSSession
non importa comandi con lo stesso nome dei comandi nella sessione corrente.
Tipo: | SwitchParameter |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-ArgumentList
Specifica una matrice di comandi risultanti dall'uso degli argomenti specificati (valori dei parametri).
Ad esempio, per importare la variante del Get-Item
comando nell'unità del certificato (Cert:) nella sessione PSSession in $S
, digitare Import-PSSession -Session $S -Command Get-Item -ArgumentList cert:
.
Tipo: | Object[] |
Alias: | Args |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-Certificate
Specifica il certificato client utilizzato per firmare i file di formato (*. Format.ps1xml) o file di modulo script (con estensione psm1) nel modulo temporaneo creato Import-PSSession
.
Immettere una variabile che contiene un certificato oppure un comando o un'espressione che ottiene il certificato.
Per trovare un certificato, usare il Get-PfxCertificate
cmdlet o usare il Get-ChildItem
cmdlet nell'unità Certificato (Cert:). Se il certificato non è valido o non ha autorizzazioni sufficienti, il comando non riesce.
Tipo: | X509Certificate2 |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-CommandName
Specifica i comandi con i nomi o i modelli di nome specificati. I caratteri jolly sono consentiti. Usare CommandName o il relativo alias, Name.
Per impostazione predefinita, Import-PSSession
importa tutti i comandi dalla sessione, ad eccezione dei comandi con gli stessi nomi dei comandi nella sessione corrente. In questo modo si evita che i comandi importati nascondano o sostituiscano i comandi nella sessione. Per importare tutti i comandi, anche quelli che nascondono o sostituiscono altri comandi, usare il parametro AllowClobber .
Se si utilizza il parametro CommandName , i file di formattazione per i comandi non vengono importati a meno che non si usi il parametro FormatTypeName . Analogamente, se si usa il parametro FormatTypeName , non vengono importati comandi a meno che non si usi il parametro CommandName .
Tipo: | String[] |
Alias: | Name |
Posizione: | 2 |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-CommandType
Specifica il tipo di oggetti comando. Il valore predefinito è Cmdlet. Usare CommandType o il relativo alias, Type. I valori validi per questo parametro sono:
Alias
: alias di Windows PowerShell nella sessione remota.All
: cmdlet e funzioni nella sessione remota.Application
: tutti i file diversi dai file di Windows PowerShell nei percorsi elencati nella variabile di ambiente Path ($env:path
) nella sessione remota, inclusi i file .txt, .exe e .dll.Cmdlet
: cmdlet nella sessione remota. "Cmdlet" è il valore predefinito.ExternalScript
: i file con estensione ps1 nei percorsi elencati nella variabile di ambiente Path ($env:path
) nella sessione remota.Filter
eFunction
: le funzioni di Windows PowerShell nella sessione remota.Script
: lo script si blocca nella sessione remota.
Questi valori sono definiti come enumerazione basata su flag. È possibile combinare più valori per impostare più flag usando questo parametro. I valori possono essere passati al parametro CommandType come matrice di valori o come stringa delimitata da virgole di tali valori. Il cmdlet combina i valori usando un'operazione binary-OR. Il passaggio di valori come matrice è l'opzione più semplice e consente anche di usare il completamento tramite tabulazione sui valori.
Tipo: | CommandTypes |
Alias: | Type |
Valori accettati: | Alias, Function, Filter, Cmdlet, ExternalScript, Application, Script, Workflow, Configuration, All |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-DisableNameChecking
Indica che questo cmdlet elimina il messaggio che avvisa quando si importa un cmdlet o una funzione il cui nome include un verbo non approvato o un carattere non consentito.
Per impostazione predefinita, quando un modulo importato esporta cmdlet o funzioni i cui nomi contengono verbi non approvati, Windows PowerShell visualizza il seguente messaggio di avviso:
"AVVISO: alcuni nomi di comando importati includono verbi non approvati che potrebbero renderli meno individuabili. Usare il parametro Verbose per altri dettagli o tipo Get-Verb
per visualizzare l'elenco dei verbi approvati".
Si tratta semplicemente di un avviso. Il modulo completo viene comunque importato, inclusi i comandi non conformi. Il messaggio viene visualizzato dagli utenti del modulo, tuttavia il problema di denominazione deve essere corretto dall'autore del modulo.
Tipo: | SwitchParameter |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-FormatTypeName
Specifica le istruzioni di formattazione per i tipi di Microsoft .NET Framework specificati. Immettere i nomi dei tipi. I caratteri jolly sono consentiti.
Il valore di questo parametro deve essere il nome di un tipo restituito da un Get-FormatData
comando nella sessione da cui vengono importati i comandi. Per ottenere tutti i dati di formattazione nella sessione remota, digitare *
.
Se il comando non include il parametro CommandName o FormatTypeName , Import-PSSession
importa istruzioni di formattazione per tutti i tipi .NET Framework restituiti da un Get-FormatData
comando nella sessione remota.
Se si utilizza il parametro FormatTypeName , non vengono importati comandi a meno che non si usi il parametro CommandName .
Analogamente, se si usa il parametro CommandName , i file di formattazione per i comandi non vengono importati a meno che non si usi il parametro FormatTypeName .
Tipo: | String[] |
Posizione: | 3 |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-FullyQualifiedModule
Il valore può essere un nome di modulo, una specifica completa del modulo o un percorso di un file di modulo.
Quando il valore è un percorso, il percorso può essere completo o relativo. Un percorso relativo viene risolto rispetto allo script che contiene l'istruzione using.
Quando il valore è un nome o una specifica del modulo, PowerShell cerca il modulo specificato in PSModulePath .
Una specifica del modulo è una tabella hash con le chiavi seguenti.
ModuleName
- Obbligatorio Specifica il nome del modulo.GUID
- Facoltativo Specifica il GUID del modulo.- È anche obbligatorio specificare almeno una delle tre chiavi seguenti.
ModuleVersion
- Specifica una versione minima accettabile del modulo.MaximumVersion
- Specifica la versione massima accettabile del modulo.RequiredVersion
- Specifica una versione esatta e obbligatoria del modulo. Non è possibile usare questa opzione con le altre chiavi di versione.
Non è possibile specificare il parametro FullyQualifiedModule nello stesso comando di un parametro Module . I due parametri si escludono a vicenda.
Tipo: | ModuleSpecification[] |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-Module
Specifica e matrice di comandi negli snap-in e nei moduli di Windows PowerShell. Immettere i nomi degli snap-in e dei moduli. I caratteri jolly non sono consentiti.
Import-PSSession
non può importare provider da uno snap-in.
Per altre informazioni, vedere about_PSSnapins e about_Modules.
Tipo: | String[] |
Alias: | PSSnapin |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-Prefix
Specifica un prefisso per i sostantivi nei nomi dei comandi importati.
Usare questo parametro per evitare conflitti di nomi che potrebbero verificarsi quando più comandi nella sessione hanno lo stesso nome.
Ad esempio, se si specifica il prefisso Remote e quindi si importa un Get-Date
cmdlet, il cmdlet è noto nella sessione come Get-RemoteDate
e non viene confuso con il cmdlet originale Get-Date
.
Tipo: | String |
Posizione: | Named |
Valore predefinito: | None |
Necessario: | False |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
-Session
Specifica la sessione PSSession da cui vengono importati i cmdlet. Immettere una variabile contenente un oggetto sessione o un comando che ottiene un oggetto sessione, ad esempio un New-PSSession
comando o Get-PSSession
. È possibile specificare una sola sessione. Questo parametro è obbligatorio.
Tipo: | PSSession |
Posizione: | 0 |
Valore predefinito: | None |
Necessario: | True |
Accettare l'input della pipeline: | False |
Accettare caratteri jolly: | False |
Input
None
Non è possibile inviare tramite pipe oggetti a questo cmdlet.
Output
Questo cmdlet restituisce lo stesso oggetto modulo restituito New-Module
dai cmdlet e Get-Module
.
Tuttavia, il modulo importato è temporaneo ed esiste solo nella sessione corrente. Per creare un modulo permanente su disco, usare il Export-PSSession
cmdlet .
Note
Windows PowerShell include gli alias seguenti per Import-PSSession
:
ipsn
Import-PSSession
si basa sull'infrastruttura remota di PowerShell. Per usare questo cmdlet, il computer deve essere configurato per la comunicazione remota WS-Management. Per altre informazioni, vedere about_Remote e about_Remote_Requirements.Import-PSSession
non importa variabili o provider di PowerShell.Quando si importano i comandi con lo stesso nome dei comandi della sessione corrente, i comandi importati possono nascondere alias, funzioni e cmdlet e sostituire funzioni e variabili nella sessione. Per evitare conflitti di nomi, usare il parametro Prefix . Per altre informazioni, vedere about_Command_Precedence.
Import-PSSession
converte tutti i comandi in funzioni prima di importarli. Di conseguenza, i comandi importati hanno un comportamento leggermente diverso rispetto a quello che avrebbero avuto mantenendo il tipo di comando originale. Ad esempio, se si importa un cmdlet da una sessione PSSession e si importa un cmdlet con lo stesso nome da un modulo o da uno snap-in, il cmdlet importato dalla sessione PSSession viene sempre eseguito per impostazione predefinita perché le funzioni hanno la precedenza rispetto ai cmdlet. Al contrario, se si importa un alias in una sessione in cui è presente un alias con lo stesso nome, viene sempre usato l'alias originale perché gli alias hanno la precedenza rispetto alle funzioni. Per altre informazioni, vedere about_Command_Precedence.Import-PSSession
usa ilWrite-Progress
cmdlet per visualizzare lo stato di avanzamento del comando. È possibile che venga visualizzato l'indicatore di stato durante l'esecuzione del comando.Per trovare i comandi da importare,
Import-PSSession
usa ilInvoke-Command
cmdlet per eseguire unGet-Command
comando nella sessione PSSession. Per ottenere i dati di formattazione per i comandi, usa ilGet-FormatData
cmdlet . È possibile che vengano visualizzati messaggi di errore da questi cmdlet quando si esegue unImport-PSSession
comando.Import-PSSession
Non è inoltre possibile importare comandi da una sessione PSSession che non include iGet-Command
cmdlet ,Get-FormatData
Select-Object
, eGet-Help
.I comandi importati hanno le stesse limitazioni degli altri comandi remoti, inclusa l'impossibilità di avviare un programma con un'interfaccia utente, ad esempio il Blocco note.
Poiché i profili di Windows PowerShell non vengono eseguiti in PSSessions, i comandi aggiunti da un profilo a una sessione non sono disponibili per
Import-PSSession
. Per importare comandi da un profilo, usare unInvoke-Command
comando per eseguire manualmente il profilo nella sessione PSSession prima di importare i comandi.Il modulo temporaneo che
Import-PSSession
crea può includere un file di formattazione, anche se il comando non importa i dati di formattazione. I file di formattazione creati non conterranno dati di formattazione se il comando non li importa.Per usare
Import-PSSession
, i criteri di esecuzione nella sessione corrente non possono essere limitati o AllSigned, perché il modulo temporaneo cheImport-PSSession
crea contiene file di script non firmati non consentiti da questi criteri. Per usareImport-PSSession
senza modificare i criteri di esecuzione per il computer locale, utilizzare il parametro Scope diSet-ExecutionPolicy
per impostare un criterio di esecuzione meno restrittivo per un singolo processo.In Windows PowerShell 2.0, gli argomenti della Guida per i comandi importati da un'altra sessione non includono il prefisso assegnato usando il parametro Prefisso . Per ottenere assistenza su un comando importato in Windows PowerShell 2.0, usare il nome del comando originale (senza prefisso).