Nel precedente script #263 abbiamo visto come Azure Container Jobs ci offre la possibilità di eseguire job containerizzati che operano per una durata definita e terminano quando il compito è completato. Questi jobs possono essere eseguiti manualmente oppure ad intervalli regolari, ma è interessante poterli avviare anche tramite trigger.
I trigger si basano sempre sulle regole di scaler di KEDA e, a differenza dell'app, dove una o più istanze vengono attivate in base alle regole per processare più eventi in sequenza o in bulk, applicati ai job causano la creazione di un'istanza per ogni trigger, e risultano quindi l'ideale per operazioni lunghe che necessitano di istanze specifiche di elaborazione.
In fase di creazione di un job dal portale, quindi, se selezioniamo Event ci viene chiesto quali regole dello scaler applicare, come per le app.
Poiché gli eventi possono essere molteplici, possiamo restringere il numero minimo e massimo di istanze da prendere in carico. Nello scaler impostiamo come al solito le tipologie e i metadati, secondo quanto previsto dalla documentazione https://keda.sh/docs/scalers/.
Nell'esempio impostiamo una regola basata sulle code di Azure Storage. Purtroppo, l'interfaccia non permette ancora di impostare la parte dedicata all'autenticazione e all'utilizzo dello scaler, perciò dobbiamo ricorrere ad Azure CLI per impostare la secret da usare per la stringa di connessione.
az containerapp job update -n ricciolo2 -g ricciolo --scale-rule-auth "connection=azurewebjobsstorage" --scale-rule-type "azure-queue" --scale-rule-name queue --scale-rule-metadata "accountName=ricciolo" "queueName=jobs" "queueLength=1"
Creato e impostate le regole del job, lo scaler monitora ogni 20 secondi (modificabile tramite Azure CLI) lo stato della coda e verifica la presenza di messaggi. In base al numero crea le istanze necessarie e, poiché abbiamo impostato un queueLength a 1, in caso di tre messaggi creerà 3 istanze. In caso di 5 messaggi ne creerà comunque 3 per via dei limiti che abbiamo messo. A questo punto è compito del job togliere i messaggi (peek/lock oppure receive/delete) dalla coda affinché lo scaler non li veda al controllo successivo, pena la creazione di altre istanze.
In questo modo i job partono, eventualmente considerando le repliche, che non rientrano nel conto dell'istanze, e possono eseguire con tutto il tempo necessario l'attività. Non è previsto un modo per indicare per quale scopo specifico è prevista quell'istanza; perciò, è compito del container recuperare il lavoro da effettuare. Nel caso di una coda, il semplice prelievo del messaggio disponibile è sufficiente per distribuire i lavori.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Paginare i risultati con QuickGrid in Blazor
Personalizzare l'errore del rate limiting middleware in ASP.NET Core
Eseguire attività pianificate con Azure Container Jobs
Come EF 8 ha ottimizzato le query che usano il metodo Contains
Potenziare Azure AI Search con la ricerca vettoriale
Gestire la cancellazione di una richiesta in streaming da Blazor
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Criptare la comunicazione con mTLS in Azure Container Apps
Generare un hash con SHA-3 in .NET
Utilizzare gRPC su App Service di Azure
Filtrare i dati di una QuickGrid in Blazor con una drop down list
Eseguire query manipolando liste di tipi semplici con Entity Framework Core