欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SpringCloud如何實(shí)現(xiàn)Zuul集群(負(fù)載均衡)

 更新時(shí)間:2021年07月05日 08:52:32   作者:王小白_Ada  
這篇文章主要介紹了SpringCloud如何實(shí)現(xiàn)Zuul集群(負(fù)載均衡)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

前言:

在微服務(wù)架構(gòu)中,有一個(gè)組件可以說是必不可少的,那就是微服務(wù)網(wǎng)關(guān),微服務(wù)網(wǎng)關(guān)處理了負(fù)載均衡,緩存,路由,訪問控制,服務(wù)代理,監(jiān)控,日志等。API網(wǎng)關(guān)在微服務(wù)架構(gòu)中正是以微服務(wù)網(wǎng)關(guān)的身份存在。

一般在微服務(wù)架構(gòu)中,網(wǎng)關(guān)都是部署多個(gè)服務(wù)的,以實(shí)現(xiàn)負(fù)載均衡和保證高可用。

一、使用 Nginx+Zuul 實(shí)現(xiàn)網(wǎng)關(guān)集群

1.互聯(lián)網(wǎng)公司中網(wǎng)關(guān)都是集群 搭建集群: Nginx+Zuul 一主一備,或者輪詢多個(gè)。

2.在微服務(wù)中,所有服務(wù)請求都會(huì)統(tǒng)一請求到Zuul網(wǎng)關(guān)上。

圖示:

過程:客戶端發(fā)送請求統(tǒng)一到Nginx上,在使用Nginx實(shí)現(xiàn)反向代理和負(fù)載均衡,采用輪詢算法轉(zhuǎn)發(fā)到網(wǎng)關(guān)上。

1.創(chuàng)建Eurek注冊中心、會(huì)員服務(wù)、訂單服務(wù) (略)

搭建Zull集群前,應(yīng)該對(duì)Eureka注冊中心,以及創(chuàng)建SpringBoot項(xiàng)目應(yīng)該有了解,這里就不一 一贅述了。

實(shí)際上創(chuàng)建會(huì)員服務(wù)、訂單服務(wù)這一步可以省略,因?yàn)槲覀儍H僅是為了演示Nginx對(duì)Zuul網(wǎng)關(guān)的負(fù)載均衡效果。

會(huì)員服務(wù)配置:

過程:客戶端發(fā)送請求統(tǒng)一到Nginx上,在使用Nginx實(shí)現(xiàn)反向代理和負(fù)載均衡,采用輪詢算法轉(zhuǎn)發(fā)到網(wǎng)關(guān)上。1.創(chuàng)建Eurek注冊中心、會(huì)員服務(wù)、訂單服務(wù) (略)

搭建Zull集群前,應(yīng)該對(duì)Eureka注冊中心,以及創(chuàng)建SpringBoot項(xiàng)目應(yīng)該有了解,這里就不一 一贅述了。實(shí)際上創(chuàng)建會(huì)員服務(wù)、訂單服務(wù)這一步可以省略,因?yàn)槲覀儍H僅是為了演示Nginx對(duì)Zuul網(wǎng)關(guān)的負(fù)載均衡效果。

會(huì)員服務(wù)配置:

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

訂單服務(wù):

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

2. 創(chuàng)建Zuul服務(wù)

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

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

創(chuàng)建TokenFilet類繼承ZuulFilter,在run方法中輸入網(wǎng)關(guān)的端口,調(diào)用服務(wù)時(shí)方便查看Nginx轉(zhuǎn)發(fā)到哪個(gè)網(wǎng)關(guān)

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 {
	//統(tǒng)計(jì)當(dāng)前Zuul調(diào)用次數(shù)
    int count = 0;
    
	//獲取Zuul服務(wù)端口號(hào)
    @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執(zhí)行的順序(Filter從小到大執(zhí)行)
     * 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;
    }
    /**
     * 指定需要執(zhí)行該Filter的規(guī)則
     * 返回true則執(zhí)行run()
     * 返回false則不執(zhí)行run()
     */
    @Override
    public boolean shouldFilter() {
        System.out.println("shouldFilter()...");
        return true;
    }
    /**
     * 該Filter具體的執(zhí)行活動(dòng)
     */
    @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)) {
            //不會(huì)繼續(xù)執(zhí)行調(diào)用服務(wù)接口,網(wǎng)關(guān)直接響應(yīng)給客戶端
            //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;
        //}
        // 否則正常執(zhí)行業(yè)務(wù)邏輯,調(diào)用服務(wù).....
        System.out.println("訪問Zuul網(wǎng)關(guān)端口為:"+prot +"(total:"+ ( count++) +")");
        return null;
    }
}

啟動(dòng)兩個(gè)Zuul服務(wù),端口號(hào)分別為81和82

3. 下載Nginx服務(wù)器

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

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

在這里插入圖片描述

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

#配置上游服務(wù)器 集群,默認(rèn)輪詢機(jī)制
	upstream backServer{
		server 127.0.0.1:81;
		server 127.0.0.1:82;
		# 補(bǔ)充: backup表示從服務(wù)器或者叫備用服務(wù)器  只有當(dāng)主服務(wù)器(81、82端口)都不能訪問時(shí)才會(huì)訪問此(83端口)備用服務(wù)器 當(dāng)主服務(wù)器恢復(fù)正常后 則訪問主服務(wù)器
		#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;
			#指定上游負(fù)載均衡服務(wù)器
			proxy_pass http://backServer/;
            index  index.html index.htm;
        }
    }

雙擊nginx.exe啟動(dòng)Nginx服務(wù)器

二、 測試

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

我們可以看到兩個(gè)網(wǎng)關(guān)分別輸出了日志,實(shí)現(xiàn)了負(fù)載均衡

在這里插入圖片描述

在這里插入圖片描述

我們看到訪問的次數(shù)不一樣,這其實(shí)和使用Google瀏覽器有關(guān),可以換其他瀏覽器試試。

三、補(bǔ)充

Nginx和網(wǎng)關(guān)的區(qū)別在什么地方?

1、都可以實(shí)現(xiàn)反向代理。

2、都可以實(shí)現(xiàn)負(fù)載均衡,Nginx是服務(wù)端負(fù)載均衡,Zuul是本地負(fù)載均衡。

Nginx也可以實(shí)現(xiàn)網(wǎng)關(guān),為什么不用Nginx實(shí)現(xiàn)網(wǎng)關(guān)呢?

因?yàn)槲⒎?wù)網(wǎng)關(guān)是針對(duì)整個(gè)微服務(wù)實(shí)現(xiàn)統(tǒng)一的請求攔截,網(wǎng)關(guān)基本上都是采用自己熟悉的語言開發(fā)的,目的方便易學(xué)。

網(wǎng)關(guān)的作用:

1、網(wǎng)關(guān)對(duì)所有服務(wù)會(huì)話進(jìn)行攔截

2、網(wǎng)關(guān)安全控制、統(tǒng)一異常處理、xxs、sql注入

3、權(quán)限控制、黑名單和白名單、性能監(jiān)控、日志打印等

關(guān)于Nginx負(fù)載均衡故障轉(zhuǎn)移:

設(shè)置備用服務(wù)器(主從架構(gòu)),只有當(dāng)所有主服務(wù)器不可用時(shí)才會(huì)負(fù)載到備服務(wù)器,當(dāng)主服務(wù)器恢復(fù)正常時(shí)則負(fù)載到主服務(wù)器。

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

設(shè)置Nginx轉(zhuǎn)發(fā)請求超時(shí)時(shí)間

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;  # 超時(shí)1s則轉(zhuǎn)發(fā)到其他服務(wù),宕機(jī)情況下也適用
	    proxy_read_timeout 1;
	    proxy_send_timeout 1;

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java中notify和notifyAll的區(qū)別及何時(shí)使用

    Java中notify和notifyAll的區(qū)別及何時(shí)使用

    本文主要介紹了Java中notify和notifyAll的區(qū)別及何時(shí)使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Java線程中賣火車票問題的深入講解

    Java線程中賣火車票問題的深入講解

    這篇文章主要給大家介紹了關(guān)于Java線程中賣火車票問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Java判斷兩個(gè)浮點(diǎn)數(shù)相等

    Java判斷兩個(gè)浮點(diǎn)數(shù)相等

    本文主要介紹了Java判斷兩個(gè)浮點(diǎn)數(shù)相等,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • 詳解Java設(shè)計(jì)模式之橋接模式

    詳解Java設(shè)計(jì)模式之橋接模式

    橋接,顧名思義,就是用來連接兩個(gè)部分,使得兩個(gè)部分可以互相通訊。橋接模式將系統(tǒng)的抽象部分與實(shí)現(xiàn)部分分離解耦,使他們可以獨(dú)立的變化。本文通過示例詳細(xì)介紹了橋接模式的原理與使用,需要的可以參考一下
    2022-06-06
  • Java線程池實(shí)現(xiàn)原理總結(jié)

    Java線程池實(shí)現(xiàn)原理總結(jié)

    這篇文章主要給大家分享的是Java線程池實(shí)現(xiàn)原理總結(jié),線程池參數(shù)、線程池執(zhí)行流程等內(nèi)容上總結(jié),具有一定參考戒指,需要的小伙伴可以參考一下,希望對(duì)你有所幫助
    2022-01-01
  • Java線程中的線程本地變量ThreadLocal詳解

    Java線程中的線程本地變量ThreadLocal詳解

    這篇文章主要介紹了Java線程中的線程本地變量ThreadLocal詳解,ThreadLocal存放的值是線程內(nèi)共享的,線程間互斥的,主要用于線程內(nèi)共享一些數(shù)據(jù),避免通過參數(shù)來傳遞,這樣處理后,能夠優(yōu)雅的解決一些實(shí)際問題,需要的朋友可以參考下
    2023-11-11
  • SpringBoot?MP簡單的分頁查詢測試實(shí)現(xiàn)步驟分解

    SpringBoot?MP簡單的分頁查詢測試實(shí)現(xiàn)步驟分解

    好久沒水后端的東西了,最近在做vue項(xiàng)目寫前端的代碼,所以cloud也停進(jìn)度了,吃完飯突然記得我沒有在博客里寫分頁的東西,雖然項(xiàng)目中用到了,但是沒有拎出來,這里就拎出來看看
    2023-04-04
  • Java觀察者模式例子

    Java觀察者模式例子

    這篇文章主要介紹了Java觀察者模式例子的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • java 使用idea將工程打成jar并創(chuàng)建成exe文件類型執(zhí)行的方法詳解

    java 使用idea將工程打成jar并創(chuàng)建成exe文件類型執(zhí)行的方法詳解

    這篇文章主要介紹了java 使用idea將工程打成jar并創(chuàng)建成exe文件類型執(zhí)行,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2020-09-09
  • 如何區(qū)分JAVA中的throws和throw

    如何區(qū)分JAVA中的throws和throw

    這篇文章主要介紹了如何區(qū)分JAVA中的throws和throw,文中講解十分詳細(xì),代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下
    2020-06-06

最新評(píng)論