溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

SpringCloud怎么實現Zuul集群

發布時間:2021-07-05 13:53:45 來源:億速云 閱讀:236 作者:小新 欄目:開發技術

小編給大家分享一下SpringCloud怎么實現Zuul集群,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

一、使用 Nginx+Zuul 實現網關集群

1.互聯網公司中網關都是集群 搭建集群: Nginx+Zuul 一主一備,或者輪詢多個。

2.在微服務中,所有服務請求都會統一請求到Zuul網關上。

圖示:

SpringCloud怎么實現Zuul集群

過程:客戶端發送請求統一到Nginx上,在使用Nginx實現反向代理和負載均衡,采用輪詢算法轉發到網關上。

1.創建Eurek注冊中心、會員服務、訂單服務 (略)

搭建Zull集群前,應該對Eureka注冊中心,以及創建SpringBoot項目應該有了解,這里就不一 一贅述了。

實際上創建會員服務、訂單服務這一步可以省略,因為我們僅僅是為了演示Nginx對Zuul網關的負載均衡效果。

會員服務配置:

過程:客戶端發送請求統一到Nginx上,在使用Nginx實現反向代理和負載均衡,采用輪詢算法轉發到網關上。1.創建Eurek注冊中心、會員服務、訂單服務 (略)

搭建Zull集群前,應該對Eureka注冊中心,以及創建SpringBoot項目應該有了解,這里就不一 一贅述了。實際上創建會員服務、訂單服務這一步可以省略,因為我們僅僅是為了演示Nginx對Zuul網關的負載均衡效果。

會員服務配置:

#會員服務
server:
  port: 8082
spring:
  application:
    name: member-service    #服務名
#Eureka配置
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8761/eureka/     #注冊中心的地址

訂單服務:

#訂單服務
server:
  port: 8081
spring:
  application:
    name: order-service   #服務名
#Eureka配置
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8761/eureka/      #注冊中心地址

2. 創建Zuul服務

application.yml文件中配置 (Zull的配置生產時一般是放到配置中心中)

#配置Zuul端口
server:
  port: 81
spring:
  application:
    name: zull-gateway-service    #服務名
#Eureka配置
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:8761/eureka/    #注冊中心地址
      
# 配置網關反向代理,例如訪問/api-member/** 直接重定向到member-service服務,實現路由轉發,隱藏服務的真實ip(服務都實在內網中)
#zull根據服務名,去Eureka獲取服務真實地址,并通過本地轉發,而且默認開啟Ribbon實現負載均衡
#默認讀取Eureka注冊列表 默認30秒間隔  
zuul:
 routes:
   api-a: #會員服務網關配置
     path: /api-member/**   #訪問只要是/api-member/ 開頭的直接轉發到member-service服務
     #服務名
     serviceId: member-service
   api-b: #訂單服務網關配置
     path: /api-order/**
     serviceId: order-service

創建TokenFilet類繼承ZuulFilter,在run方法中輸入網關的端口,調用服務時方便查看Nginx轉發到哪個網關

package com.example.zuul.filter;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import io.micrometer.core.instrument.util.StringUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import javax.servlet.http.HttpServletRequest;
@Component
public class TokenFilter extends ZuulFilter {
	//統計當前Zuul調用次數
    int count = 0;
    
	//獲取Zuul服務端口號
    @Value("${server.port}")
    private String prot;
    
    /**
     * 指定該Filter的類型
     * ERROR_TYPE = "error";
     * POST_TYPE = "post";
     * PRE_TYPE = "pre";
     * ROUTE_TYPE = "route";
     */
    @Override
    public String filterType() {
        System.out.println("filterType()...");
        return "pre";
    }
    /**
     * 指定該Filter執行的順序(Filter從小到大執行)
     * DEBUG_FILTER_ORDER = 1;
     * FORM_BODY_WRAPPER_FILTER_ORDER = -1;
     * PRE_DECORATION_FILTER_ORDER = 5;
     * RIBBON_ROUTING_FILTER_ORDER = 10;
     * SEND_ERROR_FILTER_ORDER = 0;
     * SEND_FORWARD_FILTER_ORDER = 500;
     * SEND_RESPONSE_FILTER_ORDER = 1000;
     * SIMPLE_HOST_ROUTING_FILTER_ORDER = 100;
     * SERVLET_30_WRAPPER_FILTER_ORDER = -2;
     * SERVLET_DETECTION_FILTER_ORDER = -3;
     */
    @Override
    public int filterOrder() {
        System.out.println("filterOrder()...");
        return 0;
    }
    /**
     * 指定需要執行該Filter的規則
     * 返回true則執行run()
     * 返回false則不執行run()
     */
    @Override
    public boolean shouldFilter() {
        System.out.println("shouldFilter()...");
        return true;
    }
    /**
     * 該Filter具體的執行活動
     */
    @Override
    public Object run() throws ZuulException {
        // 獲取上下文
        //RequestContext currentContext = RequestContext.getCurrentContext();
        //HttpServletRequest request = currentContext.getRequest();
        //獲取userToken
       // String userToken = request.getParameter("userToken");
        //System.out.println("userToken: "+userToken);
        //if (StringUtils.isEmpty(userToken)) {
            //不會繼續執行調用服務接口,網關直接響應給客戶端
            //currentContext.setSendZuulResponse(false);
            //currentContext.setResponseStatusCode(401);
           // currentContext.setResponseBody("userToken is Null");
           // return null;
       // }else if(!userToken.equals("10010")){
           // currentContext.setSendZuulResponse(false);
            //currentContext.setResponseStatusCode(401);
            //currentContext.setResponseBody("userToken is Error");
            //return null;
        //}
        // 否則正常執行業務邏輯,調用服務.....
        System.out.println("訪問Zuul網關端口為:"+prot +"(total:"+ ( count++) +")");
        return null;
    }
}

啟動兩個Zuul服務,端口號分別為81和82

3. 下載Nginx服務器

這里演示使用Windows版本,Linux安裝也很簡單,后面操作都一樣。

windows版下載地址:http://nginx.org/en/download.html

SpringCloud怎么實現Zuul集群

下載好后解壓,進入conf目錄找到nginx.conf文件打開,配置如下:

#配置上游服務器 集群,默認輪詢機制
	upstream backServer{
		server 127.0.0.1:81;
		server 127.0.0.1:82;
		# 補充: backup表示從服務器或者叫備用服務器  只有當主服務器(81、82端口)都不能訪問時才會訪問此(83端口)備用服務器 當主服務器恢復正常后 則訪問主服務器
		#server 127.0.0.1:83 backup;
	}
    server {
        listen       80;
        server_name  localhost;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        location / {
            ##root   html;
			#指定上游負載均衡服務器
			proxy_pass http://backServer/;
            index  index.html index.htm;
        }
    }

雙擊nginx.exe啟動Nginx服務器

二、 測試

瀏覽器訪問http://localhost/api-member

我們可以看到兩個網關分別輸出了日志,實現了負載均衡

SpringCloud怎么實現Zuul集群

SpringCloud怎么實現Zuul集群

我們看到訪問的次數不一樣,這其實和使用Google瀏覽器有關,可以換其他瀏覽器試試。

三、補充

Nginx和網關的區別在什么地方?

1、都可以實現反向代理。

2、都可以實現負載均衡,Nginx是服務端負載均衡,Zuul是本地負載均衡。

Nginx也可以實現網關,為什么不用Nginx實現網關呢?

因為微服務網關是針對整個微服務實現統一的請求攔截,網關基本上都是采用自己熟悉的語言開發的,目的方便易學。

網關的作用:

1、網關對所有服務會話進行攔截

2、網關安全控制、統一異常處理、xxs、sql注入

3、權限控制、黑名單和白名單、性能監控、日志打印等

關于Nginx負載均衡故障轉移:

設置備用服務器(主從架構),只有當所有主服務器不可用時才會負載到備服務器,當主服務器恢復正常時則負載到主服務器。

upstream backServer{
		server 127.0.0.1:81;
		server 127.0.0.1:82;
		# 補充: backup表示從服務器或者叫備用服務器  只有當主服務器(81、82端口)都不能訪問時才會訪問此(83端口)備用服務器 當主服務器恢復正常后 則訪問主服務器
		server 127.0.0.1:83 backup;
	}

設置Nginx轉發請求超時時間

upstream backServer{
		server 127.0.0.1:81;
		server 127.0.0.1:82;
		server 127.0.0.1:83 backup;
	}
	
location / {
        proxy_pass   http://backServer/;
        proxy_redirect  default;
	    proxy_connect_timeout 1;  # 超時1s則轉發到其他服務,宕機情況下也適用
	    proxy_read_timeout 1;
	    proxy_send_timeout 1;

看完了這篇文章,相信你對“SpringCloud怎么實現Zuul集群”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女