Esercitazione: Eseguire il push di un'immagine del contenitore aggiornata in un registro contenitori con replica geografica per le distribuzioni di app Web a livello di area

Questa è la terza parte di un'esercitazione in tre parti. Nell'esercitazione precedente è stata configurata la replica geografica per due diverse distribuzioni regionali di app Web. In questa esercitazione, verrà prima di tutto modificata l'applicazione, poi si compilerà una nuova immagine del contenitore e si eseguirà il push di tale immagine nel registro con replica geografica. Infine, si visualizzerà la modifica, distribuita automaticamente dai webhook di Registro Azure Container, in entrambe le istanze delle app Web.

In questa esercitazione, l'ultima parte della serie, vengono illustrate le seguenti attività:

  • Modificare il codice HTML dell'applicazione Web
  • Compilare l'immagine Docker a aggiungere tag per l'immagine
  • Eseguire il push della modifica in Registro Azure Container
  • Visualizzare l'app aggiornata in due aree diverse

Se non sono ancora state configurate le due distribuzioni regionali di app Web per contenitori, tornare all'esercitazione precedente della serie, Distribuire un'app Web da Registro Azure Container.

Modificare l'applicazione web

In questo passaggio verrà apportata una modifica all'applicazione Web che risulterà molto visibile dopo il push dell'immagine del contenitore aggiornata in Registro Azure Container.

Trovare il file AcrHelloworld/Views/Home/Index.cshtml nell'origine dell'applicazione clonata da GitHub in un'esercitazione precedente e aprirlo nell'editor di testo preferito. Aggiungere la riga seguente sotto la riga <h1> esistente:

<h1>MODIFIED</h1>

Il file Index.cshtml modificato deve essere simile al seguente:

@{
    ViewData["Title"] = "Azure Container Registry :: Geo-replication";
}
<style>
    body {
        background-image: url('images/azure-regions.png');
        background-size: cover;
    }
    .footer {
        position: fixed;
        bottom: 0px;
        width: 100%;
    }
</style>

<h1 style="text-align:center;color:blue">Hello World from:  @ViewData["REGION"]</h1>
<h1>MODIFIED</h1>
<div class="footer">
    <ul>
        <li>Registry URL: @ViewData["REGISTRYURL"]</li>
        <li>Registry IP: @ViewData["REGISTRYIP"]</li>
        <li>Registry Region: @ViewData["REGION"]</li>
    </ul>
</div>

Ricompilare l'immagine

Dopo aver aggiornato l'applicazione Web, è necessario ricompilare l'immagine del contenitore. Come in precedenza, usare il nome dell'immagine completo, incluso il nome di dominio completo (FQDN) del server di accesso, per il tag:

docker build . -f ./AcrHelloworld/Dockerfile -t <acrName>.azurecr.io/acr-helloworld:v1

Eseguire il push dell'immagine in Registro Azure Container

In seguito, eseguire il push dell'immagine del contenitore aggiornata acr helloworld nel registro con replica geografica. In questo caso, viene eseguito un singolo comando docker push per distribuire l'immagine aggiornata nelle repliche del registro in entrambe le aree Stati Uniti occidentali e Stati Uniti orientali.

docker push <acrName>.azurecr.io/acr-helloworld:v1

L'output docker push dovrebbe essere simile al seguente:

$ docker push uniqueregistryname.azurecr.io/acr-helloworld:v1
The push refers to a repository [uniqueregistryname.azurecr.io/acr-helloworld]
5b9454e91555: Pushed
d6803756744a: Layer already exists
b7b1f3a15779: Layer already exists
a89567dff12d: Layer already exists
59c7b561ff56: Layer already exists
9a2f9413d9e4: Layer already exists
a75caa09eb1f: Layer already exists
v1: digest: sha256:4c3f2211569346fbe2d1006c18cbea2a4a9dcc1eb3a078608cef70d3a186ec7a size: 1792

Visualizzare i log dei webhook

Durante la replica dell'immagine è possibile visualizzare i webhook di Registro Azure Container attivati.

Per visualizzare i webhook regionali creati in seguito alla distribuzione del contenitore in app Web per contenitori in un'esercitazione precedente, passare al registro contenitori nel portale di Azure e quindi selezionare Webhook in SERVIZI.

Webhook del registro contenitori nel portale di Azure

Selezionare ogni webhook per visualizzare la cronologia delle chiamate e delle risposte. Nei log di entrambi i webhook dovrebbe essere presente una riga per l'azione push. In questo caso, il log per il webhook nell'area Stati Uniti occidentali mostra l'azione push attivata tramite docker push nel passaggio precedente:

Log dei webhook del registro contenitori nel portale di Azure (Stati Uniti occidentali)

Visualizzare l'app Web aggiornata

I webhook inviano notifica alle app Web del push di una nuova immagine nel registro, che distribuisce automaticamente il contenitore aggiornato nelle due app Web regionali.

Verificare che l'applicazione sia stata aggiornata in entrambe le distribuzioni passando a entrambe le distribuzioni di app Web regionali nel Web browser. Se occorre, è possibile trovare l'URL per l'app Web distribuita in alto a destra di ogni scheda di panoramica del servizio app.

Panoramica del servizio app nel portale di Azure

Per visualizzare l'applicazione aggiornata, selezionare il collegamento nella panoramica del servizio app. Ecco una visualizzazione di esempio dell'app in esecuzione nell'area Stati Uniti occidentali:

Visualizzazione nel browser dell'app Web modificata in esecuzione nell'area Stati Uniti occidentali

Verificare che l'immagine del contenitore aggiornata sia stata distribuita anche nella distribuzione per l'area Stati Uniti orientali visualizzandola nel browser.

Visualizzazione nel browser dell'app Web modificata in esecuzione nell'area Stati Uniti orientali

Con un singolo docker push, è stata aggiornata automaticamente l'applicazione Web in esecuzione in entrambe le distribuzioni dell'app Web a livello di area. Inoltre, Registro Azure Container ha servito le immagini del contenitore dai repository più vicini a ogni distribuzione.

Passaggi successivi

In questa esercitazione si è visto come aggiornare il contenitore dell'applicazione Web ed eseguire il push della nuova versione nel registro con replica geografica. I webhook in Registro Azure Container hanno inviato una notifica dell'aggiornamento alle app Web per contenitori, che hanno attivato un pull locale delle repliche dei registri più vicini.

ACR Build: patch e build delle immagini automatizzate

Oltre alla replica geografica, ACR Build è un'altra caratteristica di Registro Azure Container che può aiutare a ottimizzare la pipeline di distribuzione di contenitore. Per avere un'idea delle funzionalità, è consigliabile iniziare con una panoramica di ACR Build:

Automatizzare l'applicazione di patch al sistema operativo e al framework con ACR Build