A DevOps folyamat megértése

Mi a DevOps?

Ha követi blogunkat, már tudja, mi a DevOps. Ha nem, akkor itt egy gyors összefoglaló és egy cikk, amit elolvashatsz a DevOps kultúráról:

A DevOps módszertan javítja a fejlesztők és az Ops közötti kommunikációt a projektekben. A DevOps céljai a következők:

  • az incidensek megoldására fordított idő megtakarítása
  • az új funkciók gyorsabb bevezetése
  • a kockázatok csökkentése a folyamatok automatizálásával
  • jelentősen növeli az ügyfelek, és egyben a fejlesztők elégedettségét.

Ezért beszélünk a visszacsatolási körről. Ez egy DevOps-koncepció, amely a fejlesztés hatásának mérésére támaszkodik, hogy megismerjük annak hatékonyságát és tovább tanuljunk. Ez a visszacsatolási hurok a DevOps-célok elérésének és a szoftver és a csapat folyamatának sikeres fejlesztésének kulcsa. Emellett segíti csapatait abban is, hogy minőségi kódot szállítsanak.

feedback-loop-devops

Az IDC szerint napjainkban az alkalmazásfejlesztési projektek 20%-a profitál a DevOps megközelítésből. Ez a szám 2021-re 35-40%-ra fog emelkedni. Nem véletlen, hogy oly sok IT-csapat alkalmazza a DevOps módszertant a projekthez.

A DevOps alapelvei

A DevOps módszertan alkalmazása a szoftverfejlesztési csapatán belül gyökeresen meg fogja változtatni a szervezetét. Megváltoztatja a fejlesztőcsapata kódolásának és a kiadások telepítésének módját. A módszer 6 fő alapelvre épül:

  • Automatizálás
  • Iteráció
  • Self-service
  • Folyamatos fejlesztés
  • Folyamatos tesztelés
  • Collaboration

Az automatizálás lehetővé teszi a fejlesztők és az Ops számára a folyamat egyszerűsítését és a csapatok számára a nagyobb termelékenységet. Mivel az automatizálás csökkenti a manuális műveletek számát, javítja a szoftver fejlesztési minőségét és biztonságát. Míg az iteráció felgyorsítja a fejlesztési folyamatot a gyorsabb végfelhasználói visszajelzéseknek köszönhetően. Az önkiszolgálás szintén felgyorsítja a kiadásokat, mivel a fejlesztők igény szerint maguk telepíthetik az alkalmazásokat. A folyamatos fejlesztés a folyamat gördülékenyebbé tételét szolgálja. Sőt, minden egyes incidens után a DevOps-folyamat része a post mortem elvégzése. A post mortem minden egyes incidenst, annak hatását, a javítás érdekében tett lépéseket, a probléma okát és a probléma újbóli előfordulásának megelőzésére tett lépéseket rögzíti. A folyamatos tesztelés gyorsabb kiadásokat és egyúttal magasabb minőséget tesz lehetővé. Végül, de nem utolsósorban a fejlesztők és az üzemeltetés közötti együttműködés kulcsfontosságú az erőfeszítések egyesítése és a gyorsabb siker elérése érdekében.

A DevOps folyamat

A DevOps folyamat egy sor lépésből áll. Íme egy diagram, amely segít a szemléltetésben:

devops-process

A sorrendben a DevOps-folyamat lépései a következők:

  • Terv: Ez a projektnek az a része, amikor megszervezi a feladatokat, ütemterveket és beállítja a projektmenedzsment-eszközöket. Az ötlet lényege, hogy a feladatokat az agilis módszertan felhasználói történetek folyamatának felhasználásával tervezzük meg. A felhasználói történet formájában írt jegyek lehetővé teszik a fejlesztők és az Ops számára, hogy megértsék, mit és miért kell fejleszteni. Egy tökéletes felhasználói történet, mint a mi (ki, hol, kiváltó ok), a miért és az elfogadási kritériumok. (Példa: Felhasználóként az ügyfélfiókomban, amikor az “opcióra” kattintok, megnyílik egy felugró ablak, és megváltoztathatom a nevemet és a keresztnevemet).
  • Kód: Itt a fejlesztők kódfejlesztést és kódellenőrzést végeznek. Amikor a kód készen van, összevonják. A DevOps gyakorlatban fontos, hogy az Ops és a fejlesztői csapatok között közös kódeszköz legyen, mint például a Github vagy a Gitlab.
  • Build: Ez a lépés az első az automatizálás felé. A cél itt az, hogy a forráskódot egy kívánt formátumba építsük, lefordítsuk, teszteljük és telepítsük az infrastruktúra egy adott helyére. Miután ez a lépés beállt, a folyamatos integrációs (CI) és szállítási (CD) eszközök ellenőrizhetik és ellenőrizhetik a forráskódot a forráskódkezelésből, és építhetik azt.
  • Tesztelés: A folyamatos tesztelési folyamat csökkenti a kockázatokat. Az automatikus tesztek biztosítják, hogy a termelésbe nem kerülnek hibák. A tesztelési eszközöket be kell illesztenie a munkafolyamatba, hogy biztosítsa a szoftver legjobb fejlesztési minőségét.
  • Kiadás: A kód átment a tesztelési (folyamatos integrációs) folyamaton, és készen áll a telepítésre.
  • Deploy: Az operatív csapat telepíti az új funkciót a termelésbe. Mivel azonban az automatizálás a DevOps egyik alapelve, lehetőség van a folyamatos telepítés beállítására.
  • Az infrastruktúra üzemeltetése/konfigurálása: Az Ops létrehozza vagy karbantartja a skálázható infrastruktúrát, az infrastruktúra mint kód, és ellenőrzi a biztonsági problémákat és a naplókezelést.
  • Monitor: A monitorozás fontos lépés, mivel lehetővé teszi az incidensek gyorsabb javítását és a végfelhasználó számára jobb élményt nyújt.

Mivel a DevOps célja az ügyfelek elégedettségének jelentős növelése, természetesen a csapatok újra kezdik a lépéseket a szoftver vagy alkalmazás új funkciójával. Ezért a DevOps-ot mindig végtelen hurokként rajzoljuk meg.

A DevOps bevezetése a csapatában

Ha a csapata még nem vezetett be DevOps-folyamatot vagy akár agilis folyamatot, ez zavarosnak tűnhet, különösen azért, mert ez nemcsak a szervezet, hanem a csapat kultúrájának megváltoztatását is jelenti.

A DevOps bevezetéséhez a csapatában időt kell szánnia, lépésről lépésre kell haladnia, nem szabad elkapkodnia. Íme, hogyan lehet fokozatosan bevezetni ezt az új kultúrát és szervezetet:

  1. A csapatok gondolkodásmódjának megváltoztatásával kezdje. Eszközök nélkül a DevOps folyamat nem létezhet, de ez nem elég, a fejlesztőknek és az Ops-nak meg kell érteniük és érdekelniük kell egymás munkáját. Röviden, a fejlesztőknek és az Ops-nak meg kell tanulniuk együttműködni.
  2. Agilis fejlesztési folyamatot kell bevezetni. A legtöbb DevOps projekt az agilis Scrum vagy Kanban módszertanokat használja.
  3. A negyedik lépéshez a felhőalapú számítástechnikát (privát, nyilvános vagy hibrid felhő) kell bevezetni.
  4. Automatizálja a szoftvertelepítést a folyamatos integrációnak (CI) köszönhetően, így a fejlesztők könnyen tudnak új funkciót tolni.
  5. Használja a szoftver folyamatos tesztelését a kockázatok csökkentése érdekében.
  6. Vezesse be a folyamatos telepítést (CD), kevesebb manuális művelet van, gyorsabban tudja az új kiadásokat a termelésbe telepíteni.

Tartsa szem előtt, hogy ezeknek a folyamatoknak a hozzáadása megváltoztatja a szervezetét és új igényeket teremt. Például a csapatának szüksége lehet a bevezetett új DevOps-eszközökkel kapcsolatos képzésre.

Az igazi DevOps-környezetet akkor éri el, amikor a fejlesztési folyamata a lehető legjobban automatizált és agilis lesz. Ha kérdése van a folyamat valamelyik lépésével kapcsolatban, forduljon hozzánk bizalommal. Nouveau call-to-action

Vélemény, hozzászólás?

Az e-mail-címet nem tesszük közzé.