DevOps (dalla contrazione inglese di development, "sviluppo", e operations, qui simile a "messa in produzione" o "deployment") è una metodologia di sviluppo del software utilizzata in informatica che punta alla comunicazione, collaborazione e integrazione tra sviluppatori e addetti alle operations della information technology (IT).[1] DevOps vuole rispondere all'interdipendenza tra sviluppo software e IT operations, puntando ad aiutare un'organizzazione a sviluppare in modo più rapido ed efficiente prodotti e servizi software.[2][3][4][5]
Descrizione
[modifica | modifica wikitesto]Le aziende che tipicamente potrebbero avere maggiori benefici da un orientamento DevOps sono quelle con rilasci di software frequenti. Flickr ha utilizzato il metodo DevOps per supportare la necessità di dieci rilasci al giorno;[6] tale ciclo di rilasci potrebbe essere più frequente in organizzazioni che producano applicazioni multi-focus o multi-funzione, spesso indicato come "deployment continuo"[7] e associato spesso al metodo lean startup.[8] Sull'argomento sono nati gruppi di lavoro, ordini professionali e blog sin dal 2009.[4][9][10][11]
Il metodo DevOps aiuta le aziende nella gestione dei rilasci, standardizzando gli ambienti di sviluppo. Le aziende con problemi di automazione dei rilasci solitamente hanno già un processo automatico in essere ma lo vorrebbero più flessibile e controllabile, senza per questo dover agire da riga di comando per ottenere ciò. Idealmente tale automazione potrebbe essere utilizzata anche da risorse non operative (non appartenenti alle IT operations) su ambienti non di produzione; in questo modo gli sviluppatori hanno a disposizione un maggiore controllo degli ambienti, dando all'infrastruttura una visione più incentrata sull'applicazione.
L'integrazione DevOps ha come obiettivo il rilascio del prodotto, il collaudo del software, l'evoluzione e il mantenimento (correzione di bug e release minori) in modo tale da aumentare affidabilità e sicurezza e rendere più veloci i cicli di sviluppo e rilascio. Molte delle idee che costituiscono DevOps provengono dalla gestione di sistemi aziendali e dalla Metodologia agile.[12]
Storia
[modifica | modifica wikitesto]Il termine "DevOps" è stato coniato da Patrick Debois[13] e reso popolare attraverso una serie di "DevOps Days" iniziati nel 2009 in Belgio.[9] Da allora si sono svolte conferenze "DevOps Days" in India, USA, Brasile, Australia, Germania, Svezia e Svizzera.[10]
Le metodologie di sviluppo (ad esempio la Metodologia agile) che vengono attuate nelle organizzazioni tradizionali mediante distinte divisioni tra IT operations e QA da un lato, sviluppo e rilascio dall'altro, sono prive di una profonda integrazione interdipartimentale. DevOps promuove un insieme di processi e metodi indirizzati alla comunicazione e collaborazione tra le divisioni.[14]
L'adozione della metodologia DevOps è guidata da diversi fattori, come:
- Utilizzo della metodologia agile e altre metodologie di sviluppo del software
- Necessità di incrementare la frequenza dei rilasci in produzione
- Ampia disponibilità di un'infrastruttura virtualizzata[15] e in cloud
- Incremento nell'uso di data center automatizzati[16] e strumenti di configuration management e Infrastructure as Code
La metodologia DevOps è spesso descritta come una relazione più collaborativa e produttiva tra i gruppi di sviluppo e quelli di operation. Ciò incrementa l'efficienza e riduce i rischi di frequenti modifiche in produzione. Per quantificare tale effetto si sta ragionando su alcuni possibili parametri.[17]
Il ruolo di un professionista DevOps ricorda molto la figura dell'ingegnere capo all'interno del cosiddetto "Toyota Production System".[18] Tali figure sono responsabili del successo del progetto ma senza alcuna formale autorità sui diversi gruppi coinvolti. È loro richiesta conoscenza tecnica adeguata al fine di convincere i manager di quali siano le necessità e può essere di loro aiuto il sostegno da parte della dirigenza aziendale.
Invece, in molte organizzazioni, lo sviluppo del software e la gestione dei sistemi sono in divisioni differenti e poiché lo sviluppo è generalmente guidato dalle necessità dell'utente, per continue modifiche e conseguenti rilasci, i gruppi operativi sono concentrati sulla disponibilità e affidabilità dei servizi, nonché sulla gestione dei costi. Ciò produce un "gap" tra sviluppo e gestione dei servizi che rallenta il passaggio in produzione.
Impatto sui rilasci applicativi
[modifica | modifica wikitesto]In molte aziende i rilasci applicativi sono eventi ad alto impatto e rischio, coinvolgendo più gruppi di lavoro. Con la metodologia DevOps tale rischio si riduce per i seguenti motivi:
- Numero ridotto di modifiche
- L'adozione del modello agile o modello incrementale, in contrasto con il tradizionale modello a cascata, comporta minori modifiche, anche se più frequenti, con minore impatto e rischio.
- Accresciuto coordinamento dei rilasci
- La presenza di una coordinazione del rilascio riduce le distanze tra sviluppo e gestione.
- Automazione
- Una completa automazione assicura la facile ripetibilità dei rilasci e riduce gli errori nell'operazione.
Coordinatore del rilascio
[modifica | modifica wikitesto]Si tratta di un ruolo relativamente nuovo nelle aziende IT, il cui compito è di coordinare i rilasci in ambienti pre-produzione (di test). La necessità di tale figura viene da:
- La necessità di ridurre il "gap" tra sviluppo e gestione
- Accresciuta complessità dell'infrastruttura, ad esempio applicazioni multipiattaforma
- Incremento della frequenza dei rilasci, ad esempio per via dell'utilizzo della metodologia agile
- Gruppi delocalizzati, come nel caso dell'utilizzo di risorse esterne o in sedi diverse
Il ruolo del coordinatore del rilascio (anche indicato come coordinatore d'integrazione) è simile a quello di un controllore di volo che deve coordinare in tempo reale attività di diversi gruppi per raggiungere un obiettivo (atterraggi e decolli in sicurezza) usando risorse condivise (spazio aereo, sentieri di volo, piste e terminali).
Tale coordinamento non va confuso con la gestione del rilascio, che è focalizzata sulla pianificazione delle modifiche al software in ottica di una loro applicazione direttamente sulla produzione, mentre il coordinatore del rilascio si occupa del lavoro sistematico e tecnico inerente alla creazione e rilascio del software nei vari ambienti.
Note
[modifica | modifica wikitesto]- ^ (EN) Organizing a Digital Technology Department of Medium Size in a Media Company, su rajiv.com, 17 marzo 2009. URL consultato il 15 luglio 2015.
- ^ (EN) Dmitriy Samovskiy, The Rise of DevOps, in Fubaredness is contagious - preventing its spread in IT one post at a time (Dmitriy Samovskiy's Blog), 2 marzo 2010. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 7 gennaio 2011).
- ^ (EN) What is DevOps?, su dev2ops.org, 23 febbraio 2010. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 9 settembre 2012).
- ^ a b (EN) DevOps mixing dev, ops, agile, cloud, open source and business, su blogs.the451group.com, 3 marzo 2010. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 14 settembre 2015).
- ^ (EN) Devops: A Software Revolution in the Making? (PDF), su cutter.com, agosto 2011. URL consultato il 15 luglio 2015.
- ^ (EN) 10+ Deploys Per Day: Dev and Ops Cooperation at Flickr, su slideshare.net. URL consultato il 15 luglio 2015.
- ^ (EN) Why Enterprises Must Adopt Devops to Enable Continuous Delivery (PDF), su cutter.com, agosto 2011, 6-12. URL consultato il 15 luglio 2015.
- ^ Applied Lean Startup Ideas: Continuous Deployment at kaChing, su slideshare.net.
- ^ a b (EN) DevOps Days Ghent 2009, in DevopsDays. URL consultato il 15 luglio 2015.
- ^ a b (EN) DevOps Days, su devopsdays.org. URL consultato il 15 luglio 2015.
- ^ (EN) Damon Edwards, DevOps Meetup Recap, su dev2ops.org, 26 aprile 2010. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 20 luglio 2012).
- ^ (EN) Agile Infrastructure, su infoq.com, InfoQ. URL consultato il 15 luglio 2015.
- ^ (EN) Manuel Pais, Patrick Debois on the State of DevOps, su infoq.com, InfoQ, 6 aprile 2012. URL consultato il 15 luglio 2015.
- ^ (EN) James Turnbull, What DevOps means to me..., su kartar.net. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 30 dicembre 2010).
- ^ (EN) Virtual Infrastructure products: features comparison, in Welcome to IT 2.0: Next Generation IT infrastructures. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 21 luglio 2011).
- ^ (EN) Jennifer Ellard, Bringing Order to Chaos through Data Center Automation, in Information Management, SourceMedia. URL consultato il 15 luglio 2015 (archiviato dall'url originale l'11 giugno 2010).
- ^ (EN) David Booth, How to Measure the Effects of Development + Operations improvements, an OpenSpace conversation, su zeroturnaround.com. URL consultato il 15 luglio 2015 (archiviato dall'url originale il 23 luglio 2012).
- ^ The Toyota Way, 1ª ed., McGraw-Hill, 17 dicembre 2003, ISBN 0-07-139231-9.