PowerShell integration
Este conteúdo não está disponível em sua língua ainda.
The Aspire PowerShell hosting integration enables you to run PowerShell Core (pwsh) scripts alongside your Aspire projects in the Aspire app host. This integration allows you to script your resources, reference connection strings, access live resources, and leverage the full power of PowerShell within your distributed application.
Hosting integration
Section titled “Hosting integration”To get started with the Aspire PowerShell hosting integration, install the CommunityToolkit.Aspire.Hosting.PowerShell NuGet package in the app host project.
aspire add communitytoolkit-powershellA Aspire CLI é interativa; escolha o resultado adequado quando solicitado:
Select an integration to add:
> communitytoolkit-powershell (CommunityToolkit.Aspire.Hosting.PowerShell)> Other results listed as selectable options...#:package CommunityToolkit.Aspire.Hosting.PowerShell@*<PackageReference Include="CommunityToolkit.Aspire.Hosting.PowerShell" Version="*" />Add PowerShell resource
Section titled “Add PowerShell resource”To add a PowerShell resource to your app host, use the AddPowerShell extension method:
using CommunityToolkit.Aspire.Hosting.PowerShell;
var builder = DistributedApplication.CreateBuilder(args);
var storage = builder.AddAzureStorage("storage").RunAsEmulator();var blob = storage.AddBlobs("myblob");
var ps = builder.AddPowerShell("ps") .WithReference(blob) .WaitFor(storage);
// After adding all resources, run the app...The AddPowerShell method requires:
- name: The name of the PowerShell resource in the Aspire dashboard
Add scripts
Section titled “Add scripts”To execute PowerShell scripts within your resource, use the AddScript method:
var ps = builder.AddPowerShell("ps") .WithReference(blob);
var script1 = ps.AddScript("script1", """ param($name)
Write-Information "Hello, $name" Write-Information "`$myblob is $myblob"
az storage container create --connection-string $myblob -n demo az storage blob upload --connection-string $myblob -c demo --file ./scripts/script.ps1
Write-Information "Blob uploaded"""").WithArgs("world");
var script2 = ps.AddScript("script2", """ & ./scripts/script.ps1 @args""") .WithArgs(2, 3) .WaitForCompletion(script1);
// After adding all resources, run the app...The AddScript method requires:
- name: The name of the script resource in the Aspire dashboard
- script: The PowerShell script content to execute
References and dependencies
Section titled “References and dependencies”Use WithReference to pass connection strings and resource references to your PowerShell scripts. Referenced resources are available as variables in your script scope:
var storage = builder.AddAzureStorage("storage").RunAsEmulator();var blob = storage.AddBlobs("myblob");
var ps = builder.AddPowerShell("ps") .WithReference(blob); // The $myblob variable is now available in scripts
var script = ps.AddScript("demo", """ Write-Information "Connection string: $myblob"""");
// After adding all resources, run the app...Use WaitFor to specify that a PowerShell resource should wait for other resources to be ready before executing:
var storage = builder.AddAzureStorage("storage").RunAsEmulator();
var ps = builder.AddPowerShell("ps") .WaitFor(storage); // Wait for storage to be ready before running scripts
// After adding all resources, run the app...Custom arguments
Section titled “Custom arguments”Pass arguments to your PowerShell scripts using the WithArgs method:
var ps = builder.AddPowerShell("ps");
var script = ps.AddScript("process-data", """ param($count, $name)
Write-Information "Processing $count items for $name"""").WithArgs(5, "demo");
// After adding all resources, run the app...Scripts can define parameters using PowerShell’s param() block and receive arguments passed via WithArgs.
Script execution order
Section titled “Script execution order”Control the execution order of scripts using WaitForCompletion. A script that calls WaitForCompletion will not run until the referenced script completes:
var ps = builder.AddPowerShell("ps");
var script1 = ps.AddScript("setup", """ Write-Information "Setting up resources" "setup-data.txt" | Set-Content "ready"""");
var script2 = ps.AddScript("process", """ Write-Information "Processing after setup"""").WaitForCompletion(script1); // Waits for script1 to complete
// After adding all resources, run the app...Working directory
Section titled “Working directory”Scripts execute in the context of your app host’s working directory. You can access files relative to this directory within your scripts:
var ps = builder.AddPowerShell("ps");
var script = ps.AddScript("file-ops", """ $pwd | Write-Information Get-ChildItem ./scripts""");
// After adding all resources, run the app...Debugging
Section titled “Debugging”While your app host is running a script that contains a Wait-Debugger call, you can attach a PowerShell debugger to debug the script interactively.
Open a terminal with PowerShell Core (pwsh) 7.4 or later and use the following commands:
Get-PSHostProcessInfoEnter-PSHostProcess -Id <ProcessId>Get-RunspaceDebug-Runspace -Id <RunspaceId>For more information about PowerShell debugging, see Enter-PSHostProcess documentation.