前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >手把手教你写一个网关服务

手把手教你写一个网关服务

作者头像
用户5224393
发布2019-09-08 16:18:52
1K0
发布2019-09-08 16:18:52
举报
文章被收录于专栏:Java研发军团Java研发军团

什么是网关?为什么需要使用网关?

如图所示,在不使用网关的情况下,我们的服务是直接暴露给服务调用方。当调用方增多,势必需要添加定制化访问权限、校验等逻辑。当添加 API 网关后,再第三方调用端和服务提供方之间就创建了一面墙,这面墙直接与调用方通信进行权限控制。

本文所实现的网关源码抄袭了--- Oh,不对,是借鉴。借鉴了 Zuul 网关的源码,提炼出其核心思路,实现了一套简单的网关源码,博主将其改名为 Eatuul。

设计思路

先大致说一下,就是定义一个 Servlet 接收请求。然后经过 preFilter (封装请求参数), routeFilter (转发请求),postFilter (输出内容)。三个过滤器之间,共享request、response以及其他的一些全局变量。如下图所示。

与真正的 Zuul 的区别?

1)Zuul 中在异常处理模块,有一个 ErrorFilter 来处理,博主在实现的时候偷懒了,略去。

2)Zuul 中 PreFilters,RoutingFilters,PostFilters 默认都实现了一组,具体如下表所示。

博主总不可能每一个都给你们实现一遍吧。所以偷懒了,每种只实现一个。但是调用顺序还是不变,按照 PreFilters->RoutingFilters->PostFilters 的顺序调用。

3)在 RouteFilters 确实有转发请求的 Filter,然而博主偷天换日了,改用RestTemplate 实现。

代码结构

大家去 Spring 官网上搭建一套 Springboot 的项目,博主就不展示 pom 的代码了。直接将项目结构展示一下,如下图所示。

EatuulServlet.java

这个是网关的入口,逻辑也十分简单,分为三步。

1) 将 request,response 放入 threadlocal 中;

2) 执行三组过滤器;

3) 清除 threadlocal 中的的环境变量。

EatuulRunner.java

这个是具体的执行器。需要说明一下,在 Zuul 中,ZuulRunner 在获取具体有哪些过滤器的时候,有一个 FileLoader 可以动态读取配置加载。博主在实现我们自己的 EatuulRunner 时候,略去动态读取的过程,直接静态写死。

EatuulFilter.java

接下来就是一系列Filter的代码了,先上父类EatuulFilter的源码。

RequestWrapperFilter.java

这个是PreFilter,前置执行过滤器,负责封装请求。步骤如下所示。

1) 封装请求头;

2) 封装请求体;

3) 构造出 RestTemplate 能识别的 RequestEntity;

4) 将 RequestEntity 放入全局 threadlocal 之中。

RoutingFilter.java

这个是 RouteFilter,这里我偷懒了,直接做转发请求,并且将返回值ResponseEntity放入全局 threadlocal 中。

SendResponseFilter.java

这个是 postFilters,将 ResponseEntity 输出即可。

RequestContext.java

最后是一直在说的全局 threadlocal 变量。

如何测试?

自己另外起一个server端口为9090如下所示。

再来一个 controller。

然后,你就发现可以从 localhost:8080/index 进行跳转访问了。

结论

本文模拟了一下 zuul 网关的源码,借鉴了一下其精髓的部分。

转发也是一种支持。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Java研发军团 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
API 网关
腾讯云 API 网关(API Gateway)是腾讯云推出的一种 API 托管服务,能提供 API 的完整生命周期管理,包括创建、维护、发布、运行、下线等。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档