МЕТОДИ РЕАЛІЗАЦІЇ МІКРОСЕРВІСНИХ АРХІТЕКТУР: ПЕРЕВАГИ ТА НЕДОЛІКИ, ВПРОВАДЖЕННЯ ТА ТЕСТУВАННЯ ПРИ РОЗРОБЦІ ПРОГРАМНИХ ЗАСТОСУНКІВ

Автор(и)

  • НАТАЛІЯ ПРАВОРСЬКА Хмельницький національний університет Автор
  • СЕРГІЙ ГРИГА Хмельницький національний університет Автор https://orcid.org/0009-0002-4409-4531

DOI:

https://doi.org/10.31891/2307-5732-2024-335-3-55

Ключові слова:

мікросервіси, мікросервісна архітектура, технології розробки програмних застосунків, патерни проектування, конструювання програмного забезпечення, тестування

Анотація

Розробка мікросервісної архітектури є складним та комплексним процесом, що потребує глибокого розуміння багатьох аспектів її реалізації. У даній статті було розглянуто дану архітектуру, її переваги та недоліки, у яких випадках її доцільно використовувати, деякі важливі методи, технології, патерни та підходи до тестування. Особливий акцент робиться на важливість коректного розбиття функціоналу системи на мікросервіси, що можна ефективно провести за допомого підходу Еріка Еванса «domain-driven design» та використанню граничних контекстів.

Серед важливих технологій, які було розглянуто, відносяться контейнеризація та оркестрація контейнерів, що при використанні у зв’язці дозволяють помістити кожен мікросервіс у окремий контейнер які можна швидко та легкого запустити на різних операційних системах без необхідності попереднього налаштування їхніх параметрів, допомагає ефективно використовувати і розподіляти ресурси між ними, а також спрощує процес управління.

Ефективність, та ряд інших важливих параметрів програмного продукту, напряму залежать від обраних патернів проектування та якості їхньої реалізації, наприклад, патерн вимикач при коректній розробці та налаштуванні може забезпечувати стабільну роботу всієї системи навіть за умови некоректної роботи окремих мікросервісів, що тимчасово обмежуються і стають недоступними для виклику до виправлення всіх помилок, чи шлюз та патерн «Sega», що дозволяють забезпечити маршрутизацію запитів та підтримувати коректну роботу кожного мікросервісу за умов виникнення різного виду помилок.

Тестування мікросервісної архітектури є надзвичайно важливим та комплексним завданням, від якого залежить вся подальша робота системи, тому було визначено, що його доцільно проводити одночасно за допомогою декількох різних методів тестування, а саме юніт-тестів, інтегрованого та наскрізного тестування, що у сукупності дозволяють на різних рівнях та етапах розробки перевірити коректність роботи, як усієї системи, так і її окремих елементів, що дозволяє швидко виявити помилки та усунути їх до розгортання програмного забезпечення.

В результаті досліджень було визначено та проаналізовано переваги та недоліки мікросервісної архітектури, доцільність її використання та ряд сучасних технологій, патернів проектування та способів тестування, що в сукупності допоможуть уникнути ряду проблем при розробці та створити якісну мікросервісну архітектуру.

Ключові слова: мікросервіси, мікросервісна архітектура, технології розробки програмних застосунків, патерни проектування, конструювання програмного забезпечення, тестування.

 

 

Developing a microservice architecture is a complex and comprehensive process that requires a deep understanding of many aspects of its implementation. This article discusses this architecture, its advantages and disadvantages, when it is appropriate to use it, and some important methods, technologies, patterns, and approaches to testing. Particular emphasis is placed on the importance of correctly dividing the system functionality into microservices, which can be effectively done with the help of Eric Evans' domain-driven design approach and the use of boundary contexts.

Among the important technologies that were considered were containerization and container orchestration, which, when used in conjunction, allow each microservice to be placed in a separate container that can be quickly and easily run on different operating systems without the need to pre-configure their parameters, helps to efficiently use and allocate resources between them, and simplifies the management process.

Efficiency, and a number of other important parameters of a software product, directly depend on the selected design patterns and the quality of their implementation, for example, the switch pattern, if properly designed and configured, can ensure stable operation of the entire system even if individual microservices are not working correctly, temporarily limited and become unavailable for calling until all errors are corrected, or the gateway and the Sega pattern, which allow you to route requests and maintain the correct operation of each microservice in the event of a problem.

Testing of microservice architecture is an extremely important and complex task, on which all further operation of the system depends, so it was determined that it should be carried out simultaneously using several different testing methods, namely unit tests, integrated and end-to-end testing, which together allow at different levels and stages of development to check the correctness of the operation of both the entire system and its individual elements, which allows you to quickly identify errors and eliminate them before deploying the software.

As a result of the research, the advantages and disadvantages of microservice architecture, the feasibility of its use, and a number of modern technologies, design patterns and testing methods were identified and analyzed, which together will help to avoid a number of problems in the development and create a high-quality microservice architecture.

Keywords: microservices, microservice architecture, software application development technologies, design patterns, software design, testing.

Завантаження

Опубліковано

30.05.2024

Як цитувати

ПРАВОРСЬКА, Н., & ГРИГА, С. (2024). МЕТОДИ РЕАЛІЗАЦІЇ МІКРОСЕРВІСНИХ АРХІТЕКТУР: ПЕРЕВАГИ ТА НЕДОЛІКИ, ВПРОВАДЖЕННЯ ТА ТЕСТУВАННЯ ПРИ РОЗРОБЦІ ПРОГРАМНИХ ЗАСТОСУНКІВ. Herald of Khmelnytskyi National University. Technical Sciences, 335(3(1), 404-408. https://doi.org/10.31891/2307-5732-2024-335-3-55