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
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:
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
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
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.
^
(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).
^ab
(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).