springcloud-gateway源码-(一)入门使用

springcloud-gateway源码-(一)入门使用

1: fork spring cloud gateway到自己分支

链接:https://github.com/50133142/spring-cloud-gateway.git
建立自己的学习分支:

2:mvn install 成功

在这里插入图片描述

坑:需要注释掉 maven-checkstyle-plugin 才能install成功

3:运行gateway的demo一

在himly-demo工程下,新建gateway工程,服务注册到eureka上,
github链接:https://github.com/50133142/hmily/tree/master/hmily-demo/hmily-demo-springcloud
yml配置如下:

核心配置
• ID:编号,路由的唯一标识。
• URI:路由指向的目标 URI,即请求最终被转发的目的地。
• Predicate:谓语,作为路由的匹配条件。Gateway 内置了多种 Predicate 的实现,提供了多种请求的匹配条件,比如说基于请求的 Path、Method 等等。
• Filter:过滤器,对请求进行拦截,实现自定义的功能。Gateway 内置了多种 Filter 的实现,提供了多种请求的处理逻辑,比如说限流、熔断等等

post测试:
本地起eureka,order ,gateway三个服务
在这里插入图片描述

4:Gateway 的整体工作流程中的作用

(摘抄:http://www.iocoder.cn/Spring-Cloud/Spring-Cloud-Gateway/?self)
,如下图所示:
在这里插入图片描述

① Gateway 接收客户端请求。
② 请求与 Predicate 进行匹配,获得到对应的 Route。匹配成功后,才能继续往下执行。
③ 请求经过 Filter 过滤器链,执行前置(prev)处理逻辑。
例如说,修改请求头信息等。
④ 请求被 Proxy Filter 转发至目标 URI,并最终获得响应。
一般来说,目标 URI 是被代理的微服务,如果是在 Spring Cloud 架构中。
⑤ 响应经过 Filter 过滤器链,执行后置(post)处理逻辑。
⑥ Gateway 返回响应给客户端。

5 :压测

直连order服务压测 (在本地window环境)

命令:sb -u http://localhost:8090/order/gateway -c 20 -N 60

在这里插入图片描述

请求网关压测

命令:sb -u http://localhost:9527/order/gateway -c 20 -N 60

在这里插入图片描述

压测对比:请求网关是相对直连服务QPS性能的50%
总结:请求网关多出IO消耗,代理调用处理和从eureka获取访问ip信息

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值