통합이란?

URL 복사

IT 통합 또는 시스템 통합은 IT 조직 전체에서 데이터, 애플리케이션, API, 장치를 연결하여 효율성, 생산성, 민첩성을 높여줍니다. 통합은 IT의 모든 요소를 연동하기 위한 기반이므로 시장 변화에 맞춰 비즈니스를 수행하기 위한 혁신적이고 근본적인 변화를 모색하는 데 핵심 사안이 됩니다. 상호 연결의 수준을 넘어 다양한 시스템의 기능을 연결하여 새로운 기능을 제공함으로써 통합은 새로운 가치를 추가합니다. 예를 들어 Apache Kafka는 애플리케이션과 데이터 스트림을 통합하도록 지원하는 오픈소스 플랫폼이므로, 실시간으로 데이터에 대해 작업을 수행할 수 있습니다.

IT 통합은 작업하는 코드의 사본을 하루에 여러 번 공유 중앙 리포지토리에 병합하는 개발자 프랙티스인 지속적인 통합(Continuous Integration, CI)과는 다릅니다. CI의 목표는 조기에 문제를 탐지할 수 있도록 구축과 확인을 자동화하여 개발 속도를 높이는 것입니다.

IT 시스템은 시간이 지남에 따라 성장하고 발전하면서 넓은 영역으로 분산되기 시작했습니다. 이로 인해 한 벤더의 솔루션이 다른 벤더의 솔루션과 통신할 수 없게 되었습니다. 그리고 전체 IT 스택을 소유하고 있어야만 이 모든 스택이 연결될 수 있었습니다. 따라서 특히 비즈니스 로직을 구현하고 실행할 때 더 이상 작업이 중복되지 않도록 하려면 이 복잡하게 얽혀 있는 기술을 체계화할 방법이 필요했습니다.

*참고: 물리적 토폴로지와 논리적 토폴로지, 아키텍처와 기술 접근 방식은 의미에 관한 논쟁이 있을 수 있으며 아래 설명은 일반적인 개요를 제시하기 위한 것입니다.

엔터프라이즈 애플리케이션 통합

이렇게 서로 다른 요소들이 확산되는 문제를 해결하기 위한 솔루션은 애플리케이션 사이에서 메시지 기반의 실시간 통합을 구현하는 기술이자 툴링이자 프레임워크인 엔터프라이즈 애플리케이션 통합(Enterprise Application Integration, EAI)입니다. 이 메시지는 변경 사항이나 개별 애플리케이션 내에 빌드된 매개 변수로 트리거됩니다. EAI는 포인트 투 포인트와 허브앤스포크 2가지 방식 중 하나로 이루어졌습니다.

Point to point integration vs. hub and spoke integration

포인트 투 포인트 모델이란 IT 환경의 다른 애플리케이션 및 요소와 통신할 수 있도록 각각의 애플리케이션을 사용자 정의해야 한다는 뜻입니다. 즉, 각 IT 자산과 그에 연결되어 있는 모든 자산을 사용자 정의해야 합니다. 이것은 매우 번거로운 작업이며, 당연히 오류가 발생하기가 매우 쉽습니다. 더 복잡한 문제는, 인프라와 애플리케이션을 업데이트하면 시간이 지남에 따라 유지관리하기가 더 어려워질 수 있다는 것입니다.

이 문제를 해결하기 위해 중앙 브로커인 허브를 통해 애플리케이션과 서비스 간 연결을 처리하는 허브앤스포크 모델이 등장했습니다. 허브를 애플리케이션과 서비스에 연결하는 역할을 하는 스포크는 개별적으로 유지관리할 수 있습니다. 모든 통합 기술을 허브 및 스포크에서 처리하기 때문에 애플리케이션 자체에 더 집중하게 됩니다. 이 접근 방식의 주된 단점은 허브의 중앙화입니다. 중앙화된 허브는 시스템과 인프라 통신의 단일 장애 지점이 됩니다. EAI 허브앤스포크 모델의 모든 통합은 설계상 허브에 의존하여 기능을 발휘합니다.

엔터프라이즈 서비스 버스

EAI 허브앤스포크 접근 방식은 애플리케이션 간에 서비스를 모듈화하여 메시지 기반 추상화를 제공하는 툴인 ESB(엔터프라이즈 서비스 버스)에 적용되었습니다.

ESB는 이러한 모듈화된 서비스가 모두 공유되고 라우팅되고 애플리케이션과 데이터 간 연결을 위해 구성되도록 하는 중앙 허브의 역할도 합니다. ESB는 EAI 허브앤스포크를 위한 더 나은 솔루션이지만 조직은 성장하고, 자산이 늘어나고, 모든 자산과 소프트웨어 리소스에 더 빠른 속도를 요구하게 되므로 최종적인 솔루션은 아닙니다.

Enterprise Service Bus Integration

지금까지는 ESB가 허브앤스포크 모델과 상당히 유사하다고 생각했을 것입니다. 그렇기는 하지만 ESB에는 기능 측면에서 차별화되는 매우 뚜렷한 특징이 몇 가지 있습니다.

  • ESB는 오픈 표준에 따라 서비스로 구현됩니다. 따라서 애플리케이션마다 고유한 인터페이스를 작성할 필요가 없습니다.
  • 애플리케이션을 최소한으로 변경하면서 통합 서비스를 배포할 수 있습니다.
  • ESB는 산업 표준, 오픈 프로토콜, 인터페이스를 사용하여 쉽게 새로운 버전을 배포할 수 있습니다.

그러나 허브앤스포크와 관련하여 언급된 명확한 이유, 즉 한 곳에서 모든 통합 서비스를 호스팅하고 제어하기 위해 일반적인 ESB 배포가 중앙 집중화된 아키텍처로 이어지는 경우가 많습니다. 하지만 ESB 배포와 아키텍처가 중앙 집중화되면 중앙 거버넌스의 유연성이 떨어져 디지털 트랜스포메이션 이니셔티브의 기반을 구축하기 위한 속도와 적응성을 갖춘 솔루션을 제공하기 힘들어지며 ESB 자체가 모놀리식(Monolithic) 애플리케이션이 되는 경우도 종종 있습니다.

애자일 인테그레이션

지금까지는 통합, 즉 모든 것을 연동시키는 기술을 설명했습니다. 그렇다면 애자일 통합이란 무엇일까요? 간단히 말해, Red Hat이 연결된 시스템의 미래를 바라보는 방식, 특히 급변하는 환경에서 IT 팀이 완수해야 하는 실제 작업을 지원하는 방식을 말합니다.

Agile Integration - Hybrid Platform

Red Hat은 중앙화된 팀이 모놀리식 기술을 제어하는 통합에 대한 전통적인 접근 방식은 분산형 애플리케이션의 개발 및 장기적인 유용성을 저해할 수 있다고 생각합니다. ESB 같은 전통적인 통합 기술은 보안과 데이터 무결성을 우선시 하는 이점이 있지만, 동시에 전체 엔터프라이즈 통합에 대한 정의를 단일 팀에 의존한다는 한계도 있습니다.

애자일 및 DevOps 방법론을 통해 개발되어 탄력적으로 결합된 오늘날 클라우드 네이티브 애플리케이션 아키텍처는 민첩성과 확장성을 동등하게 중요시하는 통합 접근 방식을 필요로 합니다. Red Hat의 애자일 인테그레이션은 리소스를 연결하는 접근 방식으로, 통합 기술, 애자일 제공 기술 및 클라우드 네이티브 플랫폼을 결합하여 소프트웨어 제공 속도를 높이고 보안을 강화합니다. 특히 애자일 통합에서는 API 같은 통합 기술을 Linux 컨테이너로 배포하고 통합 역할을 다기능팀(Cross-Functional Team)으로 확장합니다. 애자일 통합 아키텍처의 3가지 주요 기능은 분산 통합, 컨테이너 그리고 애플리케이션 프로그래밍 인터페이스입니다.

분산형 통합

  • 소규모 IT 설치 공간
  • 패턴 기반
  • 이벤트 지향적
  • 커뮤니티 소싱

이점: 유연성

컨테이너

  • 클라우드 네이티브
  • 린(Lean), 개별 배포
  • 확장성, 고가용성

이점: 확장성

애플리케이션 프로그래밍 인터페이스(API)

  • 엔드포인트 정의와 관리 및 재사용성
  • 에코시스템 영향 및 사용

이점: 재사용성

Red Hat 리소스

Red Hat은 사일로화된 중앙 집중형 아키텍처보다는 분산 및 반복적인 통합 아키텍처가 애플리케이션 개발뿐만 아니라 인프라에도 민첩성을 더할 수 있다고 생각하기 때문입니다. 여기에 해당되는 요소는 무엇일까요? 컨테이너화된 마이크로서비스, 하이브리드 클라우드 및 애플리케이션 프로그래밍 인터페이스(Application Programming Interfaces, API)를 개발자에게 익숙한 애자일 및 DevOps 적용 사례에 맞춘 아키텍처 방식의 프레임워크가 이에 포함됩니다.

왜 애자일 인테그레이션에 Red Hat을 선택해야 할까요

허브

레드햇 공식 블로그

레드햇 공식 블로그에서 고객, 파트너, 커뮤니티 에코시스템 등 현재 화제가 되는 최신 정보를 살펴 보세요.

모든 Red Hat 제품 체험판

무료 제품 체험판을 통해 핸즈온 경험을 얻고, 자격증 시험에 대비하거나 해당 제품이 조직에 적합한지 평가할 수 있습니다.

추가 자료

애플리케이션 통합이란?

애플리케이션 통합은 데이터 교환과 서비스 사용을 통해 다양한 시스템과 애플리케이션이 함께 작동할 수 있도록 연결합니다.

API란? 기본 개념, 개발 방식, 종류, 서비스, Web API 연동 방법

API(애플리케이션 프로그래밍 인터페이스)는 응용프로그램과 시스템 간의 통신을 위한 인터페이스입니다. API의 역할, 중요성, 사용법, Web API 연동 방법을 알아보세요

미들웨어(middleware)란? 개념, 종류, 필요성

미들웨어란 운영 체제에서 제공하지 않는 일반적인 서비스와 기능을 애플리케이션에 제공하는 소프트웨어를 뜻하며, 개발자와 운영자가 애플리케이션을 효율적으로 구축하고 배포하도록 지원합니다.

인테그레이션 리소스