Jump to section

Cosa sono i microservizi?

Copia URL
Teaching an elephant to dance

Come rendere agile un'architettura monolitica

Per rendere le applicazioni e l'ambiente più agili e adattabili ai cambiamenti serve una strategia di trasformazione digitale che rifletta gli obiettivi e la cultura aziendale.

Un'architettura a microservizi è un approccio cloud native alla realizzazione di software secondo modalità che permettono l'esistenza indipendente di ogni funzione principale di un'applicazione. 

Quando gli elementi di un'applicazione sono distinti in questo modo, i team di sviluppo e operativi possono lavorare in tandem senza intralciare le reciproche attività. Ciò consente a più sviluppatori di lavorare simultaneamente alla stessa app, riducendo le tempistiche di sviluppo.

Un'architettura di microservizi è un approccio cloud native alla realizzazione di software secondo modalità che permettono l'esistenza indipendente di ogni funzione principale di un'applicazione. 

Quando gli elementi di un'applicazione sono distinti in questo modo, i team di sviluppo e operativi possono lavorare in tandem senza intralciare le reciproche attività. Ciò consente a più sviluppatori di lavorare simultaneamente alla stessa app, riducendo le tempistiche di sviluppo.

 

L'architettura a microservizi è un'evoluzione della Service Oriented architecture (SOA), due approcci simili in quanto entrambe suddividono le applicazioni complesse e di grandi dimensioni in componenti più piccoli e più facili da gestire. A causa delle loro somiglianze, le architetture SOA e dei microservizi sono spesso confuse. La differenza principale è che la SOA è un approccio architetturale di livello enterprise, mentre i microservizi sono una strategia di implementazione adottata dagli sviluppatori di app.

L'architettura a microservizi è un'evoluzione della Service Oriented architecture (SOA), due approcci simili in quanto entrambe suddividono le applicazioni complesse e di grandi dimensioni in componenti più piccoli e più facili da gestire. A causa delle loro somiglianze, le architetture SOA e dei microservizi sono spesso confuse. La differenza principale è che la SOA è un approccio architetturale di livello enterprise, mentre i microservizi sono una strategia di implementazione adottata dagli sviluppatori di app.

Basandosi su un'architettura distribuita, i microservizi consentono di ottenere sviluppo e routine più efficienti. La possibilità di sviluppare più microservizi in contemporanea Ciò consente a più sviluppatori di lavorare simultaneamente alla stessa app, riducendo le tempistiche di sviluppo.

Time-to-market più rapido

Consentendo di abbreviare i cicli di sviluppo, un'architettura basata su microservizi supporta deployment e aggiornamenti più agili.

Scalabilità superiore

Man mano che la domanda per determinati servizi aumenta, i microservizi possono essere distribuiti su più server e infrastrutture, in base alle esigenze aziendali.

Resilienza

Ciascun servizio, se costruito correttamente, è indipendente e non influisce sugli altri servizi dell'infrastruttura. Di conseguenza, l'eventuale errore di un componente non determina il blocco dell'intera app, come avviene con il modello monolitico.

Semplicità di deployment

Poiché le app basate su microservizi sono più piccole e modulari delle tradizionali applicazioni monolitiche, tutti i problemi associati a tali deployment vengono automaticamente eliminati. Benché questo approccio richieda un coordinamento superiore, per il quale può rivelarsi utile un livello di service mesh, i vantaggi che ne derivano sono determinanti.

Accessibilità

Poiché le app più grandi vengono suddivise in parti più piccole, per gli sviluppatori è molto più semplice comprendere, aggiornare e migliorare tali componenti, e questo permette di accelerare i cicli di sviluppo, soprattutto in combinazione con le metodologie di sviluppo agile, come DevOps.

Maggiore apertura

Grazie alle API poliglotte, gli sviluppatori sono liberi di scegliere il linguaggio e la tecnologia ottimali per la funzione da creare.

La flessibilità che caratterizza i microservizi può portare a un'accelerazione della distribuzione delle nuove modifiche, il che significa creare nuovi schemi. Nell'ingegneria del software, uno "schema" indica qualsiasi soluzione algoritmica nota come funzionante. Uno "schema da evitare" indica invece gli errori comuni compiuti con l'intento di risolvere un problema, che però ne creano altri nel lungo termine.

Oltre a queste, un'architettura basata su microservizi presenta due criticità principali: la complessità e la produttività. Quando si lavora con un'architettura a microservizi, è importante tenere conto degli schemi da evitare più comuni.

  1. Scalabilità: la possibilità di dimensionare qualsiasi funzione durante il processo di sviluppo del ciclo di vita software pone diverse sfide, soprattutto all'inizio. Durante la configurazione iniziale, è importante dedicare tempo a identificare le dipendenze tra servizi e i potenziali ostacoli capaci di creare incompatibilità con le versioni precedenti. Al momento della distribuzione, l'automazione è il miglior investimento, perché la complessità dei microservizi può renderli umanamente ingestibili. 
  2. Registrazione: nei sistemi distribuiti, per ricollegare tutti i vari componenti sono necessari registri centralizzati, senza i quali gestirli in modo scalabile risulterebbe impossibile.
  3. Monitoraggio: è fondamentale per i team operativi avere una visibilità centralizzata del sistema, al fine di identificare l'origine dei problemi. 
  4. Debugging: il debugging remoto tramite l'ambiente di sviluppo integrato (IDE) locale non è una scelta praticabile con decine o centinaia di servizi. Al momento non esiste un'unica soluzione legata al debugging.
  5. Connettività: occorre valutare quale metodo di rilevamento dei servizi scegliere, se centralizzato o integrato.

Container e Kubernetes
Un container è un'unità di software nella quale il codice dell'applicazione è incluso in un unico pacchetto che contiene anche tutti i file necessari alla sua esecuzione. In questo modo è più facile spostare l'applicazione containerizzata tra gli ambienti conservandone tutte le funzionalità.

Kubernetes è una piattaforma di orchestrazione dei container che consente di aggiornare i singoli componenti di un'applicazione senza influenzare gli altri elementi dello stack tecnologico; è perfetta per automatizzare la gestione, la scalabilità e il deployment delle applicazioni di microservizi.

API
Un'interfaccia di programmazione delle applicazioni, o API, è il componente dell'applicazione responsabile di comunicare con le altre applicazioni. Nell'ambito dell'infrastruttura di un'architettura a microservizi, le API giocano il ruolo strategico che permette ai diversi servizi di un microservizio di condividere le informazioni, funzionando come se fossero un servizio solo.

Flusso di eventi
Un evento è qualsiasi cosa che accade in un servizio di microservizi, ad esempio l'aggiunta o la rimozione di un articolo da un carrello per acquisti online.

Gli eventi compongono flussi di eventi che riflettono il comportamento mutevole di un sistema. Il loro monitoraggio permette alle organizzazioni di comprendere il comportamento di dati e utenti in modo utile. L'elaborazione dei flussi di eventi permette di intraprendere azioni immediate e può essere utilizzata con i carichi di lavoro operativi in tempo reale. Viene ormai applicata a diversi aspetti, dall'analisi delle frodi alla manutenzione dei sistemi.

Serverless computing
Definiamo serverless computing un modello di sviluppo cloud native che permette agli sviluppatori di creare e gestire le applicazioni, mentre un provider cloud è responsabile del provisioning, della manutenzione e della scalabilità dell'infrastruttura del server. Gli sviluppatori devono semplicemente creare pacchetti di codice all'interno di container per il deployment. Il serverless computing aiuta le aziende ad accelerare l'innovazione, astraendo l'applicazione dall'infrastruttura alla base.

Le soluzioni open source di Red Hat ti aiutano nella suddivisione delle tue applicazioni monolitiche in microservizi, nella loro gestione e orchestrazione, fino alla gestione dei dati che i microservizi creano. 

Red Hat OpenShift
Red Hat® OpenShift® è una piattaforma Kubernetes che offre un metodo unificato per la connessione, la gestione e il monitoraggio delle applicazioni basate su microservizi. Supporta applicazioni containerizzate, in uso e cloud native, oltre a quelle in corso di refactoring per essere adattate ai microservizi. OpenShift si integra con Red Hat Application Services e può essere utilizzato con strumenti di automazione esistenti quali Git, Maven e Jenkins. È inoltre dotato di un sistema operativo Linux di livello enterprise, che assicura maggiore sicurezza all'intero cluster. 

Che si stiano ottimizzando applicazioni già in uso, avviando una migrazione verso il cloud o realizzando soluzioni totalmente nuove basate sui microservizi, Red Hat OpenShift costituisce una piattaforma più sicura e stabile per tutta l'infrastruttura.

 

Red Hat Runtimes

Red Hat Runtimes è un insieme di raccolte di runtime preconfigurate e containerizzate che costituiscono le fondamenta dei microservizi. Supporta un gran numero di linguaggi e framework da utilizzare nella progettazione di architetture di microservizi quali Quarkus, Spring Boot, MicroProfile e Node.js. Inoltre, Red Hat Runtimes include servizi di supporto per l'accesso rapido ai dati con Red Hat Data Grid, e servizi per la protezione delle API dei microservizi con Red Hat Single-sign on.

 

Red Hat Integration

Red Hat Integration è un set completo di tecnologie di integrazione e messaggistica finalizzate a connettere le applicazioni e i dati sulle infrastrutture ibride. È una soluzione agile, distribuita, containerizzata e basata sulle API. Fornisce orchestrazione e creazione dei servizi, connettività delle applicazioni, trasformazione dei dati, messaggistica in tempo reale e gestione delle API, il tutto associato a una piattaforma cloud native e una toolchain per un supporto completo dello sviluppo applicativo moderno.

Gli sviluppatori possono sfruttare strumenti come i servizi con trascinamento della selezione e i pattern di integrazione incorporati per la creazione dei microservizi. Al contempo, gli utenti aziendali possono avvalersi degli strumenti web per sviluppare API capaci di integrare microservizi diversi.

Keep reading

ARTICOLO

I microservizi supportano l'integrazione dell'IT nel settore sanitario

I microservizi permettono agli sviluppatori che lavorano in ambito sanitario e altri settori di creare applicazioni che grazie all'impiego di servizi a basso accoppiamento risultano facili da sviluppare, testare, distribuire e aggiornare.

ARTICOLO

Cosa sono i microservizi?

I microservizi sono un approccio architetturale alla realizzazione di applicazioni, in cui le varie componenti di un'app, che vengono suddivise in funzioni indipendenti, lavorano insieme.

ARTICOLO

Cos'è una service mesh?

Una service mesh è un livello infrastrutturale integrato direttamente nell'app in grado di documentare le modalità di interazione tra i vari servizi, ottimizzando la comunicazione ed evitando i tempi di inattività.

Scopri di più sui microservizi

Prodotti

Una piattaforma applicativa aziendale che offre servizi verificati per consentire la distribuzione delle app sulle infrastrutture preferite.

Risorse

Ebook

Il percorso verso le applicazioni cloud-native: 8 passi per guidarti nel percorso verso il cloud native.

Ebook

Come rendere agile un'architettura monolitica.

Formazione

Corso di formazione gratuito

Developing Cloud-Native Applications with Microservices Architectures