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

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

不言
不言앞으로
2019-04-11 13:18:397658검색

이 글은 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제