Spring Cloud入门-Gateway服务网关(Hoxton版本),java反射机制面试题
创始人
2025-01-09 15:08:53
0

注意:Predicate中提到的配置都在application-predicate.yml文件中进行修改,并用该配置启动api-gateway服务。

After Route Predicate

在指定时间之后的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: after_route

uri: ${service-url.user-service}

predicates:

  • After=2019-12-29T18:30:00+08:00[Asia/Shanghai]

Before Route Predicate

在指定时间之前的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: before_route

uri: ${service-url.user-service}

predicates:

  • Before=2019-12-29T18:30:00+08:00[Asia/Shanghai]

Between Route Predicate

在指定时间区间内的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: before_route

uri: ${service-url.user-service}

predicates:

  • Between=2019-12-29T18:30:00+08:00[Asia/Shanghai], 2019-12-30T18:30:00+08:00[Asia/Shanghai]

Cookie Route Predicate

带有指定Cookie的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: cookie_route

uri: ${service-url.user-service}

predicates:

  • Cookie=username,jourwon

使用curl工具发送带有cookie为username=jourwon的请求可以匹配该路由。

curl http://localhost:9201/user/1 --cookie “username=jourwon”

Header Route Predicate

带有指定请求头的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: header_route

uri: ${service-url.user-service}

predicates:

  • Header=X-Request-Id, \d+

使用curl工具发送带有请求头为X-Request-Id:123的请求可以匹配该路由。

curl http://localhost:9201/user/1 -H “X-Request-Id:123”

Host Route Predicate

带有指定Host的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: host_route

uri: ${service-url.user-service}

predicates:

  • Host=**.jourwon.com

使用curl工具发送带有请求头为Host:www.jourwon.com的请求可以匹配该路由。

curl http://localhost:9201/user/1 -H “Host:www.jourwon.com”

Method Route Predicate

发送指定方法的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: method_route

uri: ${service-url.user-service}

predicates:

  • Method=GET

使用curl工具发送GET请求可以匹配该路由。

curl http://localhost:9201/user/1

使用curl工具发送POST请求无法匹配该路由。

curl -X POST http://localhost:9201/user/1

Path Route Predicate

发送指定路径的请求会匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: path_route

uri: ${service-url.user-service}/user/{id}

predicates:

  • Path=/user/{id}

使用curl工具发送/user/1路径请求可以匹配该路由。

curl http://localhost:9201/user/1

使用curl工具发送/abc/1路径请求无法匹配该路由。

curl http://localhost:9201/abc/1

Query Route Predicate

带指定查询参数的请求可以匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: query_route

uri: ${service-url.user-service}/user/getByUsername

predicates:

  • Query=username

使用curl工具发送带username=jourwon查询参数的请求可以匹配该路由。

curl http://localhost:9201/user/getByUsername?username=jourwon

使用curl工具发送带不带查询参数的请求无法匹配该路由。

curl http://localhost:9201/user/getByUsername

RemoteAddr Route Predicate

从指定远程地址发起的请求可以匹配该路由。

spring:

cloud:

gateway:

routes:

  • id: remoteaddr_route

uri: ${service-url.user-service}

predicates:

  • RemoteAddr=192.168.1.1/24

使用curl工具从192.168.1.1发起请求可以匹配该路由。

curl http://localhost:9201/user/1

Weight Route Predicate

使用权重来路由相应请求,以下表示有80%的请求会被路由到localhost:8201,20%会被路由到localhost:8202。

spring:

cloud:

gateway:

routes:

  • id: weight_high

uri: http://localhost:8201

predicates:

  • Weight=group1, 8

  • id: weight_low

uri: http://localhost:8202

predicates:

  • Weight=group1, 2

Route Filter 的使用


路由过滤器可用于修改进入的HTTP请求和返回的HTTP响应,路由过滤器只能指定路由进行使用。Spring Cloud Gateway 内置了多种路由过滤器,他们都由GatewayFilter的工厂类来产生,下面我们介绍下常用路由过滤器的用法。

AddRequestParameter GatewayFilter

给请求添加参数的过滤器。

spring:

cloud:

gateway:

routes:

  • id: add_request_parameter_route

uri: http://localhost:8201

filters:

  • AddRequestParameter=username, jourwon

predicates:

  • Method=GET

以上配置会对GET请求添加username=jourwon的请求参数,通过curl工具使用以下命令进行测试。

curl http://localhost:9201/user/getByUsername

相当于发起该请求:

curl http://localhost:8201/user/getByUsername?username=jourwon

StripPrefix GatewayFilter

对指定数量的路径前缀进行去除的过滤器。

spring:

cloud:

gateway:

routes:

  • id: strip_prefix_route

uri: http://localhost:8201

predicates:

  • Path=/user-service/**

filters:

  • StripPrefix=2

以上配置会把以/user-service/开头的请求的路径去除两位,通过curl工具使用以下命令进行测试。

curl http://localhost:9201/user-service/a/user/1

相当于发起该请求:

curl http://localhost:8201/user/1

PrefixPath GatewayFilter

与StripPrefix过滤器恰好相反,会对原有路径进行增加操作的过滤器。

spring:

cloud:

gateway:

routes:

  • id: prefix_path_route

uri: http://localhost:8201

predicates:

  • Method=GET

filters:

  • PrefixPath=/user

以上配置会对所有GET请求添加/user路径前缀,通过curl工具使用以下命令进行测试。

curl http://localhost:9201/1

相当于发起该请求:

curl http://localhost:8201/user/1

Hystrix GatewayFilter

Hystrix 过滤器允许你将断路器功能添加到网关路由中,使你的服务免受级联故障的影响,并提供服务降级处理。

要开启断路器功能,我们需要在pom.xml中添加Hystrix的相关依赖:

org.springframework.cloud

spring-cloud-starter-netflix-hystrix

然后添加相关服务降级的处理类:

@RestController

public class FallbackController {

@GetMapping(“/fallback”)

public Object fallback() {

Map result = new HashMap<>();

result.put(“data”,null);

result.put(“message”,“Get request fallback!”);

result.put(“code”,500);

return result;

}

}

在application-filter.yml中添加相关配置,当路由出错时会转发到服务降级处理的控制器上:

spring:

cloud:

gateway:

routes:

  • id: hystrix_route

uri: ${service-url.user-service}

predicates:

  • Method=GET

filters:

  • name: Hystrix

args:

name: fallbackcmd

fallback-uri: forward:/fallback

关闭user-service,调用该地址进行测试:http://localhost:9201/user/1 ,发现已经返回了服务降级的处理信息。

在这里插入图片描述

RequestRateLimiter GatewayFilter

RequestRateLimiter 过滤器可以用于限流,使用RateLimiter实现来确定是否允许当前请求继续进行,如果请求太大默认会返回HTTP 429-太多请求状态。

在pom.xml中添加相关依赖:

org.springframework.boot

spring-boot-starter-data-redis-reactive

添加限流策略的配置类,这里有两种策略一种是根据请求参数中的username进行限流,另一种是根据访问IP进行限流;

@Configuration

public class RedisRateLimiterConfig {

@Bean

public KeyResolver userKeyResolver() {

return exchange -> Mono.just(exchange.getRequest().getQueryParams().getFirst(“username”));

}

@Bean

public KeyResolver ipKeyResolver() {

return exchange -> Mono.just(exchange.getRequest().getRemoteAddress().getHostName());

}

}

我们使用Redis来进行限流,所以需要添加Redis和RequestRateLimiter的配置,这里对所有的GET请求都进行了按IP来限流的操作;

spring:

redis:

host: localhost

password: 123456

port: 6379

cloud:

gateway:

routes:

  • id: requestratelimiter_route

uri: http://localhost:8201

filters:

  • name: RequestRateLimiter

args:

每秒允许处理的请求数量

redis-rate-limiter.replenishRate: 1

每秒最大处理的请求数量

redis-rate-limiter.burstCapacity: 2

限流策略,对应策略的Bean

key-resolver: “#{@ipKeyResolver}”

predicates:

  • Method=GET

logging:

level:

org.springframework.cloud.gateway: debug

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

最后

为什么我不完全主张自学?
平台上的大牛基本上都有很多年的工作经验了,你有没有想过之前行业的门槛是什么样的,现在行业门槛是什么样的?以前企业对于程序员能力要求没有这么高,甚至十多年前你只要会写个“Hello World”,你都可以入门这个行业,所以以前要入门是完全可以入门的。
②现在也有一些优秀的年轻大牛,他们或许也是自学成才,但是他们一定是具备优秀的学习能力,优秀的自我管理能力(时间管理,静心坚持等方面)以及善于发现问题并总结问题。
如果说你认为你的目标十分明确,能做到第②点所说的几个点,以目前的市场来看,你才真正的适合去自学。

除此之外,对于绝大部分人来说,报班一定是最好的一种快速成长的方式。但是有个问题,现在市场上的培训机构质量参差不齐,如果你没有找准一个好的培训班,完全是浪费精力,时间以及金钱,这个需要自己去甄别选择。

我个人建议线上比线下的性价比更高,线下培训价格基本上没2W是下不来的,线上教育现在比较成熟了,此次疫情期间,学生基本上都感受过线上的学习模式。相比线下而言,线上的优势以我的了解主要是以下几个方面:
①价格:线上的价格基本上是线下的一半;
②老师:相对而言线上教育的师资力量比线下更强大也更加丰富,资源更好协调;
③时间:学习时间相对而言更自由,不用裸辞学习,适合边学边工作,降低生活压力;
④课程:从课程内容来说,确实要比线下讲的更加深入。

应该学哪些技术才能达到企业的要求?(下图总结)

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
[外链图片转存中…(img-tcQ8heaC-1711957052788)]

最后

为什么我不完全主张自学?
平台上的大牛基本上都有很多年的工作经验了,你有没有想过之前行业的门槛是什么样的,现在行业门槛是什么样的?以前企业对于程序员能力要求没有这么高,甚至十多年前你只要会写个“Hello World”,你都可以入门这个行业,所以以前要入门是完全可以入门的。
②现在也有一些优秀的年轻大牛,他们或许也是自学成才,但是他们一定是具备优秀的学习能力,优秀的自我管理能力(时间管理,静心坚持等方面)以及善于发现问题并总结问题。
如果说你认为你的目标十分明确,能做到第②点所说的几个点,以目前的市场来看,你才真正的适合去自学。

除此之外,对于绝大部分人来说,报班一定是最好的一种快速成长的方式。但是有个问题,现在市场上的培训机构质量参差不齐,如果你没有找准一个好的培训班,完全是浪费精力,时间以及金钱,这个需要自己去甄别选择。

我个人建议线上比线下的性价比更高,线下培训价格基本上没2W是下不来的,线上教育现在比较成熟了,此次疫情期间,学生基本上都感受过线上的学习模式。相比线下而言,线上的优势以我的了解主要是以下几个方面:
①价格:线上的价格基本上是线下的一半;
②老师:相对而言线上教育的师资力量比线下更强大也更加丰富,资源更好协调;
③时间:学习时间相对而言更自由,不用裸辞学习,适合边学边工作,降低生活压力;
④课程:从课程内容来说,确实要比线下讲的更加深入。

应该学哪些技术才能达到企业的要求?(下图总结)

[外链图片转存中…(img-LrSjPRbt-1711957052788)]

[外链图片转存中…(img-M1O6Yde7-1711957052788)]

相关内容

热门资讯

windows10、11只允许... 一、背景1、Windows 11,电脑不能访问外网以及内网IP地址2、Windows ...
一起来探讨《WPk透视辅助》太... 一起来探讨《WPk透视辅助》太坑了其实确实是有挂(有挂存在);一、AI软件牌型概率发牌机制”必胜“技...
科普分享微扑克网页版原来真的是... 科普分享微扑克网页版原来真的是有挂,太嚣张了原来真的有挂,详细教程(有挂方式);1、完成微扑克的残局...
揭秘真相《Wepoke漏洞》软... 揭秘真相《Wepoke漏洞》软件透明挂!(透明挂)软件下载(2020已更新)(哔哩哔哩)揭秘真相《W...
一分钟了解微扑克机器人原来是有... 大家肯定在之前微扑克或者微扑克中玩过一分钟了解微扑克机器人原来是有挂,太夸张了原来是有挂,详细教程(...
2025有料了解!微扑克脚本辅... 2025有料了解!微扑克脚本辅助器程序(辅助挂)原来确实是有挂(确实有挂)详细教程(哔哩哔哩);1、...
科普分享Wepoke计算器软件... 科普分享Wepoke计算器软件透明挂!太坑了其实真的是有挂的(有挂详情)(哔哩哔哩);一、有挂的是的...
2023已更新《Wepoke长... 2023已更新《Wepoke长期》软件透明挂!(透明挂)软件机器人(2021已更新)(哔哩哔哩);1...
一分钟了解《微扑克辅助器挂》微... 一分钟了解《微扑克辅助器挂》微扑克app外挂辅助神器(哔哩哔哩);微扑克软件透明挂作为一款微扑克辅助...
2024版辅助挂Wepoke脚... 自定义新版系统规律,只需要输入自己想要的开挂功能,一键便可以生成出专用辅助器,不管你是想分享给你好友...