Lo sviluppo per Windows Azure è possibile grazie al SDK che oltre a rendere disponibile alcuni template, si integra in Visual Studio 2010 per fornire funzionalità aggiuntive specifiche. Tra queste è presente anche la funzione di deployment e altre attività inerenti al debugging, mentre tutti gli altri aspetti si possono gestire attraverso il portale Windows Azure.
Spesso si ha la necessità di compiere operazioni ripetitive oppure di programmarle ad una determinata ora, ma poiché la gestione delle macchine virtuali è tutt'altro che rapida, queste operazioni possono risultare scomode e dispendiose. A questo scopo vengono in aiuto le estensioni di Windows Azure per Windows PowerShell disponibili all'indirizzo
http://code.msdn.microsoft.com/azurecmdlets
Grazie alle capacità di PowerShell, nato appositamente per eseguire script in sostituzione dei vecchi batch, è possibile controllare i servizi, attivare o spegnere ruoli o deployare nuovi pacchetti. Per quest'ultimo i comandi che si possono usare sono:
- Get-HostedService: ottiene il riferimento al servizio in base al certificato e all'ID di sottoscrizione;
- Get-Deployment: restituisce il deployment di produzione o di staging di un servizio;
- Remove-Deployment: rimuove il deployment di riferimento;
- Set-DeploymentStatus: cambia lo stato del deployment in sospeso o avviato;
- Get-OperationStatus: restituisce lo stato dell'operazione in corso.
Ipotizzando di usare Windows PowerShell ISE (l'editor specifico), è possibile sfruttare questi comandi per sostituire un deployment e poi avviarlo. Per farlo occorre prima caricare lo snapin ed è inoltre comodo partire definendo alcune variabili utili allo scripting, tra cui il certificato (installato sul portale) per la comunicazione, l'ID, il nome del servizio, i percorsi al pacchetto e alla configurazione:
Add-PSSnapin AzureManagementToolsSnapIn $cert = get-item cert:\CurrentUser\MY\[thumbPrint] $sub = "guid sottoscrizione" $servicename = 'nome servizio' $package = "myapp.cspkg" $config = "myapp.cscfg"
I passaggi da eseguire sono sostanzialmente tre e per priam cosa occorre sospendere il servizio attualmente attivo. Con la concatenazione dei comandi, possibile tramite la pipe, si ottiene il servizio, poi il deployment e lo si sospende:
Get-HostedService $servicename -Certificate $cert -SubscriptionId $sub | Get-Deployment -Slot Production | Set-DeploymentStatus 'Suspended' | Get-OperationStatus -WaitToComplete
Con l'opzione -WaitToComplete si attende la fine dell'operazione, la quale può impiegare anche qualche minuto. Successivamente con la stessa tecnica si rimuove il deployment:
Get-HostedService $servicename -Certificate $cert -SubscriptionId $sub | Get-Deployment -Slot Production | Remove-Deployment | Get-OperationStatus -WaitToComplete
Si procede poi con il caricamento del pacchetto e la relativa configurazione:
Get-HostedService $servicename -Certificate $cert -SubscriptionId $sub | New-Deployment Production $package $config -Label 'nuova installazione' | Get-OperationStatus -WaitToComplete
Una volta caricato è possibile procedere all'avviamento del servizio:
Get-HostedService $servicename -Certificate $cert -SubscriptionId $sub | Get-Deployment -Slot Production | Set-DeploymentStatus 'Running' | Get-OperationStatus -WaitToComplete
E' possibile salvare lo script in file ps1 così da poterlo utilizzare più volte. Infine, essendo molteplici i comandi, si invita a visionare la lista sul sito apposito, indicato in precedenza.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sfruttare lo stream rendering per le pagine statiche di Blazor 8
Eseguire una query su SQL Azure tramite un workflow di GitHub
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Migliora le tue soluzioni ASP.NET Core con Azure OpenAI
Paginare i risultati con QuickGrid in Blazor
Recuperare un elemento inserito nella cache del browser tramite API JavaScript
Utilizzare domini personalizzati gestiti automaticamente con Azure Container Apps
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Eseguire attività pianificate con Azure Container Jobs
Eseguire operazioni sui blob con Azure Storage Actions
Sostituire la GitHub Action di login su private registry
I più letti di oggi
- Utilizzare WebAssembly con .NET, ovunque
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
- Utilizzare il trigger SQL con le Azure Function
- Disabilitare automaticamente un workflow di GitHub (parte 2)
- Ottimizzazione dei block template in Angular 17
- Paginare i risultati con QuickGrid in Blazor