Idee per soluzioni
In questo articolo viene descritta un'idea di soluzione. Il cloud architect può usare queste linee guida per visualizzare i componenti principali di un'implementazione tipica di questa architettura. Usare questo articolo come punto di partenza per il design di una soluzione ben progettata che sia in linea con i requisiti specifici del carico di lavoro.
Questo articolo descrive una variante di un'architettura basata su eventi serverless eseguita in servizio Azure Kubernetes (AKS) con il ridimensionatore KEDA. La soluzione inserisce un flusso di dati, elabora i dati e quindi scrive i risultati in un database back-end.
Architettura
Scaricare un file di Visio di questa architettura.
Flusso di dati
- Il servizio Azure Kubernetes con il scaler KEDA viene usato per ridimensionare automaticamente i contenitori Funzioni di Azure in base al numero di eventi che devono essere elaborati.
- Gli eventi arrivano all'hub eventi di input.
- La funzione di de-batch e filtro di Azure viene attivata per gestire l'evento. Questo passaggio filtra gli eventi indesiderati e de-batch gli eventi ricevuti prima di inviarli all'hub eventi di output.
- Se la funzione di de-invio in batch e filtro di Azure non riesce a archiviare correttamente l'evento, l'evento viene inviato all'hub eventi deadletter 1.
- Gli eventi in arrivo nell'hub eventi di output attivano la funzione di Azure di trasformazione. Questa funzione di Azure trasforma l'evento in un messaggio per l'istanza di Azure Cosmos DB.
- L'evento viene archiviato in un database di Azure Cosmos DB.
Componenti
- Il servizio Azure Kubernetes semplifica la distribuzione di un cluster Kubernetes gestito in Azure tramite l'offload del sovraccarico operativo in Azure. Come servizio Kubernetes ospitato, Azure gestisce attività critiche quali il monitoraggio dell'integrità e la manutenzione.
- KEDA è un'utilità di scalabilità automatica basata su eventi usata per ridimensionare i contenitori nel cluster Kubernetes in base al numero di eventi che devono essere elaborati.
- Hub eventi inserisce il flusso di dati. Hub eventi è progettato per scenari di flusso di dati con velocità effettiva elevata.
- Funzioni di Azure è un'opzione di calcolo senza server. Usa un modello basato su eventi, in cui una parte di codice (una funzione) viene richiamata da un trigger.
- Azure Cosmos DB è un servizio di database multimodelli disponibile in modalità serverless basata sul consumo. Per questo scenario, la funzione di elaborazione eventi archivia i record JSON usando Azure Cosmos DB per NoSQL.
Nota
Per gli scenari Internet of Thing (IoT), è consigliabile hub IoT di Azure. hub IoT ha un endpoint predefinito compatibile con l'API Hub eventi di Azure, quindi è possibile usare entrambi i servizi in questa architettura senza modifiche importanti nell'elaborazione back-end. Per informazioni, vedere Connessione di dispositivi IoT ad Azure: hub IoT e hub eventi.
Dettagli dello scenario
Questo articolo descrive un'architettura basata su eventi serverless eseguita nel servizio Azure Kubernetes con il scaler KEDA. La soluzione inserisce un flusso di dati, elabora i dati e quindi scrive i risultati in un database back-end.
Potenziale caso d'uso
Un caso d'uso comune per l'implementazione di un modello di elaborazione del flusso di eventi end-to-end include il servizio di inserimento in streaming di Hub eventi per ricevere ed elaborare eventi al secondo usando una logica di de-batch e trasformazione implementata con funzioni attivate dall'hub eventi altamente scalabili.
Collaboratori
Questo articolo viene gestito da Microsoft. Originariamente è stato scritto dai seguenti contributori.
Autore principale:
- Rajasa Savant | Senior Software Development Engineer
Per visualizzare i profili LinkedIn non pubblici, accedere a LinkedIn.