SpringCLoud之搭建Zuul網關集羣

1.使用技術html

  Springboot,SpringCloud,Zuul,Nignxjava

2.目的nginx

  使用Zuul搭建微服務高可用的網關spring

3.項目建立apache

3.1 建立註冊中心(略)api

3.2 建立一個hello-service的服務工程服務器

3.3 建立springcloud-zuul-ha網關服務app

3.3.1 建立工程(略)負載均衡

3.3.2 pom.xmlmaven

<?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>qinfeng.zheng</groupId>
    <artifactId>springcloud-zuul-ha</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>springcloud-zuul-ha</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.2.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencies>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-zuul</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-eureka</artifactId>
        </dependency>

    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <!--Dalston.RC1這個高版本的zuul依賴有問題-->
                <version>Brixton.SR7</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

 

3.3.3 application.yml

###服務註冊地址
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8763/eureka/
###api網關端口號
server:
  port: 82
###網關名稱
spring:
  application:
    name: service-zuul

zuul:
  routes:
  ###定義轉發服務規則
    api-a:
      path: /api-hello/**   #請求路徑中含有api-hello,都會轉發到hello-service服務
      ###服務別名  zuul網關默認整合ribbon 自動實現負載均衡輪訓效果
      serviceId: hello-service

 

3.3.4 定義一個過濾器

  qinfeng.zheng.filter.AccessFilter

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

/**
* 建立時間: 16:07 2018/7/16
* 修改時間:
* 編碼人員: ZhengQf
* 版 本: 0.0.1
* 功能描述: 自定義一個Zuul Filter,它在請求路由以前進行過濾
*
* 補: zuul兩大功能: 1.路由請求
* 2.過濾
*/
@Component
public class AccessFilter extends ZuulFilter {

  @Value("${server.port}")
  private String serverPort;

/**
* 過濾器的類型,它決定過濾器在請求的哪一個生命週期中執行,
* pre:請求被路由以前作一些前置工做 ,好比請求和校驗
* routing : 在路由請求時被調用,路由請求轉發,便是將請求轉發到具體的服務實例上去.
* post : 在routing 和 error過濾器以後被調用..因此post類型的過濾器能夠對請求結果進行一些加工
* error :處理請求發生錯誤時調用
*/
  @Override
  public String filterType() {

    return "pre"; //
  }

/**
*過濾器的執行順序.
*在一個階段有多個過濾器時,須要用此指定過濾順序
* 數值越小優先級越高
*/
  @Override
  public int filterOrder() {
    return 0;
  }

/**
* 判斷過濾器是否執行,直接返回true,表明對全部請求過濾
* 此方法指定過濾範圍
* @return
*/
  @Override
  public boolean shouldFilter() {
    return true;
  }

/**
* 過濾的具體邏輯
* @return
*/
  @Override
  public Object run() {

 

  // 1.獲取上下文
  RequestContext currentContext = RequestContext.getCurrentContext();
  // 2.獲取 Request
  HttpServletRequest request = currentContext.getRequest();
  // 3.獲取token 的時候 從請求頭中獲取
  String token = request.getParameter("token");
  request.setAttribute("serverPort", serverPort);
  if (StringUtils.isEmpty(token)) {
      // 不會繼續執行... 不會去調用服務接口,網關服務直接響應給客戶端
      currentContext.setSendZuulResponse(false);
      currentContext.setResponseBody("token is null");
      currentContext.setResponseStatusCode(401);
      return null;
      // 返回一個錯誤提示
  }
  // 正常執行調用其餘服務接口...
  System.out.println("網關執行端口號:" + serverPort);
  return null;
  }

} 

 

3.3.5 啓動類

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@EnableZuulProxy
@EnableEurekaClient
@SpringBootApplication
public class SpringcloudZuulHaApplication {

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

 

 

3.3.6  啓動網關項目

使用server.port模擬兩個網關項目,端口號分別爲81,82   -------> 測試網關高可用

使用server.port模擬兩個hello-service項目,端口號分別爲8080,8081 ---->測試zuul的路由時,自動負載均衡

查看註冊中心,一共有四個服務:

 

   3.4 nginx配置負載均衡,而後 cmd ,start nginx.exe啓動nginx服務

     upstream  backServer{
        server 127.0.0.1:81;
        server 127.0.0.1:82;
    }
    
    server {
        listen       80;
        server_name  qinfeng.zheng.com;

        location / {
            ### 指定上游服務器負載均衡服務器
            proxy_pass http://backServer/;
            index  index.html index.htm;
        }
    }

   3.5 在本地host文件中配置 qinfeng.zheng.com 的域名

 

4.測試

  第一次請求: http://qinfeng.zheng.com/api-hello/hello/index?token=123

  

 

第二次請求:http://qinfeng.zheng.com/api-hello/hello/index?token=123

5.總結

  1.使用nignx負載均衡和反向代理技術能夠實現網關的高可用

  2.zuul網關自動集成ribbon客戶端,實現路由的負載均衡

相關文章
相關標籤/搜索