spring cloud 笔记 |第四章: Zuul 路由网关

简介

Zuul网关是具体核心业务服务的看门神,相比具体实现业务的系统服务来说它是一个边缘服务,主要提供动态路由、监控、弹性、安全性等功能。在分布式的微服务中,系统被拆为多套系统,通过zuul网关来对用户的请求进行路由没转发到具体的后台服务系统中。

路由网关的作用

Zuul网关的主要功能是路由转发和过滤器,核心是一系列的过滤器,这些过滤器可以对请求或者响应结果做一系列过滤,Zuul提供了一个框架可以支持动态加载,编译,运行这些过滤器,这些过滤器是使用责任链方式顺序对请求或者响应结果进行处理的,不会直接进行通信,但是通过责任链传递的RequestContext参数可以共享一些东西。

在zuul中过滤分为四种:
PRE Filters:前置过滤,当请求会路由转发到具体后端服务器前执行的过滤器.

ROUTING Filters:路由过滤器,该过滤器作用是把请求具体转发到后端服务器上.

POST Filters:后置过滤器,当把请求路由到具体后端服务器后执行的过滤器.

CUSTOM Filters:自定义拦截器.

ERROR Filters(错误过滤器):当上面任何一个类型过滤器执行出错时候执行该过滤器.

Zuul 工作原理

当Zuul接收到请求后,首先会由前置过滤器进行处理,然后在由路由过滤器具体把请求转发到后端应用,然后在执行后置过滤器把执行结果写会到请求方,当上面任何一个类型过滤器执行出错时候执行该过滤器.

工作原理图

工作原理图

代码实现

实现原理图

image

准备工作

继续上一章笔记的工程,启动eureka-server 工程;启动service-hello工程;启动service-ribbon工程;

修改service-ribbon配置文件,再启动一个servuce-ribbon工程(同时启动两个servuce-ribbon工程,启动两个实例的方法第二章已经提到过了.):

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8081/eureka/
server:
  port: 8085
spring:
  application:
    name: service-ribbon2

创建Zuul 路由网关

创建service-zuul工程:Cloud Discovery -> Eureka Discovery Client


创建service-zuul工程

创建完成后,在service-zuul项目的pom文件继承父pom文件,并查看是否引入了spring-cloud-starter-netflix-eureka-client的依赖.
并引入依赖:

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

在启动类applicaton类加上注解@EnableZuulProxy,开启zuul的功能:

@SpringBootApplication
@EnableZuulProxy
@EnableEurekaClient
@EnableDiscoveryClient
public class ServiceZuulApplication {
    public static void main(String[] args) {
        SpringApplication.run( ServiceZuulApplication.class, args );
    }
}

加上配置文件application.yml加上以下的配置代码:

server:
  port: 8086

#向注册服务中心地址
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8081/eureka/

#向注册中心注册的服务名
spring:
  application:
    name: service-zuul

#配置路由网关管理的路由
zuul:
  routes:
    api-a:
      #分配的路由
      path: /api-a/**
      #调用的服务
      serviceId: service-ribbon
    api-b:
      path: /api-b/**
      serviceId: service-ribbon2

首先指定服务注册中心的地址为http://localhost:8081/eureka/,服务的端口为8086,服务名为service-zuul;以/api-a/ 开头的请求都转发给service-ribbon服务;以/api-b/开头的请求都转发给service-ribbon2服务;

访问:http://localhost:8086/api-a/hello,显示:

hello ! 我是 8083号服务器.

访问:http://localhost:8086/api-b/hello,显示:

hello ! 我是 8083号服务器.

演示了Zuul路由的作用,接下来演示过滤的方法;

服务过滤

在service-zuul工程中,创建过滤类并继承ZuulFilter,并做一个简单的安全验证demo:

@Component
public class Filter extends ZuulFilter {

    private static Logger log = LoggerFactory.getLogger( Filter.class );

    //配置过滤器类型
    //pre:路由之前
    //routing:路由之时
    //post: 路由之后
    //error:发送错误调用
    @Override
    public String filterType() {
        return "pre";
    }
    //过滤器顺序
    @Override
    public int filterOrder() {
        return 0;
    }
    //设置过滤条件
    @Override
    public boolean shouldFilter() {
        return true;
    }
    //过滤器具体业务逻辑
    @Override
    public Object run() {
        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 null" );
            ctx.setSendZuulResponse( false );
            ctx.setResponseStatusCode( 401 );
            try {
                ctx.getResponse().getWriter().write( "token is null" );
            } catch (Exception e) {
            }

            return null;
        }
        log.info( "succeed" );
        return null;
    }
}

这时访问:http://localhost:8086/api-a/hello,显示:

token is null

这时访问:http://localhost:8086/api-a/hello?token=123456,显示:

hello ! 我是 8083号服务器.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,968评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,601评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,220评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,416评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,425评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,144评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,432评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,088评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,586评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,028评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,137评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,783评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,343评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,333评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,559评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,595评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,901评论 2 345

推荐阅读更多精彩内容