목차
작동 방식
사용 팁
Java java지도 시간 SpringCloud에서 zuul의 원리와 사용법 소개

SpringCloud에서 zuul의 원리와 사용법 소개

Apr 11, 2019 pm 01:18 PM
java springboot springcloud

이 글은 Spring Cloud의 zuul의 원리와 사용법을 소개합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

소개

Zuul은 장치 및 웹 사이트에서 Netflix 스트리밍 애플리케이션의 백엔드까지 모든 요청을 처리하는 정문입니다. 엣지 서비스 애플리케이션인 Zuul은 동적 라우팅, 모니터링, 탄력성 및 보안을 지원하도록 구축되었습니다. 또한 필요에 따라 요청을 여러 Amazon Autoscaling 그룹으로 라우팅할 수도 있습니다.

Zuul은 다양한 유형의 필터를 사용하여 엣지 서비스에 기능을 빠르고 유연하게 적용할 수 있습니다. 이러한 필터는 다음 기능을 수행하는 데 도움이 됩니다.

  • 인증 및 보안 – 각 리소스에 대한 인증 요구 사항을 식별하고 해당 요구 사항을 충족하지 않는 요청을 거부합니다.
  • 통찰력 및 모니터링 – 엣지에서 의미 있는 데이터와 통계를 추적하여 생산에 대한 정확한 시각을 제공합니다.
  • 동적 라우팅 – 필요에 따라 요청을 다른 백엔드 클러스터로 동적으로 라우팅합니다.
  • 스트레스 테스트 – 클러스터에 대한 트래픽을 점차적으로 늘려 성능을 평가합니다.
  • 부하 감소 – 각 유형의 요청에 용량을 할당하고 한도를 초과하는 요청을 제거합니다.
  • 정적 응답 처리 - 일부 응답을 내부 클러스터로 전달하는 대신 엣지에서 직접 구축
  • 다중 지역 탄력성 - AWS 지역 전체에 요청을 라우팅하여 ELB 사용을 다양화하고 엣지를 더욱 향상시킵니다. 회원들에게 더 가까이 다가가세요

작동 방식

상위 수준 보기에서 Zuul 2.0은 사전 필터(인바운드 필터)를 실행한 다음 Netty 클라이언트를 사용하여 요청을 프록시한 다음 반환하기 전에 사후 필터(아웃바운드 필터)를 실행하는 Netty 서버입니다. 응답.

SpringCloud에서 zuul의 원리와 사용법 소개

필터는 Zuul 비즈니스 로직의 핵심입니다. 위 다이어그램에 표시된 것처럼 매우 광범위한 작업을 수행할 수 있으며 요청-응답 수명 주기의 다양한 부분에서 작동할 수 있습니다.

  • 인바운드 필터는 원본으로 라우팅하기 전에 실행되며 요청을 인증, 라우팅 및 장식하는 데 사용할 수 있습니다.
  • 엔드포인트 필터를 사용하여 정적 응답을 반환할 수 있습니다. 그렇지 않으면 내장된 ProxyEndpoint 필터가 요청을 원본으로 라우팅합니다.
  • 아웃바운드 필터는 소스로부터 응답을 받은 후 실행되며 사용자 응답을 측정하고 장식하거나 사용자 정의 헤더를 추가하는 데 사용할 수 있습니다.

필터에는 동기 및 비동기라는 두 가지 유형이 있습니다. 이벤트 루프에서 실행 중이므로 필터를 차단하지 마세요. 차단하려면 별도의 스레드 풀에서 비동기 필터를 차단하세요. 그렇지 않으면 동기 필터를 사용하세요.

유틸리티 필터

  • DebugRequest - 추가 디버그 로그를 요청에 추가하기 위한 쿼리 매개변수를 찾습니다.
  • Healthcheck - 모든 것이 올바르게 부트스트랩된 경우 200을 반환하는 간단한 정적 엔드포인트 필터
  • ZuulResponseFilter - 정보 추가 헤더는 다음에 대한 추가 세부 정보를 제공합니다. 라우팅, 요청 실행, 상태 및 오류 이유
  • GZipResponseFilter - gzip 아웃바운드 응답 활성화 가능
  • SurgicalDebugFilter - 디버깅을 위해 특정 요청을 다른 호스트로 라우팅할 수 있음

사용 팁

다음에 따라 다름: 필터 필터

    <dependency>
            <groupid>org.springframework.cloud</groupid>
            <artifactid>spring-cloud-starter-netflix-zuul</artifactid>
        </dependency>
로그인 후 복사

application.yml 경로 전달 구성

@Component
public class MyFilter extends ZuulFilter {

    private static Logger log = LoggerFactory.getLogger(MyFilter.class);

    /**
     * pre:路由之前
     * routing:路由之时
     * post: 路由之后
     * error:发送错误调用
     * @return
     */
    @Override
    public String filterType() {
        return "pre";
    }

    /**
     * 过滤的顺序
     * @return
     */
    @Override
    public int filterOrder() {
        return 0;
    }

    /**
     * 这里可以写逻辑判断,是否要过滤,本文true,永远过滤
     * @return
     */
    @Override
    public boolean shouldFilter() {
        return true;
    }


    /**
     * 过滤器的具体逻辑。
     * 可用很复杂,包括查sql,nosql去判断该请求到底有没有权限访问。
     * @return
     * @throws ZuulException
     */
    @Override
    public Object run() throws ZuulException {
        RequestContext ctx = RequestContext.getCurrentContext();
        HttpServletRequest request = ctx.getRequest();
        log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));
        Object accessToken = request.getParameter("token");
        if(accessToken == null) {
            log.warn("token is empty");
            ctx.setSendZuulResponse(false);
            ctx.setResponseStatusCode(401);
            try {
                ctx.getResponse().getWriter().write("token is empty");
            }catch (Exception e){}

            return null;
        }
        log.info("ok");
        return null;
    }

}
로그인 후 복사

Enable zuul

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
server:
  port: 8769
spring:
  application:
    name: cloud-service-zuul
zuul:
  routes:
    api-a:
      path: /api-a/**
      serviceId: cloud-service-ribbon
    api-b:
      path: /api-b/**
      serviceId: cloud-service-feign
로그인 후 복사

Route Meltdown

@SpringBootApplication
@EnableZuulProxy
@EnableEurekaClient
@EnableDiscoveryClient
public class CloudServiceZuulApplication {

    public static void main(String[] args) {
        SpringApplication.run(CloudServiceZuulApplication.class, args);
    }

}
로그인 후 복사

Summary Zuul 게이트웨이에는 자동 전달 메커니즘이 있습니다. 하지만 실제로 Zuul에는 더 많은 애플리케이션 시나리오, 인증, 트래픽 전달, 요청 통계 등 이러한 기능은 모두 Zuul을 사용하여 구현할 수 있습니다.


위 내용은 SpringCloud에서 zuul의 원리와 사용법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 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. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

자바의 완전수 자바의 완전수 Aug 30, 2024 pm 04:28 PM

Java의 완전수 가이드. 여기서는 정의, Java에서 완전 숫자를 확인하는 방법, 코드 구현 예제에 대해 논의합니다.

자바의 웨카 자바의 웨카 Aug 30, 2024 pm 04:28 PM

Java의 Weka 가이드. 여기에서는 소개, weka java 사용 방법, 플랫폼 유형 및 장점을 예제와 함께 설명합니다.

Java의 스미스 번호 Java의 스미스 번호 Aug 30, 2024 pm 04:28 PM

Java의 Smith Number 가이드. 여기서는 정의, Java에서 스미스 번호를 확인하는 방법에 대해 논의합니다. 코드 구현의 예.

Java Spring 인터뷰 질문 Java Spring 인터뷰 질문 Aug 30, 2024 pm 04:29 PM

이 기사에서는 가장 많이 묻는 Java Spring 면접 질문과 자세한 답변을 보관했습니다. 그래야 면접에 합격할 수 있습니다.

Java 8 Stream foreach에서 나누거나 돌아 오시겠습니까? Java 8 Stream foreach에서 나누거나 돌아 오시겠습니까? Feb 07, 2025 pm 12:09 PM

Java 8은 스트림 API를 소개하여 데이터 컬렉션을 처리하는 강력하고 표현적인 방법을 제공합니다. 그러나 스트림을 사용할 때 일반적인 질문은 다음과 같은 것입니다. 기존 루프는 조기 중단 또는 반환을 허용하지만 스트림의 Foreach 메소드는이 방법을 직접 지원하지 않습니다. 이 기사는 이유를 설명하고 스트림 처리 시스템에서 조기 종료를 구현하기위한 대체 방법을 탐색합니다. 추가 읽기 : Java Stream API 개선 스트림 foreach를 이해하십시오 Foreach 메소드는 스트림의 각 요소에서 하나의 작업을 수행하는 터미널 작동입니다. 디자인 의도입니다

Java의 날짜까지의 타임스탬프 Java의 날짜까지의 타임스탬프 Aug 30, 2024 pm 04:28 PM

Java의 TimeStamp to Date 안내. 여기서는 소개와 예제와 함께 Java에서 타임스탬프를 날짜로 변환하는 방법에 대해서도 설명합니다.

캡슐의 양을 찾기위한 Java 프로그램 캡슐의 양을 찾기위한 Java 프로그램 Feb 07, 2025 am 11:37 AM

캡슐은 3 차원 기하학적 그림이며, 양쪽 끝에 실린더와 반구로 구성됩니다. 캡슐의 부피는 실린더의 부피와 양쪽 끝에 반구의 부피를 첨가하여 계산할 수 있습니다. 이 튜토리얼은 다른 방법을 사용하여 Java에서 주어진 캡슐의 부피를 계산하는 방법에 대해 논의합니다. 캡슐 볼륨 공식 캡슐 볼륨에 대한 공식은 다음과 같습니다. 캡슐 부피 = 원통형 볼륨 2 반구 볼륨 안에, R : 반구의 반경. H : 실린더의 높이 (반구 제외). 예 1 입력하다 반경 = 5 단위 높이 = 10 단위 산출 볼륨 = 1570.8 입방 단위 설명하다 공식을 사용하여 볼륨 계산 : 부피 = π × r2 × h (4

Spring Tool Suite에서 첫 번째 Spring Boot 응용 프로그램을 실행하는 방법은 무엇입니까? Spring Tool Suite에서 첫 번째 Spring Boot 응용 프로그램을 실행하는 방법은 무엇입니까? Feb 07, 2025 pm 12:11 PM

Spring Boot는 강력하고 확장 가능하며 생산 가능한 Java 응용 프로그램의 생성을 단순화하여 Java 개발에 혁명을 일으킨다. Spring Ecosystem에 내재 된 "구성에 대한 협약"접근 방식은 수동 설정, Allo를 최소화합니다.

See all articles