Uso dei servizi di bilanciamento del carico in Azure
Microsoft Azure offre numerosi servizi che consentono di gestire la distribuzione del traffico e il bilanciamento del carico. È possibile usare questi servizi singolarmente o combinarne i metodi in base alle esigenze, così da realizzare una soluzione ottimale.
In questa esercitazione viene innanzitutto illustrato un caso d'uso di un cliente e viene mostrato in che modo è possibile assicurare maggiore affidabilità e prestazioni più elevate mediante il portafoglio di soluzioni Azure per il bilanciamento del carico: Gestione traffico, il gateway applicazione e Load Balancer. Vengono quindi illustrate istruzioni dettagliate per la creazione di una distribuzione che sia geograficamente ridondante, distribuisca il traffico alle macchine virtuali e aiuti a gestire differenti tipi di richieste.
A livello concettuale, ognuno di questi servizi svolge un ruolo distinto nella gerarchia di bilanciamento del carico.
Gestione traffico offre il bilanciamento del carico DNS globale. Esamina le richieste DNS in ingresso e risponde con un endpoint integro e in base ai criteri di routing selezionati dal cliente. Le opzioni per i metodi di routing sono le seguenti:
- Routing delle prestazioni per reindirizzare il richiedente all'endpoint più vicino in termini di latenza.
- Priorità di routing per indirizzare tutto il traffico a un endpoint, con altri endpoint come backup.
- Routing round robin ponderato, che distribuisce il traffico in base alla ponderazione assegnata a ciascun endpoint.
- Routing basato sulla geografia per distribuire il traffico agli endpoint dell'applicazione in base alla posizione geografica dell'utente.
- Routing basato sulla subnet per distribuire il traffico agli endpoint dell'applicazione in base alla subnet (intervallo di indirizzi IP) dell'utente.
- Routing multivalore che consente di inviare indirizzi IP di più endpoint applicazione in una singola risposta DNS.
Il client si connette direttamente all'endpoint restituito da Gestione traffico. Gestione traffico di Azure rileva gli endpoint non integri e reindirizza i client a un'altra istanza integra. Per altre informazioni sul servizio, vedere Gestione traffico di Azure documentazione.
Il gateway applicazione offre un servizio di controller per la distribuzione di applicazioni con numerose funzionalità di bilanciamento del carico di livello 7. Consente ai clienti di ottimizzare la produttività della web farm eseguendo l'offload della terminazione TLS a elevato utilizzo di CPU nel gateway applicazione. Altre funzionalità di routing di livello 7 includono la distribuzione round robin del traffico in ingresso, l'affinità di sessione basata su cookie, il routing basato su percorso URL e la possibilità di ospitare più siti Web dietro un unico gateway applicazione. Il gateway applicazione può essere configurato come gateway con connessione Internet, come gateway solo interno o come una combinazione di queste due opzioni. È completamente gestito in Azure e offre scalabilità e disponibilità elevata, oltre a un set completo di funzionalità di registrazione e diagnostica che ne migliorano la gestibilità.
Load Balancer è parte integrante dello stack SDN di azure e offre servizi di bilanciamento del carico di livello 4 a elevate prestazioni e bassa latenza per tutti i protocolli UDP e TCP. Gestisce le connessioni in ingresso e in uscita. È possibile configurare endpoint pubblici e interni con carico bilanciato e definire regole per mappare le connessioni in ingresso a destinazioni pool back-end con opzioni di probe dell'integrità TCP e HTTP per gestire la disponibilità del servizio.
In questo scenario di esempio viene usato un semplice sito Web che gestisce due tipi di contenuto: immagini e pagine Web con rendering dinamico. Questo sito Web deve essere geograficamente ridondante e deve servire gli utenti dalla località ad essi più vicina (latenza più bassa). Lo sviluppatore dell'applicazione ha deciso che qualsiasi URL corrispondente al pattern /images/* venga servito da un pool dedicato di macchine virtuali separato dal resto della Web farm.
Inoltre, il pool predefinito di macchine virtuali che rende disponibile il contenuto dinamico deve comunicare con un database back-end ospitato in un cluster a disponibilità elevata. La configurazione dell'intera distribuzione viene eseguita tramite Azure Resource Manager.
Usando Gestione traffico, gateway applicazione e Load Balancer, è possibile abilitare questo sito Web per raggiungere gli obiettivi di progettazione seguenti:
- Ridondanza multi-geografica: se un'area geografica risulta non disponibile, Gestione traffico reindirizza senza problemi il traffico all'area geografica appropriata più vicina senza alcun intervento da parte del proprietario dell'applicazione.
- Latenza ridotta: il cliente viene automaticamente indirizzato da Gestione traffico all'area geografica più vicina. Per questo motivo, quando il cliente richiede il contenuto delle pagine Web, si registra una latenza più bassa.
- Scalabilità indipendente: poiché il carico di lavoro delle applicazioni Web è separato in base al tipo di contenuto, il proprietario dell'applicazione può ridimensionare i carichi di lavoro relativi alle richieste in modo indipendente l'uno dall'altro. Il gateway applicazione assicura che il traffico venga indirizzato ai pool corretti in base alle regole specificate e all'integrità dell'applicazione.
- Bilanciamento del carico interno: con il posizionamento di Load Balancer davanti al cluster a disponibilità elevata, viene esposto all'applicazione solo l'endpoint attivo e integro per un database. Inoltre, un amministratore del database può ottimizzare il carico di lavoro distribuendo le repliche attive e passive nel cluster indipendentemente dall'applicazione front-end. Load Balancer offre connessioni al cluster a disponibilità elevata e assicura che soltanto i database integri ricevano le richieste di connessione.
Il diagramma seguente illustra l'architettura di questi scenario:
Nota
Questo esempio è solo una delle numerose configurazioni possibili dei servizi di bilanciamento del carico offerti da Azure. È possibile combinare e associare Gestione traffico, il gateway applicazione e Load Balancer per soddisfare al meglio le specifiche esigenze di bilanciamento del carico. Ad esempio, se l'offload TLS o l'elaborazione del livello 7 non è necessaria, load Balancer può essere usato al posto di gateway applicazione.
Nel portale di Azure fare clic su Crea una risorsa>Rete>Profilo di Gestione traffico>Crea.
Immettere le informazioni di base seguenti:
- Nome: assegnare al profilo di Gestione traffico un nome del prefisso DNS.
- Metodo di routing: selezionare il criterio per il metodo di routing del traffico. Per altre informazioni sui metodi, vedere Informazioni sui metodi di routing del traffico di Gestione traffico.
- Sottoscrizione: selezionare la sottoscrizione contenente il profilo.
- Gruppo di risorse: selezionare il gruppo di risorse contenente il profilo. Può trattarsi di un gruppo di risorse nuovo o esistente.
- Percorso gruppo di risorse: il servizio Gestione traffico è globale e non legato a una località. Tuttavia, è necessario specificare un'area per il gruppo in cui risiedono i metadati associati al profilo di Gestione traffico. La località non ha alcun impatto sulla disponibilità di runtime del profilo.
Fare clic su Crea per generare il profilo di Gestione traffico.
Nel portale di Azure fare clic su Crea una nuova risorsa>Rete>Gateway applicazione nel pannello a sinistra.
Inserire le seguenti informazioni di base sul gateway applicazione:
- Nome : nome del gateway applicazione.
- Dimensioni SKU: dimensioni del gateway applicazione. Le opzioni disponibili sono Small, Medium e Large.
- Numero di istanze: il numero di istanze, un valore da 2 a 10.
- Gruppo di risorse: il gruppo di risorse che contiene il gateway applicazione. Può trattarsi di un gruppo di risorse nuovo o esistente.
- Posizione: l'area del gateway applicazione. È la stessa posizione del gruppo di risorse. La posizione è importante perché la rete virtuale e l'IP pubblico devono trovarsi nella stessa posizione del gateway.
Fare clic su OK.
Definire le configurazioni della rete virtuale, della subnet, dell'IP front-end e del listener per il gateway applicazione. In questo scenario l'indirizzo IP front-end è Pubblico. Questo consente, in un secondo tempo, di aggiungerlo come endpoint al profilo di Gestione traffico.
Nota
Se si usa HTTPS, selezionare HTTPS accanto a Protocollo nella scheda Listener . L'opzione predefinita è HTTP. È inoltre necessario creare e assegnare un certificato SSL. Per altre informazioni, vedere l'esercitazione gateway applicazione per SSL.
Quando si sceglie un pool back-end, un gateway applicazione configurato con una regola basata sul percorso tiene conto non solo della distribuzione round robin ma anche del modello di percorso dell'URL della richiesta. In questo scenario si aggiunge una regola basata sul percorso per indirizzare qualsiasi URL con "/images/*" al pool di server di immagini. Per altre informazioni sulla configurazione del routing basato sul percorso URL per un gateway applicazione, vedere Creare una regola basata sul percorso per un gateway applicazione.
Dal gruppo di risorse passare all'istanza del gateway applicazione creata nella sezione precedente.
Nella sezione Impostazioni selezionare Pool back-end, quindi selezionare Aggiungi per aggiungere le macchine virtuali da associare ai pool back-end di livello Web.
Immettere il nome del pool back-end e tutti gli indirizzi IP dei computer presenti nel pool. In questo scenario si connettono due pool di server back-end di macchine virtuali.
Nella sezione Impostazioni del gateway applicazione selezionare Regole e quindi fare clic sul pulsante Basata sul percorso per aggiungere una nuova regola.
Immettere le informazioni seguenti per configurare la regola.
Impostazioni di base:
- Nome: nome descrittivo della regola accessibile nel portale.
- Listener: listener usato per la regola.
- Pool back-end predefinito: pool back-end da usare con la regola predefinita.
- Impostazioni HTTP predefinite: impostazioni HTTP da usare con la regola predefinita.
Regole basate sul percorso:
- Nome: nome descrittivo della regola basata sul percorso.
- Percorsi: regola basata sul percorso usata per l'inoltro del traffico.
- Pool back-end: pool back-end da usare con questa regola.
- Impostazione HTTP: impostazioni HTTP da usare con questa regola.
Importante
Percorsi: i percorsi validi devono iniziare con "/". Il carattere jolly "*" è consentito solo alla fine. Gli esempi validi sono /xyz, /xyz*o /xyz/*.
In questo scenario Gestione traffico è connesso ai gateway applicazione (come configurati nei passaggi precedenti) presenti in aree geografiche diverse. Dopo aver configurato i gateway applicazione, il passaggio successivo consiste nel connettere tali gateway al profilo di Gestione traffico.
Aprire il profilo di Gestione traffico. A tale scopo, esaminare il gruppo di risorse o cercare il nome del profilo di Gestione traffico in Tutte le risorse.
Nel riquadro a sinistra, selezionare Endpoint e fare clic su Aggiungi per aggiungere un endpoint.
Immettere le informazioni seguenti per creare un endpoint:
- Tipo: selezionare il tipo di endpoint per il bilanciamento del carico. In questo scenario selezionare Endpoint di Azure perché è in corso la connessione alle istanze del gateway applicazione configurate in precedenza.
- Nome: inserire il nome dell'endpoint.
- Tipo di risorsa di destinazione: selezionare Indirizzo IP pubblico, quindi, nell'impostazione Risorsa di destinazione, selezionare l'IP pubblico del gateway applicazione configurato in precedenza.
A questo punto è possibile testare la configurazione accedendola con il DNS del profilo di Gestione traffico (in questo esempio:
TrafficManagerScenario.trafficmanager.net
). È possibile inviare di nuovo le richieste, visualizzare le macchine virtuali o arrestare le macchine virtuali e i server Web creati in aree diverse. È anche possibile modificare e testare impostazioni del profilo di Gestione traffico diverse.
In questo scenario Load Balancer distribuisce le connessioni dal livello Web al database all'interno di un cluster a disponibilità elevata.
Se il cluster di database a disponibilità elevata usa SQL Server AlwaysOn, vedere Configurare uno o più listener del gruppo di disponibilità AlwaysOn per istruzioni dettagliate.
Per altri dettagli sulla configurazione di un servizio di bilanciamento del carico interno, vedere Creare un servizio di bilanciamento del carico interno nel portale di Azure.
- Nel portale di Azure fare clic su Crea una nuova risorsa>Rete>Bilanciamento del carico nel pannello a sinistra.
- Scegliere un nome per il bilanciamento del carico.
- Impostare Tipo su Interno e scegliere la rete virtuale e la subnet appropriate per il servizio di bilanciamento del carico.
- In Assegnazione indirizzo IP selezionare Dinamico o Statico.
- In Gruppo di risorse scegliere il gruppo di risorse per il servizio di bilanciamento del carico.
- In Località scegliere l'area geografica appropriata per il servizio di bilanciamento del carico.
- Al termine, fare clic su Crea per generare il servizio di bilanciamento del carico.
Dal gruppo di risorse individuare il servizio di bilanciamento del carico creato nei passaggi precedenti.
Nella sezione Impostazioni fare clic su Pool back-end e quindi fare clic su Aggiungi per aggiungere un nuovo pool back-end.
Immettere il nome del pool back-end
Aggiungere singoli computer o un set di disponibilità per il pool back-end.
Nella sezione Impostazioni del servizio di bilanciamento del carico selezionare Probe e quindi selezionare Aggiungi per aggiungere un nuovo probe.
Immettere il nome per il probe.
Selezionare il Protocollo per il probe. Per un database, può essere preferibile un probe TCP anziché un probe HTTP. Per altre informazioni sui probe del servizio di bilanciamento del carico, vedere Informazioni sui probe del servizio di bilanciamento del carico.
Immettere la Porta del database da usare per l'accesso al probe.
In Intervallo specificare la frequenza di probe per l'applicazione.
In Soglia di non integrità specificare il numero di tentativi continui di probe non riusciti che possono verificarsi prima che una macchina virtuale back-end venga considerata non integra.
Fare clic su OK per creare il probe.
- Nella sezione Impostazioni del servizio di bilanciamento del carico selezionare Regole di bilanciamento del carico e quindi selezionare Aggiungi per creare una regola.
- Immettere il nome per la regola di bilanciamento del carico.
- Impostare le opzioni Indirizzo IP front-end del servizio di bilanciamento del carico, Protocollo e Porta.
- In Porta back-end specificare la porta da usare nel pool di back-end.
- Selezionare il Pool back-end e il Probe creati nei passaggi precedenti per applicarvi la regola.
- In Salvataggio permanente sessione scegliere la modalità di salvataggio delle sessioni.
- In Timeout di inattività specificare il numero di minuti prima di un timeout di inattività.
- Per Indirizzo IP mobile selezionare Disabilitato o Abilitato.
- Fare clic su OK per creare la regola.
Vengono ora configurati l'indirizzo IP e la porta font-end del servizio di bilanciamento del carico nell'applicazione in esecuzione sulle macchine virtuali di livello Web per qualsiasi connessione di database. Questa configurazione è specifica delle applicazioni in esecuzione su tali macchine virtuali. Per configurare l'indirizzo IP e la porta di destinazione, vedere la documentazione dell'applicazione. Per individuare l'indirizzo IP del front-end, passare al pool di indirizzi IP front-end nelle impostazioni del servizio di bilanciamento del carico nel portale di Azure.