Architektúra mikroslužieb je systém, v ktorom veľká aplikácia pozostáva z malých služieb, ktoré navzájom spolupracujú a komunikujú pomocou API.
Tieto služby sú vysoko nezávislé a voľne prepojené. Vďaka tomu sa dajú ľahko testovať a udržiavať, čo zase urýchľuje proces vývoja.
Ako fungujú mikroslužby
Pred mikroslužbami bol štandardný spôsob vývoja aplikácií pomocou monolitickej architektúry. Takéto aplikácie boli samostatné, nezávislé jednotky. Ich komponenty – ako používateľské rozhranie, obchodná logika a ukladanie údajov – boli napísané v jedinej kódovej základni.
Zatiaľ čo monolitové aplikácie sa ľahko navrhujú a vyvíjajú, výsledný kód môže byť ťažké pochopiť, škálovať a udržiavať.
V architektúre mikroslužieb rozdeľujete veľkú aplikáciu na menšie autonómne služby. Každá služba je zodpovedná za jednu aplikačnú úlohu a komunikuje s ostatnými pomocou API.
Každá služba obsahuje aj všetky potrebné závislosti a nemusíte ju prepájať s externými zdrojmi.
Mikroslužby sú skvelé pre aplikácie vyvinuté veľkými organizáciami. Jeden tím môže pracovať na jednej službe, zatiaľ čo druhý tím pracuje na inej. Tieto služby potom môžete otestovať a nasadiť samostatne.
Príkladom systému mikroslužieb je aplikácia elektronického obchodu so samostatnými službami na spracovanie používateľského rozhrania, nákupného košíka, inventára a objednávok.
Výhody architektúry mikroslužieb
Flexibilita a škálovateľnosť
Keďže každá mikroslužba je nezávislá od ostatných, môžete ich vyvíjať a nasadzovať samostatne. Ak sa určitá služba spomalí, môžete ju spustiť na výkonnejšom hardvéri alebo pridať ďalšie procesory na servery, na ktorých je spustená.
Môžete tiež spustiť dve inštancie mikroslužby paralelne.
Jednoduchá údržba a aktualizácie
Ak vytvoríte aplikáciu podľa architektúry mikroslužieb, môžete ju upgradovať postupne. Môžete vykonávať zmeny v službe a aktualizovať ju bez ovplyvnenia ostatných častí aplikácie.
Potenciál pre rýchlejší rozvoj a nasadenie
Malé tímy spolupracujú na vývoji každej mikroslužby. Keďže mikroslužba vykonáva špecifickú úlohu, členovia tímu sa môžu sústrediť len na túto úlohu.
Navyše koordinácia a rozhodovanie v malom tíme sú rýchlejšie ako vo veľkom tíme. To vedie k rýchlejšiemu vývojovému cyklu.
Nezávislé technologické voľby
Môžete sa rozhodnúť vyvinúť mikroslužbu v inom programovacom jazyku ako ostatné mikroslužby. Môžete napríklad použiť Python na vývoj jednej mikroslužby a JavaScript pre inú. Pre každý z nich môžete použiť aj iné služby správy databázy. Nakoniec budete budovať služby s najvhodnejšou technológiou alebo nástrojom.
Výzvy implementácie architektúry mikroslužieb
Zložitosť koordinácie rôznych služieb
Aplikácia môže pozostávať z mnohých služieb, ktoré musia medzi sebou komunikovať. Tieto komunikačné kanály musia byť bezpečné a robustné, aby aplikácia fungovala podľa plánu.
Problémy s ladením a testovaním
Chyby, ktoré môžete izolovať na jednu službu, sa riešia jednoduchšie. Keď sa však tieto chyby týkajú viacerých služieb, ladenie sa stáva väčšou výzvou. podobne, písanie integračných testov pre viacero služieb môže byť ťažké.
Potenciál zvýšenej réžie
Ako už bolo spomenuté, každá služba je nezávislá od ostatných a má svoje vlastné zdroje. To môže byť drahé, pretože každá služba vyžaduje vyhradenú infraštruktúru pozostávajúcu okrem iného zo serverov, nástrojov na nepretržitú integráciu a databáz.
Kedy použiť architektúru Microservices
Architektúra mikroslužieb nie je vhodná pre všetky aplikácie. Jeho výstavba a správa môže byť nákladná.
Pred rozhodnutím použiť architektúru mikroslužieb zvážte veľkosť a zložitosť vašej aplikácie. Uvidíte väčší úžitok z rozdelenia veľkej aplikácie na spravovateľné zdroje ako z malej aplikácie. Pri dostatočne malej veľkosti môže ísť o plytvanie zdrojmi.
Ak však máte veľký tím vývojárov, ktorí potrebujú rýchlo pochopiť kódovú základňu alebo chcú používať rôzne technológie, architektúra mikroslužieb môže byť tou správnou cestou.