거의 모든 컴퓨터 시스템은 ‘공유되는 자원’을 사용해 여러 작업을 수행한다. 컴퓨터 프로그래밍의 질문 중 하나는 이러한 작업을 수행하는 코드 비트가 서로 얼마나 엮여야 하는가에 관한 것이다. 그리고 점점 더 인기를 얻고 있는 해답은 마이크로서비스 개념이다. 즉, 전체 시스템을 구성하는데 다른 마이크로서비스들과 상호 작용하는 작고 분리된 기능성 덩어리를 이용하는 개념이다.
이렇듯 분리된 구성요소를 갖는다는 개념이 완전히 새로운 것은 아니지만, 마이크로서비스가 구현되는 방식은 현대적이고 클라우드에 기반한 애플리케이션을 위한 자연스러운 토대를 만든다. 마이크로서비스는 또한 데브옵스 철학과 잘 들어맞는다. 새로운 기능성을 빠르고 지속적으로 출시하도록 장려하는 것이다.
ⓒ Image Credit : Getty Images Bank
마이크로서비스란?
마이크로서비스의 ‘마이크로’는 작은 애플리케이션들을 의미한다. 나름 사실에 기반한 설명이기는 하지만 그것들을 이해하는 더 좋은 방법은 그것들이 한 가지 특정한 일을 하거나 특정한 문제를 해결하기 위해 필요한 만큼만 커야 한다는 것이다. 즉 기술적이기보다는 개념적으로 접근하는 것이 바람직하다.
“마이크로서비스는 데이터 액세스나 메시징과 같은 수평적 계층이 아니라 비즈니스 기능을 중심으로 설계되어야 한다”라고 설명된다. 그것들은 비교적 안정적인 API를 통해 다른 마이크로서비스 및 외부 사용자들과 통신해 더 큰 애플리케이션을 만든다.
따라서, 개별 마이크로서비스의 기능성은 시스템의 나머지 부분에 영향을 미치지 않고 조정되거나 급격하게 업그레이드될 수 있다. 이는 다시 데브옵스 부문들이 어떻게 운영하려고 하는지와 관련이 있다. 더 큰 애플리케이션의 특정 기능이 독립적으로 작동하는 코드의 분리된 조각으로 세분화되면 CI/CD(지속적 통합 및 지속적 전달)의 데브옵스 더욱 쉽게 작동할 수 있다. 또한, 잘 정의된 API는 마이크로서비스들을 자동으로 테스트하기 쉽게 만든다.
마이크로서비스 아키텍처 vs 모놀리틱 아키텍처
마이크로서비스가 ‘마이크로서비스 아키텍처’의 측면에서 이야기되는 것을 종종 듣게 될 것이다. 이 표현은 마이크로서비스 자체뿐만 아니라 관리 및 서비스 발견 위한 구성요소뿐만 아니라 마이크로서비스와 외부 세계 간의 통신을 처리하는 API 게이트웨이를 망라한다.
일체형을 의미하는 ‘모놀리틱 애플리케이션’은 마이크로서비스 개념과는 정반대다. 이것은 모든 코드가 하나의 큰 이진법적 실행 파일에 있는 애플리케이션의 일반화된 표현이다. 이러한 일체형 애플리케이션은 확장과 개선이 더 어렵다. 그러나 단일한 응집력 있는 애플리케이션으로 구축되기 때문에 마이크로서비스 아키텍처만큼 많은 관리가 필요하지 않다.
개념의 한계 : 마이크로서비스를 어떻게 정의할 것인가?
마이크로서비스가 한 가지 특정한 일을 해야 한다는 이전의 설명으로 잠시 되돌아가보자. 말하기는 쉽지만, 실제로는 기능성이 서로 얽혀 있는 경우가 많으며, 구분되는 선을 긋는 것은 생각보다 어렵다.
도메인 분석과 도메인 기반 설계는 큰 그림을 그리는 작업을 마이크로서비스가 해결할 수 있는 개별적인 문제들로 풀어내는 데 도움이 되는 이론적 접근법이다. 당신은 이 프로세스에서 당신의 비즈니스 도메인의 추상적인 모델을 만들게 된다. 그리고 그 과정에서 특정한 방식으로 세상과 상호 작용하는 기능성을 함께 묶는 맥락을 발견하게 된다. 마이크로소프트가 게재한 일련의 블로그 포스트 시리즈에서 이에 대해 참조할 수 있다.
예를 들어, 당신은 배송에 대해 한 가지 격리된 맥락(bounded context)과 어카운트에 대한 또 다른 격리된 맥락을 가지고 있을 수 있다. 현실세계의 물리적인 물체는 물론 가격과 그것이 도착해야 할 장소를 둘 다 가지고 있을 것이다. 하지만 격리된 맥락은 당신의 애플리케이션이 그러한 물체들에 대해 생각하고 상호 작용하는 특정한 방법을 나타낸다. 일부 격리된 맥락이 둘 이상의 마이크로서비스를 포함할 수 있지만, 각 마이크로서비스는 하나의 격리된 맥락 내에 완전히 존재해야 한다.
마이크로서비스 vs 서비스 지향 아키텍처 vs 웹 서비스
IT 전문가라면 이 중 많은 부분이 친숙하게 들린다고 생각할 수도 있을 것이다. 작고 개별적인 프로그램이 함께 작동한다는 생각은 2000년대 웹 2.0 시절의 2가지 유행어인 SOA(서비스 지향 아키텍처)와 웹 서비스를 떠올리게 할 지도 모른다. 어떤 의미에서 이 세상에는 정말로 새로운 것이 없는 것이 사실이다. 그러나 이러한 개념과 마이크로서비스 사이에는 중요한 차이점이 있다.
- 서비스 지향 아키텍처에서 개별 구성요소는 상대적으로 단단하게 결합되어 스토리지와 같은 자산을 공유하는 경우가 많으며, 엔터프라이즈 스토리지 버스라고 하는 전문 소프트웨어를 통해 통신한다. 마이크로서비스는 더 독립적이며, 더 적은 자원을 공유하고, 더 가벼운 프로토콜을 통해 통신한다. 마이크로 서비스는 SOA 환경에서 생겨났으며, 때때로 SOA의 일종, 또는 개념의 계승자로 간주된다는 점에 주목할 가치가 있다.
- 웹 서비스는 공개적으로 직면하는 기능성의 집합으로, 다른 애플리케이션들이 웹을 통해 접속할 수 있는 기능성이다. 아마도 가장 일반적인 예는 구글맵일 것이다. 구글맵은 레스토랑의 웹사이트가 고객들에게 찾아오는 길을 알려주기 위해 탑재시킬 수 있다. 이것은 마이크로서비스 아키텍처에서 볼 수 있는 것보다 훨씬 더 느슨한 연결이다.
마이크로서비스 통신
마이크로서비스 아키텍처에 대해 자주 들을 수 있는 캐치프레이즈는 ‘똑똑한 엔드포인트와 멍청한 망 제공자’다. 즉, 마이크로서비스는 복잡하고 촘촘한 통합보다는 기본적이고 잘 확립된 통신 방법을 사용하는 것을 목표로 해야 한다. 앞서 언급한 바와 같이, 이것은 마이크로서비스와 SOA를 구분 짓는 또 다른 특성이다.
일반적으로 마이크로서비스 간의 통신은 코드 스레드가 응답을 기다리는 동안 차단되지 않는다는 점에서 비동기적이어야 한다. (AMQP (Advanced Message Queuing Protocol)와 같은 비동기 프로토콜은 마이크로서비스 아키텍처에서도 일반적이지만, HTTP와 같은 동기 통신 프로토콜을 사용하는 것은 여전히 괜찮다.)
이러한 종류의 느슨한 결합은 개별 요소나 네트워크의 부품이 고장 났을 때도 마이크로서비스 구조를 더욱 유연하게 만든다.
마이크로서비스, 자바, 그리고 스프링 부트 및 스프링 클라우드
마이크로서비스 분야의 첫 작품 중 일부는 자바 커뮤니티에서 생겨났다. 마틴 파울러는 초기 지지자였다. 폴란드에서 열린 2012 자바 컨퍼런스는 ‘마이크로 서비스 - 자바, 유닉스 웨이’라는 제목으로 이 주제에 대해 가장 중요한 초기 프레젠테이션 중 하나를 선보였다.
1970년대 최초의 유닉스 애플리케이션의 발전을 이끌었던 원칙들(‘한 가지 일을 하고 그것을 잘 하는 프로그램을 쓰라. 함께 작동하는 프로그램을 쓰라’)을 자바 개발에 적용할 것을 권고했다.
이러한 역사의 결과로 마이크로서비스를 구축할 수 있게 해주는 자바 프레임워크가 많아졌다. 가장 인기 있는 것 중 하나는 스프링 부트인데, 이것은 마이크로서비스용으로 특별히 고안되었다.
부트는 스프링 클라우드에 의해 확장되었는데, 이름이 시사하는 바와 같이, 당신이 이러한 서비스를 클라우드에도 배치할 수 있게 해준다. 스프링의 개발자인 피보탈 소프트웨어(Pivotal Software)는 이들 프레임워크를 사용하여 마이크로서비스 개발을 시작하는 데 대한 좋은 튜토리얼을 가지고 있다.
마이크로서비스와 콘테이너: 도커, 쿠버네티스 등등
마이크로서비스를 주류화하는 데 있어 가장 발전한 기반 기술은 콘테이너들이다. 콘테이너는 VM 인스턴스와 유사하지만, 전체의 자족적인 OS를 포함하는 대신, 호스트 운영 체제의 커널을 사용한다. 그러나 그 안에서 실행되는 코드는 계속해서 자족적이게 하는 고립된 사용자 공간일 뿐이다. 콘테이너는 VM 인스턴스보다 훨씬 작고 로컬 또는 클라우드에서 신속하게 배치하기가 용이하며 수요 및 가용 리소스에 맞게 스핀업 또는 스핀다운 될 수 있다.
마이크로서비스에 대한 콘테이너의 강점은 명확하다. 각 개별 마이크로서비스는 자체 콘테이너에서 실행될 수 있으므로 서비스 관리의 오버헤드를 크게 줄일 수 있다. 대부분의 콘테이너 구현에는 콘테이너 기반 애플리케이션의 배치, 관리, 확장, 네트워킹 및 가용성을 자동화하는 보완적인 조율 도구가 있다.
작고 구축이 용이한 마이크로서비스와 배치하기 쉬운 콘테이너의 조합으로 데브옵스 철학이 가능해진다. 콘테이너 개념의 구현에는 여러 가지가 있지만, 단연코 가장 인기 있는 것은 도커다. 이는 오케스트레이션 플랫폼으로서 일반적으로 쿠버네티스와 짝을 이룬다.
스프링은 인기가 있지만 자바 플랫폼에 묶여 있다. 반면에 콘테이너 기반의 시스템은 여러 언어로 가능하다. OS가 지원하는 프로그래밍 언어는 어떤 것이든 콘테이너에서 실행될 수 있으며, 이는 프로그래머들에게 더 많은 융통성을 준다. 실제로 마이크로서비스의 큰 장점은 각각의 개별 서비스가 가장 이치에 맞는 어떤 언어로든 작성될 수 있거나 개발자들이 가장 편하게 사용할 수 있다는 것이다.
사실 그것의 API가 안정적이기만 하다면, 서비스는 시스템 전체에 영향을 주지 않고 새로운 언어로 완전히 재구축될 수 있다. 디존(DZone)은 마이크로서비스에 대해서 스프링 클라우드 대 쿠버네티스의 장단점에 대해 논하는 기사를 냈다.
마이크로서비스의 디자인 유형
마이크로서비스를 개발하기 위해 어떤 언어를 사용하든, 당신은 이전에 다른 개발자들이 직면했던 문제에 직면하게 될 것이다. 디자인 유형은 컴퓨터 과학에서 반복되는 문제에 대해 공식화된 추상적인 해결책이며, 그 중 다수는 특별히 마이크로서비스를 위한 것이다. 디보페디아(Devopedia)는 다음과 같은 훌륭한 목록을 가지고 있다.
- 서비스 레지스트리 : 마이크로서비스의 이용가능한 인스턴스에 클라이언트를 연결시키기 위한 것
- 서킷 브레이커: 고장난 서비스가 반복해서 요청되지 않도록 하는 것
- 폴백: 고장난 서비스에 대안을 제공하기 위한 것
- 사이드카: 로깅, 서비스 동기화 또는 모니터링 등 메인 컨테이너에 보조 서비스를 제공하기 위한 것
- 어댑터: 메인 컨테이너와 외부 세계 사이의 인터페이스를 표준화하거나 정상화하는 것
- 앰버서더: 로컬호스트 연결을 외부 연결에 프록시하기 위한 것과 같이 메인 컨테이너를 외부 세계에 연결하는 것
마이크로서비스와 클라우드 : AWS와 애저
앞서 언급한 바와 같이, 컨테이너를 사용하는 장점 중 하나는 유연한 컴퓨팅 리소스를 사용하여 애플리케이션 효율성을 극대화할 수 있는 클라우드에 쉽게 구축할 수 있다는 것이다. 상상할 수 있는 것처럼 주요 퍼블릭 클라우드 공급업체들은 모두 마이크로서비스 기반의 애플리케이션을 실행하기 위해 플랫폼을 제공하고 있다. 보다 많은 정보는 아마존, 마이크로소프트 및 구글의 자료를 확인하도록 한다. ciokr@idg.co.kr
출처 : http://www.itworld.co.kr/t/34/%ED%81%B4%EB%9D%BC%EC%9A%B0%EB%93%9C/133523
'IT & Insight > IT News' 카테고리의 다른 글
"AI가 내취향 아네?"…플로, 음원시장 흔든다 (0) | 2019.10.25 |
---|---|
구글 고의 위력을 보여주는 10가지 오픈소스 프로젝트 (0) | 2019.10.23 |
KIST, 다수 로봇 효율적 분업 새 알고리즘 개발 (0) | 2019.10.21 |
ETRI, 한국전자전서 AI기술 등 소개 (0) | 2019.10.21 |
차세대 웹으로 진화하는 ‘HTML5’ (0) | 2019.10.18 |