• <noscript id="e0iig"><kbd id="e0iig"></kbd></noscript>
  • <td id="e0iig"></td>
  • <option id="e0iig"></option>
  • <noscript id="e0iig"><source id="e0iig"></source></noscript>
  • SpringCloud 2.x學習筆記:4、Zuul

    標簽: Zuul

    1、Zuul簡介

    zuul 是netflix開源的一個API Gateway 服務器, 本質上是一個web servlet應用。

    請參考官方文檔:
    https://springcloud.cc/spring-cloud-dalston.html#_router_and_filter_zuul

    Zuul的主要功能是路由轉發過濾器。路由功能是微服務的一部分,比如/api/user轉發到到user服務,/api/shop轉發到到shop服務。zuul默認和Ribbon結合實現了負載均衡的功能。

    2、新建模塊

    2.1 pom文件

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <groupId>com.cntaiping.tpa</groupId>
        <artifactId>zuul</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <packaging>jar</packaging>
        <name>zuul</name>
        <description>Demo project for Spring Boot</description>
    
        <parent>
            <groupId>com.cntaiping.tpa</groupId>
            <artifactId>cloud</artifactId>
            <version>1.0-SNAPSHOT</version>
        </parent>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
            </dependency>
        </dependencies>
    </project>
    
    

    2.2 application.properties

    eureka.client.serviceUrl.defaultZone=http://localhost:8800/eureka/
    server.port=8400
    spring.application.name=service-zuul
    #表示只要訪問以/api-a/開頭的多層目錄都可以路由到 id為compute-service的服務上
    zuul.routes.consumer-feign=/api-a/**
    zuul.routes.consumer-hystrix=/api-b/**
    

    服務消費者也可以作為服務提供者。
    以/api-a/ 開頭的請求都轉發給consumer-feign服務;以/api-b/開頭的請求都轉發給consumer-hystrix服務;

    2.3 Application類

    package com.cntaiping.tpa.zuul;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.client.SpringCloudApplication;
    import org.springframework.cloud.netflix.zuul.EnableZuulProxy;
    
    /**
     * @SpringCloudApplication注解
     * 整合了@SpringBootApplication、@EnableEurekaClient、@EnableCircuitBreaker
     * 主要目的還是簡化配置
     */
    @EnableZuulProxy
    @SpringCloudApplication
    public class ZuulApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ZuulApplication.class, args);
        }
    
    }
    

    2.4 運行效果

    從執行結果可以說明zuul起到了路由的作用
    在這里插入圖片描述

    在這里插入圖片描述

    3、過濾器

    可以通過zuul提供的過濾器,進行一些請求過濾,比如安全驗證。
    停止模塊,增加過濾器類如下。

    package com.cntaiping.tpa.zuul.filter;
    
    import com.netflix.zuul.ZuulFilter;
    import com.netflix.zuul.context.RequestContext;
    import com.netflix.zuul.exception.ZuulException;
    import org.slf4j.Logger;
    import org.slf4j.LoggerFactory;
    import org.springframework.stereotype.Component;
    
    import javax.servlet.http.HttpServletRequest;
    
    @Component
    public class TokenFilter extends ZuulFilter {
    
        private static Logger log = LoggerFactory.getLogger(TokenFilter.class);
    
       /**
        返回一個字符串代表過濾器的類型,
        pre:路由之前
        routing:路由之時
        post: 路由之后
        error:發送錯誤調用
       */
        @Override
        public String filterType() {
            return "pre";
        }
    
        /**
          過濾的順序
       */
        @Override
        public int filterOrder() {
            return 0;
        }
    
        /**
          這里可以寫邏輯判斷,是否要過濾,本文true,永遠過濾。
        */
        @Override
        public boolean shouldFilter() {
            return true;
        }
    
        /**
          過濾器的具體邏輯。
       */
        @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;
        }
    }
    
    

    重新運行模塊
    在這里插入圖片描述

    在這里插入圖片描述

    http://localhost:8400/api-a/hello?name=chengyq&token=111
    在這里插入圖片描述

    版權聲明:本文為chengyuqiang原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接和本聲明。
    本文鏈接:https://blog.csdn.net/chengyuqiang/article/details/90716992

    智能推薦

    SpringCloud 2.x學習筆記:15、Spring Cloud Gateway之Filter過濾器(Greenwich版本)

    1、AddRequestHeader過濾器 http://localhost:7013/get AddRequestHeaderGatewayFilterFactory的源碼 從代碼可知道,由當前的ServerHttpRequest創建新 ServerHttpRequest ,并在新的ServerHttpRequest加一個請求頭,然后創建新的 ServerWebExchange ,提交過濾器鏈繼...

    SpringCloud 2.x學習筆記:6、高可用的分布式配置中心(Greenwich版本)

    1、復用服務注冊中心 參考https://blog.csdn.net/chengyuqiang/article/details/90645498 2、改造config-server 2.1 pom.xml 添加 完整的pom.xml 2.2 application.yml 2.3 Application啟動類 添加@EnableEurekaClient 2.4 啟動兩個實例 3、改造config-...

    SpringCloud學習筆記4

    零、springcloud細節問題(回顧) Eureka Server Eureka Client @EnableEurekaClient 專用于Eureka Server注冊中心 @EnableDiscoveryClient 通用任何注冊中心 客戶端的調用方式 restTemplate + ribbon ribbon(軟負載均衡 默認 輪詢) 客戶端僅引入兩個依賴(spring-cloud-st...

    springcloud學習記錄-zuul

    springcloud學習記錄-zuul Zuul的主要功能是作為網關進行路由轉發和過濾。 核心功能包括: (1)身份認證和安全:識別每一個資源的驗證要求,審查和監控 (2)動態路由:動態將請求路由到不同后端集群 (3)壓力測試:增加指定集群流量,檢測性能 (4)負載分配:為不同負載類型分配對應容量,超過容量時自動丟棄 Zuul和Eureka結合,將Zuul自身注冊為Eureka服務治理下的客戶端...

    springcloud學習筆記(八)SpringCloud集成zuul路由(一)

    在微服務架構中,需要幾個基礎的服務治理組件,包括服務注冊與發現、服務消費、負載均衡、斷路器、智能路由、配置管理等,由這幾個基礎組件相互協作,共同組建了一個簡單的微服務系統。一個簡答的微服務系統如下圖:   注意:A服務和B服務是可以相互調用的,作圖的時候忘記了。并且配置服務也是注冊到服務注冊中心的。 在Spring Cloud微服務系統中,一種常見的負載均衡方式是,客戶端的請求首先經過負...

    猜你喜歡

    SpringCloud——Zuul

    1、簡介 Zuul是Netflix開源的微服務網關,可以和Eureka、Feign、Hystrix等組件配合使用。Zuul核心是一系列的過濾器,可以完成很多的功能。 身份認證與安全:識別每個資源的驗證要求,并拒絕與要求不符的請求 審查與監控:在邊緣位置追蹤有意義的數據和統計結果,從而帶來精確的生產視圖。 動態路由:動態地將請求路由到不同不同的后端集群 壓力測試:逐漸增加指向集群的流量,以了解性能 ...

    SpringCloud Zuul

    網關,外界環境訪問Cloud服務中心的服務時,都需要通過網關組件進行訪問,相當于代理作用。微服務網關是微服務架構中一個不可或缺的部分。通過服務網關統一向外系統提供REST API的過程中,除了具備服務路由、均衡負載功能之外,它還具備了權限控制等功能。 在Spring cloud體系中,一般上選擇zuul或者Gateway網關技術。 Spring Cloud Zuul:Zuul是Netflix開源的...

    SpringCloud Zuul

    1. 場景描述 今天接著介紹springcloud,今天介紹下springcloud的路由網關-Zuul,外圍系統或者用戶通過網關訪問服務,網關通過注冊中心找到對應提供服務的客戶端,網關也需要到注冊中心進行注冊。 2. 解決方案 2.1 官網架構圖 3,搭建模塊 1,cloud-zuul8751 2,pom文件 3,主啟動類 4,yml...

    HTML中常用操作關于:頁面跳轉,空格

    1.頁面跳轉 2.空格的代替符...

    freemarker + ItextRender 根據模板生成PDF文件

    1. 制作模板 2. 獲取模板,并將所獲取的數據加載生成html文件 2. 生成PDF文件 其中由兩個地方需要注意,都是關于獲取文件路徑的問題,由于項目部署的時候是打包成jar包形式,所以在開發過程中時直接安照傳統的獲取方法沒有一點文件,但是當打包后部署,總是出錯。于是參考網上文章,先將文件讀出來到項目的臨時目錄下,然后再按正常方式加載該臨時文件; 還有一個問題至今沒有解決,就是關于生成PDF文件...

    精品国产乱码久久久久久蜜桃不卡