Kniha „The Phoenix Project: ANovel About IT, Devops, and Helping Your Business Win“ vo veľkej miere zviditeľnila pojem DevOps apodrobne rozpracovala tému IT manažmentu asním súvisiace obchodné problémy. Stala sa hitom, ktorý poukázal na 3 hlavné cesty, ktorými využiť DevOps.
Prvá cesta: Zľava doprava
Základným princípom rýchleho vývoja produktu je, že všetky oddelenia vo firme, ktoré sa zúčastňujú daných procesov, musia vykonávať svoju prácu najlepšie ako vedia aodovzdávať ju dokončenú ďalej. Aby bolo niečo takéto možné, každé oddelenie (jednotlivec či celá divízia) musí minimalizovať množstvo rozrobenej roboty (WIP – Work In Progress) azamerať sa na úlohy postupne - jednu po druhej. Taktiež je dôležité, aby každý účastník prešiel celým procesom bez odhalenia akýchkoľvek nedostatkov anedošlo tak ktomu, že niektorá zmiestnych divízií spôsobí globálnu degradáciu. Každé oddelenie by malo odovzdávať všetky informácie apoznatky ďalšiemu oddeleniu, ktoré preberá jeho prácu apokračuje vdokončovaní procesu.
Ako znázorňuje obrázok dole, DevOps aktivuje celý tok získavania obchodnej hodnoty: od získania biznisu aidentifikovania požiadaviek na produkt, cez samotný development (tvorba produktu podľa požiadaviek), cez zabezpečenie prevádzky až po jeho dodanie ku zákazníkovi.
Druhá cesta: Sprava doľava
Na vybudovanie vysoko kvalitného produktu, ktorý bude spĺňať potreby zákazníkov, je kľúčové od nich získavať spätnú väzbu čo najrýchlejšie. Oddelenia, ktoré sme si zadefinovali vyššie (business, development, operations, customer), by mali poskytovať spätnú väzbu oddeleniu, ktoré sa nachádza vtoku pred ním. Vývojársky tím by mal obchodnému oddeleniu poskytnúť informácie o časových odhadoch, technologických obmedzeniach amožných rizikách vobchode. Oddelenie prevádzky musí informovať tím vývojárov odetegovaných problémoch azákazník by mal na oddelenie prevádzky posúvať ďalej svoj názor apostrehy vsúvislosti skvalitou produktu.
Vbode, vktorom dochádza ku komunikácií aodovzdávaniu práce medzi vývojárskym tímom aoddelením prevádzky sa môže mnoho úkonov automatizovať. Apráve toto je miesto, vktorom sa vykonáva kontinuálna integrácia (CI – Continuous Integration) akontinuálne nasadenie (CD – Continuous Deployment).
Kontinuálna integrácia sa môže realizovať automatizovanými procesmi, ktoré sa spúšťajú zakaždým, keď je kód nasadený do systému na riadenie verzie (VCS – Version Control System), ako je napríklad Git, alebo keď je zlúčený do (pred)produkčnej vetvy. Vývojár môže vidieť výsledok testu v priebehu niekoľkých minút ana základe neho okamžite vie, či jeho nový kód spĺňa všetko, čo vyžadujú dané testy. Tie pritom obsahujú mnoho aspektov programovania, ako sú napríklad analýza kvality kódu, testovanie častí logiky (unit testy), integračné testy na odhalenie chýb pri integrácii medzi integrovanými časťami kódu, automatické testovanie používateľského rozhrania a iné typy automatizovaných testov. Tieto testy sa môžu vykonávať pred alebo aj po vytvorení softvéru, závisí od charakteru testu.
Predstavte si, že by ste počas jedného dňa robili viacero zmien achceli by ste ich mal ihneď integrované. Čo by to znamenalo? Vývojár by musel zakaždým poslať softvér testovaciemu oddeleniu (QA – Quality Assurance), tí by museli znova vykonať všetky testy anakoniec aj otestovať celý integrovaný systém. Toto všetko však môže byť automatizované vCI, čo znamená, že QA potom testuje celé systémy až po tom, čo sú úspešne nasadené do vývojárskeho prostredia alebo (pred)produkčného prostredia.
Ďalšou skvelou črtou kontinuálnej integrácie je automatické buildovanie. Znamená to, že tvorba softvéru sa generuje automaticky po poslaní kódu do VCS alebo na základe konkrétneho času. Ak buildovanie zlyhá, automaticky sa deteguje chyba. Vďaka tomu to vývojár nezistí až v„deň D“, kedy má ísť softvér oficiálne von.
Výsledkom celej integrácie v CI je, že buď vývojár získa spätnú väzbu na tie veci, ktoré by mal opraviť, alebo získa skontrolovaný a spustiteľný softvér, ktorý je pripravený na nasadenie. Následne po tom začína proces kontinuálnej dodávky CD, kedy sa softvér dodáva do reálneho prostredia na testovanie apoužívanie.
Existujú 2 typy CD reťazcov: Kontinuálna dodávka (Continuous Delivery) aKontinuálne nasadenie (Continuous Deployment). Sú veľmi podobné, len s jedným zásadným rozdielom – pri kontinuálnej dodávke musí byť nasadenie do produkcie manuálne naplánované či dokonca manuálne vykonané. Pri kontinuálnom nasadení je celý proces plne automatizovaný adá sa mu zabrániť iba tým, že neprejde testovaním.
Oba tieto CD reťazce sú určené na dodávanie malých iteratívnych zmien do produkcie, pri ktorých je ľahké identifikovať chyby avprípade potreby ich vrátiť naspäť. Každá zo zmien musí vždy prejsť sériou automatizovaných testov, ktoré výrazne znižujú riziko výskytu porúch po nasadení.
Veľkou výhodou použitia CI/CD je, že neexistujú žiadne „dni vydania“ (release date), pretože každý deň je malým dňom vydania. Tejto veci sa teší najmä vývojársky tím aoddelenie prevádzky, pretože práve oni majú tendenciu robiť zmeny na poslednú chvíľu atie veľakrát končia vneúspešných vydaniach.
Proces CI/CD závisí vo veľkej miere na nástrojoch na testovanie, integráciu a nasadenie. Mnoho projektov v oblasti infraštruktúry sa distribuuje vývojárom, nakoľko virtuálne kontajnery sa používajú na simuláciu produkčného prostredia na lokálnom počítači, vo vývojovom prostredí a v(pred)produkčnom prostredí. Toto tiež zabraňuje tomu, aby sa tak často nevyskytovali chyby špecifické pre daný systém.
Vďaka týmto technikám je spoločnosť Facebook schopná vykonávať tisícky nasadení každý jeden deň, testovať ich, šíriť ich medzi zamestnancami, rozširovať ich najprv na niekoľko používateľov a nakoniec sprístupňovať všetkým používateľom. Tieto zmeny je možné kedykoľvek zastaviť automatizovanými testami alebo spätnou väzbou od ľudí, ktorí ich už používajú.
Tretia cesta
Tretia cesta je o kultúrnom posune priamo v organizácii. Ľudia sa nemusia báť riskovať a experimentovať. Ak to nefunguje, automatizované testy by mali zastaviť nasadzovanie. Ak to funguje, tím niečo vyskúšal a naučil sa vďaka tomu niečo nové. Voboch prípadoch – úspech alebo zlyhanie – sa ľudia niečo naučia azískajú nové skúsenosti. Tím by však mal mať vzálohe aj nejaký náhradný plán, ktorý by mohol byť užitočný vbudúcnosti pri zlyhaní produkcie.
Experimentovanie a riskovanie sú jediným spôsobom, ako posunúť inovácie dopredu a dosiahnuť nové hranice.