Azure Resource Manager (ARM) è il sistema che sta alla base dell'intera infrastruttura di Microsoft Azure e consente la creazione e la configurazione di qualsiasi risorsa. Un template ARM è rappresentato nel formato JSON e permette di essere inoltrato all'infrastruttura tramite script PowerShell o da DevOps per automatizzare i processi di deployment, senza intervenire manualmente.
Tra i task che più frequentemente dobbiamo effettuare c'è sicuramente quello della creazione di un web site. In questo script si vuole proporre un template ARM contenente le configurazioni minime più frequenti, fermo restando che la documentazione ufficiale fornisce maggiori dettagli. Nello specifico dobbiamo utilizzare il tipo Microsoft.Web/serverfarms per la creazione di un server plan, dettagli disponibili a questo indirizzo https://docs.microsoft.com/en-us/azure/templates/microsoft.web/serverfarms Successivamente dobbiamo creare il sito tramite Microsoft.Web/sites con questa documentazione https://docs.microsoft.com/en-us/azure/templates/microsoft.web/sites. Solitamente impostiamo lo stack da usare e alcune impostazioni per alzare il livello di sicurezza e di prestazioni.
{ "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", "contentVersion": "1.0.0.0", "parameters": { "name": { "type": "string" } }, "variables": { "siteName": "[parameters('name')]", "location": "[resourceGroup().location]", "servicePlanId": "[resourceId('Microsoft.Web/serverFarms', variables('siteName'))]" }, "resources": [ { "type": "Microsoft.Web/serverfarms", "apiVersion": "2018-02-01", "name": "[variables('siteName')]", "location": "[variables('location')]", "sku": { "name": "S1" }, "kind": "app", "properties": {} }, { "type": "Microsoft.Web/sites", "apiVersion": "2018-11-01", "name": "[variables('siteName')]", "location": "[variables('location')]", "kind": "app", "dependsOn": [ "[variables('servicePlanId')]" ], "properties": { "serverFarmId": "[variables('servicePlanId')]", "clientAffinityEnabled": false, "httpsOnly": true, "siteConfig": { "webSocketsEnabled": true, "alwaysOn": true, "http20Enabled": true, "minTlsVersion": "1.2", "ftpsState": "Disabled", "appSettings": [ { "name": "Key1", "value": "value" } ], "metadata": [ { "name": "CURRENT_STACK", "value": "dotnetcore" } ] } } } ] }
Nello script usiamo un parametro di ingresso per indicare il nome, mentre il resto viene automaticamente calcolato. Sul site indichiamo di usare .NET Core, disattiviamo l'accesso FTP, abilitiamo HTTP2 e forziamo il livello di HTTPS.
Questo è solamente un punto di partenza ma è già sufficiente per il deployment di un applicativo web.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire query verso tipi non mappati in Entity Framework Core
Potenziare Azure AI Search con la ricerca vettoriale
Implementare il throttling in ASP.NET Core
Migrare una service connection a workload identity federation in Azure DevOps
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Utilizzare HiLo per ottimizzare le insert in un database con Entity Framework
Generare token per autenicarsi sulle API di GitHub
Utilizzare politiche di resiliency con Azure Container App
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
Utilizzare Tailwind CSS all'interno di React: primi componenti
Mascherare l'output di un valore all'interno dei log di un workflow di GitHub
Eseguire attività con Azure Container Jobs
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)
- Paginare i risultati con QuickGrid in Blazor
- Ottimizzazione dei block template in Angular 17