Condividi tramite


Creazione e distribuzione di gruppi di risorse di Azure tramite Visual Studio

Nota

Il progetto gruppo di risorse di Azure è ora in fase di supporto esteso, ovvero si continuerà a supportare funzionalità e funzionalità esistenti, ma non verrà assegnata la priorità all'aggiunta di nuove funzionalità.

Nota

Per un'esperienza ottimale e più sicura, è consigliabile aggiornare l'installazione di Visual Studio alla versione più recente del supporto a lungo termine (LTS). L'aggiornamento migliorerà sia l'affidabilità che le prestazioni complessive dell'ambiente di Visual Studio. Se si sceglie di non eseguire l'aggiornamento, è possibile che si verifichino i problemi documentati in Problemi durante la creazione e la distribuzione di gruppi di risorse di Azure tramite Visual Studio.

Con Visual Studio è possibile creare un progetto che distribuisce l'infrastruttura e il codice in Azure. Ad esempio, è possibile distribuire l'host Web, il sito Web e il codice per il sito Web. Visual Studio offre molti modelli di partenza per la distribuzione di scenari comuni. In questo articolo verrà distribuita un'app Web.

Questo articolo illustra come usare Visual Studio 2019 o versione successiva con i carichi di lavoro Sviluppo di Azure e ASP.NET installati. Se si usa Visual Studio 2017, l'esperienza sarà molto simile.

Creare un progetto Gruppo di risorse di Azure

In questa sezione verrà creato un progetto Gruppo di risorse di Azure con un modello App Web.

  1. In Visual Studio scegliere File>Nuovo>Progetto.

  2. Cercare il gruppo di risorse e quindi selezionare il modello di progetto Gruppo di risorse di Azure (supporto esteso) e Avanti.

    Screenshot della finestra Crea un nuovo progetto con Gruppo di risorse di Azure e il pulsante Avanti evidenziati.

  3. Assegnare un nome al progetto. Le altre impostazioni predefinite sono probabilmente corrette, ma controllarle per assicurarsi che siano appropriate per l'ambiente specifico. Al termine, scegliere Crea.

    Screenshot della finestra di denominazione del progetto in Visual Studio.

  4. Scegliere il modello da distribuire in Gestione risorse di Azure. Si noti che sono disponibili molte opzioni diverse in base al tipo di progetto da distribuire. Per questo articolo scegliere il modello App Web e quindi OK.

    Screenshot della finestra di selezione del modello con il modello di app Web evidenziato.

    Il modello scelto è solo un punto di partenza. È possibile aggiungere e rimuovere risorse per ottenere lo scenario desiderato.

  5. Visual Studio crea un progetto di distribuzione di tipo Gruppo di risorse per l'app Web. Per visualizzare i file per il progetto, esaminare il nodo nel progetto di distribuzione.

    Screenshot di Esplora soluzioni di Visual Studio che mostra i file di progetto di distribuzione del gruppo di risorse.

    Poiché è stato scelto il modello di app Web, vengono visualizzati i file seguenti:

    File name Descrizione
    Deploy-AzureResourceGroup.ps1 Script di PowerShell che esegue i comandi di PowerShell per la distribuzione in Azure Resource Manager. Visual Studio usa questo script di PowerShell per distribuire il modello.
    WebSite.json Modello di Resource Manager che definisce l'infrastruttura da distribuire in Azure e parametri che si possono specificare durante la distribuzione. Definisce anche le dipendenze tra le risorse, per consentire a Resource Manager di distribuire le risorse nell'ordine corretto.
    WebSite.parameters.json File di parametri contenente i valori necessari per il modello, che vengono passati per personalizzare ogni distribuzione. Nota che l'azione di compilazione è impostata su Contenuto. Se aggiungi altri file di parametri, assicurati che l'azione di compilazione sia impostata su Contenuto.

    Tutti i progetti di distribuzione di tipo Gruppo di risorse contengono questi file di base. Altri progetti potrebbero includere file aggiuntivi per supportare altre funzionalità.

Personalizzare il modello di Resource Manager

È possibile personalizzare un progetto di distribuzione modificando il modello di Resource Manager che descrive le risorse da distribuire. Per informazioni sugli elementi del modello di Gestione risorse, vedere Creazione di modelli di Gestione risorse di Azure.

  1. Per lavorare al modello, aprire WebSite.json.

  2. L'editor di Visual Studio offre strumenti utili per la modifica del modello di Resource Manager. La finestra Struttura JSON semplifica la visualizzazione degli elementi definiti nel modello.

    Screenshot della finestra Struttura JSON in Visual Studio per il modello di Resource Manager.

  3. Selezionare un elemento nella struttura per passare a tale parte del modello.

    Screenshot dell'editor di Visual Studio con un elemento selezionato nella finestra Struttura JSON.

  4. È possibile aggiungere una risorsa facendo clic con il pulsante destro del mouse su risorse e scegliendo Aggiungi nuova risorsa.

    Screenshot della finestra Struttura JSON che evidenzia l'opzione Aggiungi nuova risorsa.

  5. Selezionare Account di archiviazione e specificare un nome. Specificare un nome contenente non più di 11 caratteri costituiti solo da numeri e lettere minuscole.

    Screenshot della finestra Aggiungi nuova risorsa con l'opzione Account di archiviazione selezionata.

  6. Si noti che non è stata aggiunta solo la risorsa, ma anche un parametro per il tipo di account di archiviazione e una variabile per il nome dell'account di archiviazione.

    Screenshot della finestra Struttura JSON che mostra la risorsa dell'account di archiviazione aggiunta.

  7. Il parametro per il tipo di account di archiviazione è preimpostato con i tipi consentiti e un tipo predefinito. È possibile usare questi valori o modificarli per il proprio scenario. Per impedire agli utenti di distribuire un account di archiviazione di tipo Premium_LRS tramite questo modello, rimuoverlo dai tipi consentiti.

    "demoAccountType": {
      "type": "string",
      "defaultValue": "Standard_LRS",
      "allowedValues": [
        "Standard_LRS",
        "Standard_ZRS",
        "Standard_GRS",
        "Standard_RAGRS",
        "Premium_LRS"
      ]
    }
    

Distribuire il progetto in Azure

A questo punto si è pronti a distribuire il progetto in un gruppo di risorse.

Per impostazione predefinita, lo script di PowerShell (Deploy-AzureResourceGroup.ps1) nel progetto usa il modulo AzureRM. Se il modulo AzureRM è ancora installato e si vuole continuare a usarlo, è possibile usare questo script predefinito. Con questo script è possibile usare l'interfaccia di Visual Studio per distribuire la soluzione.

Tuttavia, se è stata eseguita la migrazione al nuovo modulo Az, è necessario aggiungere un nuovo script al progetto. Per aggiungere uno script che usa il modulo Az, copiare lo script Deploy-AzTemplate.ps1 e aggiungerlo al progetto. Per usare questo script per la distribuzione, è necessario eseguirlo dalla console di PowerShell, anziché tramite l'interfaccia di distribuzione di Visual Studio.

Entrambi gli approcci sono illustrati in questo argomento. In questo articolo lo script predefinito viene indicato come script del modulo AzureRM e il nuovo script come script del modulo Az.

Script del modulo Az

Per lo script del modulo Az aprire una console di PowerShell ed eseguire:

.\Deploy-AzTemplate.ps1 -ArtifactStagingDirectory . -Location centralus -TemplateFile WebSite.json -TemplateParametersFile WebSite.parameters.json

Script del modulo AzureRM

Per lo script del modulo AzureRM usare Visual Studio:

  1. Dal menu di scelta rapida del nodo del progetto di distribuzione scegliere Distribuisci>Nuovo.

    Screenshot del menu di scelta rapida del progetto di distribuzione con le opzioni Distribuisci e Nuovo evidenziate.

  2. Verrà visualizzata la finestra di dialogo Distribuisci in gruppo di risorse . Nella casella di riepilogo a discesa Gruppo di risorse scegliere un gruppo di risorse esistente o crearne uno nuovo. Seleziona Distribuisci.

    Screenshot della finestra di dialogo Distribuisci nel gruppo di risorse in Visual Studio.

  3. Nelle finestre Output viene visualizzato lo stato della distribuzione. Al termine della distribuzione, l'ultimo messaggio indica una distribuzione riuscita con un testo simile al seguente:

    18:00:58 - Successfully deployed template 'website.json' to resource group 'ExampleAppDeploy'.
    

Visualizzare le risorse distribuite

A questo punto è possibile esaminare i risultati.

  1. In un browser aprire il portale di Azure e accedere con il proprio account. Per visualizzare il gruppo di risorse, selezionare Gruppi di risorse e il gruppo di risorse in cui è stata effettuata la distribuzione.

  2. Vengono visualizzate tutte le risorse distribuite. Si noti che il nome dell'account di archiviazione non è esattamente quello specificato quando si è aggiunta la risorsa. L'account di archiviazione deve essere univoco. Il modello aggiunge automaticamente una stringa di caratteri al nome specificato per creare un nome univoco.

    Screenshot del portale di Azure che mostra le risorse distribuite in un gruppo di risorse.

Aggiungere codice al progetto

A questo punto è stata distribuita l'infrastruttura per l'app, ma non è stato ancora distribuito il codice effettivo con il progetto.

  1. Aggiungere un progetto alla soluzione Visual Studio. Fare clic con il pulsante destro del mouse sulla soluzione e scegliere Aggiungi>Nuovo progetto.

    Screenshot del menu di scelta rapida Aggiungi nuovo progetto in Visual Studio.

  2. Aggiungere un'Applicazione Web ASP.NET Core.

    Screenshot della finestra Nuovo progetto con l'applicazione Web ASP.NET Core selezionata.

  3. Assegnare un nome all'app Web e selezionare Crea.

    Screenshot della finestra di denominazione del progetto per l'applicazione Web principale ASP.NET.

  4. Selezionare Applicazione Web e Crea.

    Screenshot della finestra Nuova applicazione Web ASP.NET Core con l'opzione Applicazione Web selezionata.

  5. Dopo che Visual Studio ha creato l'app Web, vengono visualizzati entrambi i progetti nella soluzione.

    Screenshot di Esplora soluzioni di Visual Studio che mostra entrambi i progetti nella soluzione.

  6. Ora è necessario verificare che il progetto del gruppo di risorse sia a conoscenza del nuovo progetto. Tornare al progetto del gruppo di risorse (ExampleAppDeploy). Fare clic con il pulsante destro del mouse su Riferimenti e scegliere Aggiungi riferimento.

    Screenshot del menu di scelta rapida ExampleAppDeploy che evidenzia l'opzione Aggiungi riferimento.

  7. Selezionare il progetto dell'app Web creato.

    Screenshot della finestra Aggiungi riferimento in Visual Studio con il progetto dell'app Web selezionato.

    Aggiungendo un riferimento si collega il progetto di app Web al progetto del gruppo di risorse e si impostano automaticamente alcune proprietà. Queste proprietà vengono visualizzate nella finestra Proprietà del riferimento. In Include File Path è disponibile il percorso in cui viene creato il pacchetto. Prendere nota della cartella (ExampleApp) e del file (package.zip). È necessario conoscere questi valori perché vengono specificati come parametri durante la distribuzioni dell'app.

    Screenshot della finestra Proprietà che mostra le proprietà di riferimento per il progetto dell'app Web.

  8. Tornare al modello (WebSite.json) e aggiungere una risorsa al modello.

    Screenshot della finestra Struttura JSON con l'opzione Aggiungi nuova risorsa evidenziata.

  9. Questa volta selezionare Distribuzione Web per app Web.

    Screenshot della finestra Aggiungi nuova risorsa con l'opzione Distribuzione Web per app Web selezionata.

    Salvare il modello.

  10. Nel passaggio precedente sono stati aggiunti alcuni nuovi parametri.

    Screenshot dei nuovi parametri.

    Non è necessario specificare valori per _artifactsLocation o _artifactsLocationSasToken, perché vengono generati automaticamente. Tuttavia, è necessario impostare la cartella e il nome di file sul percorso che contiene il pacchetto di distribuzione. I nomi di questi parametri terminano con PackageFolder e PackageFileName. La prima parte del nome è il nome della risorsa di distribuzione Web aggiunta. In questo articolo i nomi sono ExampleAppPackageFolder ed ExampleAppPackageFileName.

    Aprire Website.parameters.json e impostare questi parametri sui valori indicati nelle proprietà di riferimento. Impostare ExampleAppPackageFolder sul nome della cartella. Impostare ExampleAppPackageFileName sul nome del file ZIP.

    {
      "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentParameters.json#",
      "contentVersion": "1.0.0.0",
      "parameters": {
        "ExampleAppPackageFolder": {
          "value": "ExampleApp"
        },
        "ExampleAppPackageFileName": {
          "value": "package.zip"
        }
      }
    }
    

Distribuire il codice con l'infrastruttura

Dato che è stato aggiunto codice al progetto, la distribuzione è leggermente diversa in questo caso. Durante la distribuzione, gli artefatti per il progetto vengono posizionati in un'area di gestione temporanea accessibile per Resource Manager. Gli artefatti vengono posizionati in un account di archiviazione per la gestione temporanea.

Script del modulo Az

È necessario apportare una piccola modifica al modello se si usa lo script del modulo Az. Questo script aggiunge una barra al percorso degli artefatti, ma il modello non si aspetta tale barra. Aprire WebSite.json e individuare le proprietà per l'estensione MSDeploy. È presente una proprietà denominata packageUri. Rimuovere la barra tra il percorso degli artefatti e la cartella del pacchetto.

L'aspetto dovrebbe essere simile al seguente:

"packageUri": "[concat(parameters('_artifactsLocation'), parameters('ExampleAppPackageFolder'), '/', parameters('ExampleAppPackageFileName'), parameters('_artifactsLocationSasToken'))]",

Nota che nell'esempio precedente non è presente alcuna '/', fra parameters('_artifactsLocation') e parameters('ExampleAppPackageFolder').

Ricompilare il progetto. Con la compilazione del progetto ci si assicura che i file che è necessario distribuire vengano aggiunti alla cartella di gestione temporanea.

A questo punto, aprire una console di PowerShell ed eseguire:

.\Deploy-AzTemplate.ps1 -ArtifactStagingDirectory .\bin\Debug\staging\ExampleAppDeploy -Location centralus -TemplateFile WebSite.json -TemplateParametersFile WebSite.parameters.json -UploadArtifacts -StorageAccountName <storage-account-name>

Script del modulo AzureRM

Per lo script del modulo AzureRM usare Visual Studio:

  1. Per la ridistribuzione, scegliere Distribuisci e il gruppo di risorse distribuito in precedenza.

    Screenshot del menu di scelta rapida del progetto di distribuzione con le opzioni Distribuisci e Nuovo evidenziate.

  2. Selezionare l'account di archiviazione distribuito con questo gruppo di risorse per Account di archiviazione elementi.

    Screenshot della finestra di dialogo Distribuisci nel gruppo di risorse con l'account di archiviazione artefatto selezionato.

Visualizzare l'app Web

  1. Al termine della distribuzione, selezionare l'app Web nel portale. Selezionare l'URL per passare al sito.

    Screenshot del portale di Azure che mostra la risorsa dell'app Web con l'URL evidenziato.

  2. Si noti che l'app ASP.NET predefinita è stata distribuita correttamente.

    Screenshot dell'app predefinita distribuita ASP.NET in un Web browser.

Aggiungere un dashboard operativo

Non si è limitati solo alle risorse disponibili tramite l'interfaccia di Visual Studio. È possibile personalizzare la distribuzione mediante l'aggiunta di una risorsa personalizzata al modello. Per visualizzare l'aggiunta di una risorsa, aggiungere un dashboard operativo per gestire la risorsa che è stata distribuita.

  1. Aprire il file WebSite.json e aggiungere il codice JSON seguente dopo la risorsa dell'account di archiviazione ma prima della parentesi ] di chiusura della sezione relativa alle risorse.

     ,{
       "properties": {
         "lenses": {
           "0": {
             "order": 0,
             "parts": {
               "0": {
                 "position": {
                   "x": 0,
                   "y": 0,
                   "colSpan": 4,
                   "rowSpan": 6
                 },
                 "metadata": {
                   "inputs": [
                     {
                       "name": "resourceGroup",
                       "isOptional": true
                     },
                     {
                       "name": "id",
                       "value": "[resourceGroup().id]",
                       "isOptional": true
                     }
                   ],
                   "type": "Extension/HubsExtension/PartType/ResourceGroupMapPinnedPart"
                 }
               },
               "1": {
                 "position": {
                   "x": 4,
                   "y": 0,
                   "rowSpan": 3,
                   "colSpan": 4
                 },
                 "metadata": {
                   "inputs": [],
                   "type": "Extension[azure]/HubsExtension/PartType/MarkdownPart",
                   "settings": {
                     "content": {
                       "settings": {
                         "content": "__Customizations__\n\nUse this dashboard to create and share the operational views of services critical to the application performing. To customize simply pin components to the dashboard and then publish when you're done. Others will see your changes when you publish and share the dashboard.\n\nYou can customize this text too. It supports plain text, __Markdown__, and even limited HTML like images <img width='10' src='https://portal.azure.com/favicon.ico'/> and <a href='https://azure.microsoft.com' target='_blank'>links</a> that open in a new tab.\n",
                         "title": "Operations",
                         "subtitle": "[resourceGroup().name]"
                       }
                     }
                   }
                 }
               }
             }
           }
         },
         "metadata": {
           "model": {
             "timeRange": {
               "value": {
                 "relative": {
                   "duration": 24,
                   "timeUnit": 1
                 }
               },
               "type": "MsPortalFx.Composition.Configuration.ValueTypes.TimeRange"
             }
           }
         }
       },
       "type": "Microsoft.Portal/dashboards",
       "apiVersion": "2015-08-01-preview",
       "name": "[concat('ARM-',resourceGroup().name)]",
       "location": "[resourceGroup().location]",
       "tags": {
         "hidden-title": "[concat('OPS-',resourceGroup().name)]"
       }
     }
    
  2. Ridistribuire il progetto.

  3. Al termine della distribuzione, visualizzare il dashboard nel portale. Selezionare Dashboard e scegliere quello che è stato distribuito.

    Screenshot della pagina Dashboard del portale di Azure che evidenzia un dashboard personalizzato di esempio.

  4. Viene visualizzato il dashboard personalizzato.

    Screenshot del dashboard operativo personalizzato nel portale di Azure.

Puoi gestire l'accesso al dashboard usando il controllo degli accessi in base al ruolo di Azure. È anche possibile personalizzare l'aspetto del dashboard dopo la distribuzione. Tuttavia, se si ridistribuisce il gruppo di risorse, il dashboard viene ripristinato allo stato predefinito nel modello. Per altre informazioni sulla creazione di dashboard, vedere Creazione di dashboard di Azure a livello di codice.

Pulire le risorse

Quando non sono più necessarie, eseguire la pulizia delle risorse di Azure distribuite eliminando il gruppo di risorse.

  1. Nel portale di Azure selezionare Gruppi di risorse nel menu a sinistra.

  2. Selezionare il nome del gruppo di risorse.

  3. Selezionare Elimina gruppo di risorse nel menu in alto.

Passaggi successivi

In questo articolo hai imparato a creare e distribuire modelli con Visual Studio. Per altre informazioni sullo sviluppo dei modelli, vedere la nuova serie di esercitazioni per principianti: