文档章节

SpringCloud 学习(5) --- Zuul(一)基本概念、配置

庭前云落
 庭前云落
发布于 2019/12/13 21:10
字数 840
阅读 96
收藏 0

[TOC]

Spring Cloud

  • eureka:注册中心
    • 服务端:提供注册
    • 客户端:进行注册
  • ribbon:负载均衡(集群)
  • Hystrix:熔断器,执行备选方案
  • Feign:远程调用
  • Zuul:网关,统一入口。

1.1、一夫当关,万夫莫开---Zuul网关

  • 网关:程序统一入口。主要功能:服务分发(动态路由),服务鉴权等

    • Zuul是Netflix孵化的一个致力于"网关"的解决方案的开源组件

    • Zuul在动态路由、监控、弹性、服务治理、安全等方面有着重要作用。

    • Zuul底层是Servlet,本质组件是一系列Filter构成的责任链

Zuul具备的功能

  • 认证、鉴权
  • 压力控制
  • 灰度发布
  • 动态路由
  • 负载削减
  • 静态响应处理
  • 主动流量控制

1.2、Zuul入门案例--路由转发

  • 需求
//已有访问路径
http://localhost:8080/user
//通过网关希望访问路径
http://localhost:10010/service/user

面向服务的路由

创建zuul_demo

pom

 <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <!--添加eureka客户端-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
    </dependencies>

yml

server:
  port: 10010
spring:
  application:
    name: zuuldemo2
#网关配置:访问路径 和 服务路径 对应关系
zuul:
  preifx: /api  
  routes:
    userservice:
      path: /userservice/**       #访问路径
      #url: http://localhost:8080  #服务路径
      serviceId: userservice      #服务名称时  
#eureka配置
eureka:
  client:
    service-url:
      defaultZone: http://localhost:10086/eureka

开启网关代理注解@EnableZuulProxy

package com.czxy;

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;

/**
 * @author 庭前云落
 * @Date 2019/12/12 17:01
 * @description
 */
@SpringBootApplication
@EnableZuulProxy      //开启zuul代替
@EnableEurekaClient   //开启eureka客户端
public class ZuulApplication {
    public static void main(String[] args) {
        SpringApplication.run(ZuulApplication.class,args);
    }
}

1.3、路由前缀

  • 路由前缀:用于维护版本号或项目名

  • 修改yml文件,进行配置

    zuul:
      prefix: /api
    

路由通配符

规则 解释 示例
/** 匹配任意数据量的路径与字符 /client/aa,/client/aa/bb/cc
/* 匹配任意数量的字符 /client/aa,/client/aaaaaaaaaaaaaa
/? 匹配单个字符 /client/a,/client/b,/client/c

1.4、Zuul过滤器

1.4.1概述

  • 编写过滤器,继承父类:ZuulFilter
  • 常见方法:
    • filterType() 过滤器类型,取值:"pre"
    • filterOrder() 过滤器顺序,取值:1
    • shouldFilter() 是否执行,取值:true
    • run() 执行业务逻辑

1.4.2自定义过滤器

  • 将过滤器的实现,添加到spring容器中,zuul将自动启用过滤器

    • 过滤器父类:ZuulFilter

    • 工具类(请求上下文对象):RequestContext

    • 特殊请求头:Authorization

package com.czxy.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

/**
 * @author 庭前云落
 * @Date 2019/12/12 18:07
 * @description
 */
@Component
public class LoginFilter extends ZuulFilter {
    @Override
    public String filterType() {
        return "pre";  //路由之前执行
    }

    @Override
    public int filterOrder() {
        return 1;   //排序
    }

    @Override
    public boolean shouldFilter() {
        return true; //是否进行过滤,true将执行run()方法
    }

    @Override
    public Object run() throws ZuulException {
    //获得一个特殊请求头,判断是否有值:有返回null(放行),没有 响应状态码401 
        //1 获得工具类 (获得上下文对象)
        RequestContext requestContext = RequestContext.getCurrentContext();
        //2 通过工具类 获得请求对象
        HttpServletRequest request = requestContext.getRequest();
        //3 通过request对象获得特殊请求头
        String token = request.getHeader("authorization");

        //判断
        if(token == null || "".equals(token)) {
            //没有token返回401,关闭响应
            requestContext.setSendZuulResponse(false);
            requestContext.setResponseStatusCode(401);
        }
        //放行
        return null;
    }
}

© 著作权归作者所有

庭前云落

庭前云落

粉丝 17
博文 55
码字总数 45645
作品 0
南京
程序员
私信 提问
springcloud eureka 服务注册中心

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/08
0
0
springcloud 服务网关 gateway zuul

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/17
0
0
springcloud 客户端负载均衡 ribbon

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/09
0
0
史上最简单的 SpringCloud 教程 | 终章

版权声明:本文为博主原创文章,欢迎转载,转载请注明作者、原文超链接 ,博主地址:http://blog.csdn.net/forezp。 https://blog.csdn.net/forezp/article/details/70148833 转载请标明出处...

方志朋
2017/04/12
0
0
springcloud 断路由hystrix

------------------------------------------------------------------------------------------------------------ springcloud (零) springboot 基础 下载 springcloud (一)服务注册中心 ......

curiousby
2017/02/10
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Comparing getPath(), getAbsolutePath(), and getCanonicalPath() in Java

1. Overview The java.io.File class has three methods — getPath(), getAbsolutePath() and getCanonicalPath() — to obtain the filesystem path. In this article, we'll have a quick......

Ciet
40分钟前
29
0
Spring5 依赖注入和循环依赖处理

//TODO populateBean 注入属性 doGetBean->getSingleton 删除bean缓存

小小明1995
51分钟前
67
0
每天AC系列(七):合并两个有序链表

1 题目 LeetCode第21题,合并两个有序链表. 2 直接合并 因为已经有序了,类似归并排序中的合并一样,操作不难,直接上代码了. ListNode t = new ListNode(0);ListNode head = t;while(l1 != nu...

Blueeeeeee
54分钟前
47
0
数据结构之双向链表-c语言实现

原文链接:http://blog.seclibs.com/%e6%95%b0%e6%8d%ae%e7%bb%93%e6%9e%84%e4%b9%8b%e5%8f%8c%e5%90%91%e9%93%be%e8%a1%a8-c%e8%af%ad%e8%a8%80%e5%ae%9e%e7%8e%b0/ 这次完成了双向链表的代......

无心的梦呓
55分钟前
65
0
SpringCloud 基础教程(六)-负载均衡Ribbon

 我的博客:兰陵笑笑生,欢迎浏览博客!  上一章 SpringCloud基础教程(五)-配置中心热生效和高可用当中,我们对配置中心进行进行了深入的了解,本章将继续微服务架构的深入学习,了解在微服务...

_兰陵笑笑生
今天
49
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部