이 참조 아키텍처는 Azure Integration Services를 사용하여 엔터프라이즈 백 엔드 시스템에 대한 호출을 오케스트레이션합니다. 백 엔드 시스템에는 SaaS(Software as a Service) 시스템, Azure 서비스 및 기업의 기존 웹 서비스가 포함될 수 있습니다.
아키텍처
이 아키텍처의 Visio 파일을 다운로드합니다.
워크플로
애플리케이션
. 애플리케이션은 Microsoft Entra를 사용하여 인증한 후 API 게이트웨이를 호출하는 클라이언트입니다. 애플리케이션은 웹앱, 모바일 앱 또는 HTTP 요청을 수행할 수 있는 다른 클라이언트일 수 있습니다. Microsoft Entra ID. 클라이언트 애플리케이션을 인증하는 데 사용됩니다. 클라이언트 애플리케이션은 Microsoft Entra ID에서 액세스 토큰을 가져오고 API 게이트웨이에 대한 요청에 포함합니다.
Azure API Management. API Management는 두 가지 관련 구성 요소로 구성됩니다.
API 게이트웨이. API 게이트웨이는 클라이언트 애플리케이션에서 HTTP 호출을 수락하고, Microsoft Entra ID에서 토큰의 유효성을 검사하고, 백 엔드 서비스에 요청을 전달합니다. API 게이트웨이는 요청 및 응답을 변환하고 응답을 캐시할 수도 있습니다.
개발자 포털. 개발자 포털 개발자가 API를 검색하고 상호 작용하는 데 사용됩니다. 개발자 포털은 조직의 브랜딩에 맞게 사용자 지정할 수 있습니다.
Azure Logic Apps. 논리 앱은 백 엔드 서비스에 대한 호출을 오케스트레이션하는 데 사용됩니다. 논리 앱은 다양한 이벤트에 의해 트리거될 수 있으며 다양한 서비스를 호출할 수 있습니다. 이 솔루션에서 Logic Apps는 백 엔드 서비스를 호출하고 커넥터를 통해 쉽게 연결할 수 사용자 지정 코드의 필요성을 줄이는 데 사용됩니다.
백 엔드 서비스
. 백 엔드 서비스는 데이터베이스, 웹 서비스 또는 SaaS 애플리케이션과 같은 모든 서비스 또는 기간 업무 애플리케이션일 수 있습니다. 백 엔드 서비스는 Azure 또는 온-프레미스에서 호스트할 수 있습니다.
구성 요소
-
통합 서비스는 애플리케이션, 데이터 및 프로세스를 통합하는 데 사용할 수 있는 서비스 모음입니다. 이 솔루션에서는 Logic Apps 및 API Management의 두 가지 서비스가 사용됩니다. Logic Apps는 시스템 간의 메시지 기반 통합을 용이하게 하고 커넥터와의 연결을 용이하게 하는 데 사용됩니다. API Management는 백 엔드 서비스에 대한 외관을 제공하는 데 사용되어 클라이언트가 상호 작용할 수 있는 일관된 인터페이스를 허용합니다.
- Logic Apps는 애플리케이션, 데이터 및 서비스를 통합하는 엔터프라이즈 워크플로를 빌드하기 위한 서버리스 플랫폼입니다. 이 솔루션에서 Logic Apps는 백 엔드 서비스에 대한 호출을 오케스트레이션하고 커넥터를 통해 쉽게 연결하여 사용자 지정 코드의 필요성을 줄이는 데 사용됩니다.
- API Management는 HTTP API의 카탈로그를 게시하기 위한 관리형 서비스입니다. 이를 사용하여 API의 재사용 및 검색 가능성을 높이고 API 게이트웨이를 프록시 API 요청에 배포할 수 있습니다. 이 솔루션에서 API Management는 백 엔드 서비스에 대한 속도 제한, 인증 및 캐싱과 같은 추가 기능을 제공합니다. 또한 API Management는 클라이언트가 API를 검색하고 상호 작용할 수 있는 개발자 포털을 제공합니다.
- Azure DNS는 DNS 도메인에 대한 호스팅 서비스입니다. Azure DNS는 API Management 서비스에 대한 공용 DNS 레코드를 호스팅합니다. 이렇게 하면 클라이언트가 DNS 이름을 API Management 서비스의 IP 주소로 확인할 수 있습니다.
- Microsoft Entra ID는 클라우드 기반 ID 및 액세스 관리 서비스입니다. 엔터프라이즈 직원은 Microsoft Entra ID를 사용하여 외부 및 내부 리소스에 액세스할 수 있습니다. 여기서 Entra ID는 Entra B2C사용하여 OAuth 2.0 및 개발자 포털을 사용하여 API Management 서비스를 보호하는 데 사용됩니다.
시나리오 정보
통합 서비스는 엔터프라이즈의 애플리케이션, 데이터 및 프로세스를 통합하는 데 사용할 수 있는 서비스 모음입니다. 이 아키텍처는 워크플로를 오케스트레이션하는 Logic Apps 및 API 카탈로그를 만드는 API Management 서비스를 사용합니다.
이 아키텍처에는 논리 앱을 API로 가져와서 복합 API를 빌드합니다. WSDL 사양에서 OpenAPI(Swagger) 사양 가져오기 또는 SOAP API 가져오기를 통해 기존 웹 서비스를 가져올 수도 있습니다.
API 게이트웨이를 사용하여 백 엔드에서 프런트 엔드 클라이언트를 분리할 수 있습니다. 예를 들어 URL을 다시 작성하거나, 요청이 백 엔드에 도달하기 전에 변환할 수 있습니다. 또한 인증, CORS(원본 간 리소스 공유) 지원, 응답 캐싱 등 여러 교차 편집 문제를 처리합니다.
잠재적인 사용 사례
이 아키텍처는 백 엔드 서비스에 대한 비동기 호출로 인해 워크플로가 트리거되는 기본 통합 시나리오에 충분합니다. 큐 및 이벤트를 사용하는 더 정교한 아키텍처는 이러한 기본 카키텍처를 기반으로 합니다.
권장 사항
여러분의 요구 사항이 여기에 제시된 일반 아키텍처와 다를 수 있습니다. 이 섹션의 권장 사항을 시작점으로 사용합니다.
API Management
API Management 기본, 표준 또는 프리미엄 계층을 사용합니다. 이러한 계층은 프로덕션 SLA(서비스 수준 계약)를 제공하고 Azure 지역 내에서 스케일 아웃을 지원합니다. API Management의 처리량은 단위로 측정됩니다. 각 가격 책정 계층에는 최대 규모 확장이 있습니다. 프리미엄 계층은 여러 Azure 지역에서도 스케일 아웃을 지원합니다. 기능 집합 및 필요한 처리량의 수준을 기준으로 계층을 선택합니다. 자세한 내용은 API Management 가격 책정 및 Azure API Management 인스턴스의 용량을 참조하세요.
API Management 사용 계층은 이 아키텍처에 필요한 개발자 포털을 지원하지 않으므로 이 솔루션에 권장되지 않습니다. 개발자 계층은 비프로덕션 환경에 적합하며 프로덕션 워크로드에는 권장되지 않습니다. 계층 간의 차이점을 자세히 설명하는 기능 매트릭스는여기에서
각 Azure API Management 인스턴스는 기본 도메인 이름을 가지며, 이 이름은 azure-api.net
의 하위 도메인입니다(예: contoso.azure-api.net
). 조직에 사용자 지정 도메인을 구성하는 방안을 고려해 보세요.
Logic Apps
Logic Apps는 짧은 응답 대기 시간이 필요하지 않은 시나리오에 가장 적합합니다(예: 비동기 또는 반장기 실행 API 호출). 사용자 인터페이스를 차단하는 호출과 같이 짧은 대기 시간이 필요한 경우 다른 기술을 사용하세요. 예를 들어, Azure App Service에 배포되는 Azure Functions 또는 Web API를 사용합니다. API 사용자에게 API를 향하도록 API Management를 사용합니다.
지역
네트워크 대기 시간을 최소화할 수 있도록, API Management와 Logic Apps를 동일한 지역에 프로비전합니다. 일반적으로 사용자(또는 백 엔드 서비스)와 가장 가까운 지역을 선택합니다.
고려 사항
이러한 고려 사항은 워크로드의 품질을 향상시키는 데 사용할 수 있는 일련의 기본 원칙인 Azure Well-Architected Framework의 핵심 요소를 구현합니다. 자세한 내용은 Microsoft Azure Well-Architected Framework를 참조하세요.
안정성
안정성을 통해 애플리케이션이 고객에 대한 약속을 충족할 수 있습니다. 자세한 내용은 안정성대한
여기에서 각 서비스
프리미엄 계층을 사용하여 두 개 이상의 지역에 API Management를 배포하면 더 높은 SLA를 얻을 수 있습니다. API Management 가격 책정을 참조하세요.
Backup
API Management 구성을 주기적으로 백업합니다. 서비스가 배포된 곳과 다른 위치 또는 Azure 지역에 백업 파일을 저장합니다. RTO에 따라 재해 복구 전략을 선택합니다.
재해 복구 이벤트에서 새 API Management 인스턴스를 프로비전하고, 백업을 새 인스턴스로 복원하고, DNS 레코드를 다시 지정합니다.
다른 Azure 지역에서 API Management 서비스의 패시브 인스턴스를 유지합니다. 주기적으로 백업을 해당 인스턴스에 복원하여 액티브 서비스와 동기화를 유지합니다. 재해 복구 이벤트 중 서비스를 복원하려면 DNS 레코드만 다시 지정하면 됩니다. 이 방법은 패시브 인스턴스 비용이 발생하므로 비용이 증가하지만, 복구 시간이 단축됩니다.
논리 앱의 경우 코드로 구성(configuration-as-code) 방법으로 백업 및 복원하는 것이 좋습니다. 논리 앱은 서버리스이므로 Azure Resource Manager 템플릿에서 신속하게 다시 만들 수 있습니다. 원본 제어에 템플릿을 저장하고, 템플릿을 CI/CD(지속적인 통합/지속적인 배포) 프로세스와 통합합니다. 재해 복구 이벤트 발생 시, 템플릿을 새 지역에 배포합니다.
다른 지역에 논리 앱을 배포하는 경우 API Management에서 구성을 업데이트합니다. 기본 PowerShell 스크립트를 사용하여 API의 백 엔드 속성을 업데이트할 수 있습니다.
보안
우수한 보안은 중요한 데이터 및 시스템에 대한 고의적인 공격과 악용을 방어합니다. 자세한 내용은 보안대한
이 목록은 모든 보안 모범 사례를 완벽하게 설명하지는 않지만, 이 아키텍처에 한정적으로 적용되는 몇 가지 보안 고려 사항이 있습니다.
Azure API Management 서비스는 고정된 공용 IP 주소를 사용합니다. API Management의 IP 주소로만 Logic Apps 엔드포인트를 호출할 수 있도록 액세스가 제한됩니다. 자세한 내용은 인바운드 IP 주소 제한을 참조하세요.
사용자에게 적절한 액세스 수준이 있는지 확인하려면 RBAC(역할 기반 액세스 제어)를 사용합니다.
OAuth 또는 OpenID Connect를 사용하여 API Management에서 공용 API 엔드포인트를 보호합니다. 공용 API 엔드포인트를 보호하려면 ID 공급자를 구성하고, JWT(JSON Web Token) 유효성 검사 정책을 추가합니다. 자세한 내용은 Microsoft Entra ID 및 API Management에서 OAuth 2.0을 사용하여 API 보호를 참조하세요.
상호 인증서를 사용하여 API Management에서 백 엔드 서비스에 연결합니다. API Management API에 HTTPS를 적용합니다.
비밀 저장
암호, 액세스 키 또는 연결 문자열을 소스 제어로 체크 인하지 마세요. 이러한 값이 필요한 경우 적절한 기술을 사용하여 이러한 값을 보호하고 배포합니다.
논리 앱이 중요한 데이터로 작동하는 경우 자세한 지침은 Azure Logic Apps 워크플로에 대한 보안 액세스 및 데이터를 참조하세요.
API Management는 명명된 값 또는 속성이라는 개체를 사용하여 비밀을 관리합니다. 이러한 개체는 API Management 정책을 통해 액세스할 수 있는 값을 안전하게 저장합니다. 자세한 내용은 Azure API Management 정책에 명명된 값을 사용하는 방법을 참조하세요.
비용 최적화
비용 최적화는 불필요한 비용을 줄이고 운영 효율성을 개선하는 방법을 모색하는 것입니다. 자세한 내용은 비용 최적화대한
일반적으로 Azure 가격 계산기를 사용하여 비용을 예측합니다. 기타 고려 사항은 다음과 같습니다.
API Management
실행되고 있는 모든 API Management 인스턴스에 대한 요금이 청구됩니다. 시스템을 강화했는데 그 정도 성능 수준이 항상 필요한 것은 아닌 경우 수동으로 규모 축소하거나 자동 크기 조정을 구성합니다.
Logic Apps
Logic Apps는 서버리스 모델을 사용합니다. 청구는 작업 및 커넥터 실행에 따라 계산됩니다. 자세한 내용은 Logic Apps 가격 책정을 참조하세요.
자세한 내용은 Microsoft Azure Well-Architected Framework의 비용 섹션을 참조하세요.
운영 우수성
운영 우수성은 애플리케이션을 배포하고 프로덕션 환경에서 계속 실행하는 운영 프로세스를 다룹니다. 자세한 내용은 운영 우수성대한
DevOps
프로덕션, 개발 및 테스트 환경에 대해 별도의 리소스 그룹을 만듭니다. 별도의 리소스 그룹을 만들면 배포 관리, 테스트 배포 삭제, 액세스 권한 할당 등이 더 간단해집니다.
리소스 그룹에 리소스를 할당할 때는 다음 요소를 고려합니다.
수명 주기. 일반적으로 수명 주기가 같은 리소스를 동일한 리소스 그룹에 배치합니다.
Access. 그룹의 리소스에 액세스 정책을 적용하려면 Azure RBAC(Azure 역할 기반 액세스 제어)를 사용하면 됩니다.
청구. 리소스 그룹에 대한 롤업 비용을 확인할 수 있습니다.
API Management 가격 책정 계층. 개발 및 테스트 환경에는 개발자 계층을 사용합니다. 사전 프로덕션 기간에 비용을 최소화하려면 프로덕션 환경의 복제본을 배포하고 테스트를 실행한 다음, 종료합니다.
배포
Azure Resource Manager 템플릿을 사용하여 IaC(Infrastructure as Code) 프로세스에 따라 Azure 리소스를 배포합니다. 템플릿을 사용하면 Azure DevOps Services 또는 기타 CI/CD 솔루션을 사용하여 배포를 더 쉽게 자동화할 수 있습니다.
준비
워크로드를 준비하는 것이 좋습니다. 즉, 다음 단계로 이동하기 전에 다양한 단계에 배포하고 각 단계에서 유효성 검사를 실행합니다. 이 접근 방식을 사용할 경우 고도로 통제된 방식으로 프로덕션 환경에 업데이트를 푸시하고 예상치 못한 배포 문제를 최소화할 수 있습니다.
파란색-녹색 배포 및 카나리아 릴리스는 라이브 프로덕션 환경을 업데이트하기 위해 권장되는 배포 전략입니다. 또한 배포가 실패할 때 적절한 롤백 전략을 사용하는 것이 좋습니다. 예를 들어 배포 기록에서 이전에 성공한 배포를 자동으로 다시 배포할 수 있습니다. Azure CLI의 --rollback-on-error
플래그 매개 변수가 좋은 예입니다.
워크로드 격리
API Management 및 모든 개별 논리 앱을 별도의 자체 Resource Manager 템플릿에 배치합니다. 별도의 템플릿을 사용하면, 소스 제어 시스템에 리소스를 저장할 수 있습니다. 템플릿을 CI/CD 프로세스의 일부로 함께 또는 개별적으로 배포할 수 있습니다.
버전
논리 앱의 구성을 변경하거나 Resource Manager 템플릿을 통해 업데이트를 배포할 때마다 Azure는 해당 버전의 복사본을 유지하고 실행 기록이 있는 모든 버전을 유지합니다. 이러한 버전을 사용하여 기록 변경 내용을 추적하거나 버전을 논리 앱의 현재 구성으로 승격할 수 있습니다. 예를 들어 논리 앱을 이전 버전으로 롤백할 수 있습니다.
API Management는 각각 별개이지만 상호 보완 관계인 두 가지 버전 관리 개념을 지원합니다.
버전을 통해 API 소비자는 요구 사항에 맞는 API 버전을 선택할 수 있습니다(예: v1, v2, 베타 또는 프로덕션).
수정 버전을 통해 API 관리자는 API에서 호환성이 손상되지 않는 변경 작업을 수행하고 변경 내용을 배포할 수 있으며, 변경 로그를 통해 API 소비자에게 변경 관련 정보를 제공할 수 있습니다.
개발 환경에서 수정을 만들고 Resource Manager 템플릿을 사용하여 다른 환경에서 해당 변경 내용을 배포할 수 있습니다. 자세한 내용은 여러 버전의 API 게시를 참조하세요.
또한 변경 내용을 최신 버전으로 만들어서 사용자에게 제공하기 전에 수정 버전을 사용하여 미리 API를 테스트할 수 있습니다. 그러나 부하 테스트 또는 통합 테스트에는 이 방법을 권장하지 않습니다. 대신에 별도의 테스트 또는 사전 프로덕션 환경을 사용합니다.
진단 및 모니터링
API Management와 Logic Apps 둘 다 Azure Monitor를 사용하여 운영을 모니터링합니다. Azure Monitor는 각 서비스에 구성된 메트릭을 기반으로 하여 정보를 제공하고 기본적으로 활성화됩니다. 자세한 내용은 다음을 참조하세요.
또한 각 서비스에는 다음 옵션이 있습니다.
보다 심층적인 분석 및 대시보드를 위해 Logic Apps 로그를 Azure Log Analytics로 보냅니다.
DevOps 모니터링이 가능하도록, API Management에 대해 Azure Application Insights를 구성할 수 있습니다.
API Management는 사용자 지정 API 분석용 Power BI 솔루션 템플릿을 지원합니다. 자체 분석 솔루션을 만들기 위해 이 솔루션 템플릿을 사용할 수 있습니다. 비즈니스 사용자의 경우 Power BI를 통해 보고서를 사용할 수 있습니다.
성능 효율성
성능 효율성은 워크로드의 크기를 조정하여 사용자가 효율적인 방식으로 요구 사항을 충족하는 기능입니다. 자세한 내용은 성능 효율성대한
상황에 따라 캐싱 정책을 추가하여 API Management의 확장성을 높일 수 있습니다. 또한 캐싱은 백 엔드 서비스의 로드를 줄이는 데 도움이 됩니다.
더 많은 용량을 제공하기 위해 Azure 지역 내에서 Azure API Management 기본, 표준 및 프리미엄 계층을 확장할 수 있습니다. 서비스의 사용량을 분석하려면 메트릭 메뉴에서 용량 메트릭을 선택한 다음, 적절하게 확장 또는 축소합니다. 업그레이드 또는 크기 조정 프로세스를 적용하는 데는 15~45분 정도 소요될 수 있습니다.
API Management 서비스 크기 조정에 대한 권장 사항:
크기를 조정하는 경우 트래픽 패턴을 고려합니다. 더욱 일시적인 트래픽 패턴을 사용하는 고객은 더 많은 용량이 필요합니다.
66%보다 큰 일관된 용량은 확장(스케일 업)이 필요할 수 있습니다.
20% 아래의 일관된 용량은 축소(스케일 다운)가 필요할 수 있습니다.
프로덕션 환경에서 부하를 사용하도록 설정하기 전에 항상 대표적인 부하를 사용하여 API Management 서비스의 부하를 테스트합니다.
프리미엄 계층을 사용하면 API Management 인스턴스를 여러 Azure 지역에 걸쳐 확장할 수 있습니다. 이렇게 하면 API Management의 SLA를 높일 수 있으며, 여러 지역에서 사용자와 가까운 서비스를 프로비전할 수 있습니다.
Logic Apps 서버리스 모델은 관리자가 서비스 확장성을 계획할 필요가 없음을 의미합니다. 서비스가 수요를 충족하도록 자동으로 확장됩니다.
다음 단계
관련 참고 자료
큰 안정성과 확장성을 위해 백 엔드 시스템을 분리하는 메시지 큐 및 이벤트를 사용합니다. 이 아키텍처는 이 시리즈의 다음 문서에 나와 있습니다.
Azure 아키텍처 센터의 다음 문서도 참조할 수도 있습니다.