찾다
Javajava지도 시간Spring API Gateway 및 Micronaut를 사용하여 API 게이트웨이에서 마이크로서비스 및 Swagger UI 집계

이 가이드에서는 간소화된 마이크로서비스 API 문서화를 위해 Swagger 3(OpenAPI)를 Spring Cloud Gateway와 통합하는 방법을 보여줍니다. Java 21, Spring Boot 3.2 및 Micronaut를 활용하여 강력하고 사용자 친화적인 솔루션을 만들겠습니다.

Swagger/OpenAPI를 선택하는 이유는 무엇입니까?

현재 OAS(OpenAPI 사양)인 Swagger는 선도적인 API 문서 표준입니다. 그 이점은 다음과 같습니다.

  • 업계 표준: 풍부한 도구 생태계를 통해 널리 채택되고 지원됩니다.
  • 대화형 문서: 개발자가 API를 직접 탐색하고 테스트할 수 있도록 사용자 친화적인 문서를 생성합니다.
  • 개발자 생산성 향상: SDK 및 서버 스텁용 코드 생성과 같은 기능으로 API 개발을 가속화합니다.
  • 향상된 협업: 개발자, 테스터 및 이해관계자를 위한 API 기능에 대한 공통된 이해를 제공합니다.
  • 간소화된 테스트 및 디버깅: Swagger UI에는 API 응답을 검증하기 위한 테스트 인터페이스가 포함되어 있습니다.
  • 교차 언어 지원: 다양한 기술 스택을 완벽하게 통합합니다.
  • 쉬운 통합: Spring Boot 및 Micronaut와 같은 널리 사용되는 프레임워크와 간단하게 통합됩니다.
  • 자동화 친화적: API 수명주기 관리 자동화를 지원합니다.
  • 엔터프라이즈 옵션이 포함된 오픈 소스: 엔터프라이즈 옵션이 포함된 무료 오픈 소스 도구로 제공됩니다.

Spring Cloud Gateway: 재단

Spring Framework 5, Spring Boot 2 및 Project Reactor를 기반으로 구축된 Spring Cloud Gateway는 마이크로서비스에 대한 요청을 라우팅하고 필터링하기 위한 중앙 진입점 역할을 합니다.

Spring Cloud Gateway의 작동 방식:

아래 다이어그램은 Spring Cloud Gateway의 작동을 보여줍니다.

Aggregate Microservices

클라이언트 요청은 정의된 경로를 기준으로 평가됩니다. 일치하는 요청은 요청 프록시 전후에 사전 및 사후 필터를 실행하는 게이트웨이 웹 처리기에 의해 처리됩니다.

애플리케이션 구축:

Aggregate Microservices

전제 조건:

  1. 자바 21
  2. Gradle(또는 Maven)
  3. Spring Boot 3.2 이상
  4. Spring Cloud Gateway와 Swagger의 이해
  5. 마이크로너트

단계별 구현:

1단계: Micronaut 애플리케이션 생성(Job, Perk, Tag Services)

Micronaut Launcher([런처 링크])를 사용하여 job-service, perk-servicetag-service 세 가지 Micronaut 애플리케이션을 만듭니다. Java 또는 Kotlin, 안정적인 최신 Micronaut 버전, Swagger UI 및 OpenAPI를 기능으로 선택하세요. Gradle 또는 Maven을 빌드 도구로 사용합니다. 각 서비스에는 액세스 가능한 Swagger UI가 있습니다(예: http://localhost:8081/swagger-ui/index.html의 경우 job-service). CLI를 사용할 수도 있습니다:

mn create-app --build=gradle_kotlin --jdk=21 --lang=java --test=junit --features=openapi,swagger-ui dev.job.job

(perk-servicetag-service에 대해 반복하고 이에 따라 패키지 이름을 조정).

2단계: Spring Boot API 게이트웨이 생성

Spring 초기화([Spring 초기화에 대한 링크])를 사용하여 Spring Boot 프로젝트를 생성하세요. Spring Cloud Gateway, Spring Boot Actuator 및 Spring Web과 같은 종속성을 포함합니다.

3단계: Swagger를 API 게이트웨이에 통합

pom.xml(Maven) 또는 build.gradle(Gradle)에 필요한 Springdoc 종속성을 추가합니다.

dependencies {
    implementation("org.springframework.cloud:spring-cloud-starter-gateway")
    implementation("org.springdoc:springdoc-openapi-starter-webmvc-api:2.8.3")
    implementation("org.springdoc:springdoc-openapi-starter-webflux-ui:2.8.3")
}

Swagger UI를 활성화하고 각 마이크로서비스의 Swagger YAML 파일에 대한 URL을 지정하도록 application.yml을 구성합니다.

springdoc:
  api-docs:
    enabled: true
  swagger-ui:
    enabled: true
    path: /swagger-ui.html
    config-url: /v3/api-docs/swagger-config
    urls:
      - name: Job Service
        url: http://localhost:8081/swagger/job-service-0.0.yml
      - name: Perk Service
        url: http://localhost:8082/swagger/perk-0.0.yml
      - name: Tag Service
        url: http://localhost:8083/swagger/tag-0.0.yml

application.yml:

에서 API 게이트웨이 포트를 8080으로 설정합니다.
server:
  port: 8080
spring:
  application:
    name: web-api-gateway

4단계: 애플리케이션 실행

4개의 애플리케이션(3개의 Micronaut 서비스 및 Spring Boot Gateway)을 각각 시작합니다. Gateway의 Swagger UI는 http://localhost:8080/webjars/swagger-ui/index.html.

에서 액세스할 수 있습니다.

Aggregate Microservices

결론:

이러한 결합된 접근 방식은 강력하고 잘 문서화된 마이크로서비스 아키텍처를 제공합니다. Spring Cloud Gateway는 요청을 효율적으로 라우팅하는 반면 Swagger는 중앙 집중식 대화형 API 문서 경험을 제공합니다. 이 설정은 개발자 생산성과 협업을 크게 향상시킵니다. 자리 표시자 URL을 마이크로서비스 Swagger YAML 파일의 실제 URL로 바꾸는 것을 잊지 마세요.

위 내용은 Spring API Gateway 및 Micronaut를 사용하여 API 게이트웨이에서 마이크로서비스 및 Swagger UI 집계의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Java의 클래스로드 메커니즘은 다른 클래스 로더 및 대표 모델을 포함하여 어떻게 작동합니까?Mar 17, 2025 pm 05:35 PM

Java의 클래스 로딩에는 부트 스트랩, 확장 및 응용 프로그램 클래스 로더가있는 계층 적 시스템을 사용하여 클래스로드, 링크 및 초기화 클래스가 포함됩니다. 학부모 위임 모델은 핵심 클래스가 먼저로드되어 사용자 정의 클래스 LOA에 영향을 미치도록합니다.

카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?카페인 또는 구아바 캐시와 같은 라이브러리를 사용하여 자바 애플리케이션에서 다단계 캐싱을 구현하려면 어떻게해야합니까?Mar 17, 2025 pm 05:44 PM

이 기사는 카페인 및 구아바 캐시를 사용하여 자바에서 다단계 캐싱을 구현하여 응용 프로그램 성능을 향상시키는 것에 대해 설명합니다. 구성 및 퇴거 정책 관리 Best Pra와 함께 설정, 통합 및 성능 이점을 다룹니다.

Java에서 기능 프로그래밍 기술을 어떻게 구현할 수 있습니까?Java에서 기능 프로그래밍 기술을 어떻게 구현할 수 있습니까?Mar 11, 2025 pm 05:51 PM

이 기사는 Lambda 표현식, 스트림 API, 메소드 참조 및 선택 사항을 사용하여 기능 프로그래밍을 Java에 통합합니다. 간결함과 불변성을 통한 개선 된 코드 가독성 및 유지 관리 가능성과 같은 이점을 강조합니다.

캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA (Java Persistence API)를 어떻게 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:43 PM

이 기사는 캐싱 및 게으른 하중과 같은 고급 기능을 사용하여 객체 관계 매핑에 JPA를 사용하는 것에 대해 설명합니다. 잠재적 인 함정을 강조하면서 성능을 최적화하기위한 설정, 엔티티 매핑 및 모범 사례를 다룹니다. [159 문자]

고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?고급 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 또는 Gradle을 어떻게 사용합니까?Mar 17, 2025 pm 05:46 PM

이 기사에서는 Java 프로젝트 관리, 구축 자동화 및 종속성 해상도에 Maven 및 Gradle을 사용하여 접근 방식과 최적화 전략을 비교합니다.

비 블로킹 I/O에 Java의 NIO (새로운 입력/출력) API를 어떻게 사용합니까?비 블로킹 I/O에 Java의 NIO (새로운 입력/출력) API를 어떻게 사용합니까?Mar 11, 2025 pm 05:51 PM

이 기사에서는 선택기와 채널을 사용하여 단일 스레드와 효율적으로 처리하기 위해 선택기 및 채널을 사용하여 Java의 NIO API를 설명합니다. 프로세스, 이점 (확장 성, 성능) 및 잠재적 인 함정 (복잡성,

적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?적절한 버전 및 종속성 관리로 Custom Java 라이브러리 (JAR Files)를 작성하고 사용하려면 어떻게해야합니까?Mar 17, 2025 pm 05:45 PM

이 기사에서는 Maven 및 Gradle과 같은 도구를 사용하여 적절한 버전 및 종속성 관리로 사용자 정의 Java 라이브러리 (JAR Files)를 작성하고 사용하는 것에 대해 설명합니다.

네트워크 통신에 Java의 Sockets API를 어떻게 사용합니까?네트워크 통신에 Java의 Sockets API를 어떻게 사용합니까?Mar 11, 2025 pm 05:53 PM

이 기사는 네트워크 통신을위한 Java의 소켓 API, 클라이언트 서버 설정, 데이터 처리 및 리소스 관리, 오류 처리 및 보안과 같은 중요한 고려 사항에 대해 자세히 설명합니다. 또한 성능 최적화 기술, i

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.