Spring Cloud Gateway 配置(代码配置和动态路由数据库配置)

前言

了解Gateway的配置才可以理解使用Gateway可以做什么事情,才能更好地应用在产品开发中。

以下所写的yml配置指的是在配置文件中写的配置,json配置指的是使用动态路由进行配置,存在数据库里面写的配置

一、Predicates

Predicates主要起的作用是:配置路由匹配请求的规则


1、Http相关

Path配置对于请求路径的匹配规则

yml配置,多个参数用逗号隔开

- Path = /aa/**,/bb/**

json配置

{"name":"Path","args":{"pattern":"/aa/**","pattern1":"/bb/**"}}


2、Cookie配置对

Cookie中值的匹配,第一个为key,第二个为value。下例匹配cookie设置chocolate:ch.p的请求

yml配置

- Cookie = chocolate,ch.p

json配置

{"name":"Cookie","args":{"_genkey_0":"chocolate","_genkey_1":"ch.p"}}

 

3、Header匹配

Http请求中设置的内容,http-header设置X-Request-Id:\d+可以匹配,第二个参数第二个参数是正则表达式

yml配置

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


json配置

{"name":"Header","args":{"_genkey_0":"X-Request-Id","_genkey_1":"\d+"}}


4、Host匹配

Http请求Host,匹配所有host为**.somehost.com的请求

yml配置

- Host = **.somehost.com

json配置

{"name":"Host","args":{"_genkey_0":"**.somehost.com"}}


5、Method匹配Http请求头

yml配置

- Method = GET

json配置

{"name":"Method","args":{"_genkey_0":"GET"}}


6、Query匹配

Http请求中的查询参数,请求中携带param1=value的请求可以匹配

yml配置

- Query = param1,value

json配置

{"name":"Query","args":{"_genkey_0":"param1","_genkey_1":"value"}}


7、RemoteAddr匹配

请求中的RemoteAddr

yml配置

- RemoteAddr = 192.168.1.1/24

json配置

{"name":"RemoteAddr","args":{"_genkey_0":"192.168.1.1/24"}}


8、时间相关

After设置时间之后可以访问

yml配置

- After = 2017-01-20T17:42:47.789-07:00[America/Denver]

json配置

{"name":"After","args":{"_genkey_0":"2017-01-20T17:42:47.789-07:00[America/Denver]"}}


Before设置时间之前可以访问

yml配置

- Before = 2017-01-20T17:42:47.789-07:00[America/Denver]


json配置

{"name":"Before","args":{"_genkey_0":"2017-01-20T17:42:47.789-07:00[America/Denver]"}}


Before设置时间段内可以访问

yml配置

- Between = 2017-01-20T17:42:47.789-07:00[America/Denver],2017-01-21T17:42:47.789-07:00[America/Denver]

json配置

{"name":"Between","args":{"_genkey_0":"2017-01-20T17:42:47.789-07:00[America/Denver]","_genkey_1":"2017-01-21T17:42:47.789-07:00[America/Denver]"}}


9、权重路由

至少两组以上路由可以配置权重路由,配置后会根据权重随机访问几个路由

yml配置

- Weight = service1,80

json配置

{"name":"Weight","args":{"_genkey_0":"service1","_genkey_1":"80"}}

二、Filters

1、路径重写

yml配置

- RewritePath = /path/(?<segment>.*), /$\{segment}

json配置

{"name":"RewritePath","args":{"_genkey_0":"/foo/(?<segment>.*)","_genkey_1":"/$\\{segment}"}}


2、修改请求头

yml配置

- AddRequestHeader = X-Request-Foo,Bar

json配置

{"name":"AddRequestHeader","args":{"_genkey_0":"X-Request-Foo","_genkey_1":"Bar"}}


3、修改请求参数

yml配置

- AddRequestParameter = foo,bar

json配置

{"name":"AddRequestParameter","args":{"_genkey_0":"foo","_genkey_1":"bar"}}


4、修改响应参数

yml配置

- AddResponseHeader = X-Request-Foo,Bar

json配置

{"name":"AddResponseHeader","args":{"_genkey_0":"X-Request-Foo","_genkey_1":"Bar"}}


5、路径前缀增强

请求路径/hello, 将会被替换为 /mypath/hello

yml配置

- PrefixPath = /mypath

json配置

{"name":"PrefixPath","args":{"_genkey_0":"/mypath"}}


6、路径前缀删除

请求/name/bar/foo,去除掉前面两个前缀之后,最后转发到目标服务的路径为/foo

yml配置

- StripPrefix = 2

json配置

{"name":"StripPrefix","args":{"_genkey_0":"2"}}


7、请求携带保留原始Host

yml配置

- PreserveHostHeader

json配置

{"name":"PreserveHostHeader","args":{}}


8、重定向

yml配置

- RedirectTo = 302,http://acme.org

json配置

{"name":"RedirectTo","args":{"_genkey_0":"302","_genkey_1":"http://acme.org"}}


9、断路器

yml配置

- name: Hystrix
  args:
      # 断路后跳转地址
      name: fallbackcmd
      fallbackUri: forward:/incaseoffailureusethis

json配置

{"name":"Hystrix","args":{"name":"fallbackcmd","fallbackUri":"forward:/incaseoffailureusethis"}}


10、集成Redis原生支持请求限流

yml配置

 - name: RequestRateLimiter
   args:
     redis-rate-limiter.replenishRate: 10  
     redis-rate-limiter.burstCapacity: 20

json配置

{"name":"RequestRateLimiter","args":{"redis-rate-limiter.replenishRate":"10","redis-rate-limiter.burstCapacity":"20"}}


11、删除请求头属性

yml配置

- RemoveRequestHeader = X-Request-Foo

json配置

{"name":"RemoveRequestHeader","args":{"_genkey_0":"X-Request-Foo"}}


12、删除响应头属性

yml配置

- RemoveResponseHeader = X-Request-Foo

json配置

{"name":"RemoveResponseHeader","args":{"_genkey_0":"X-Request-Foo"}}


13、重写响应头

将请求 /42?user=ford&password=omg!what&flag=true, 改为 /42?
user=ford&password=***&flag=true

yml配置

- RewriteResponseHeader = X-Response-Foo,password=[^&]+,password=***

json配置

{"name":"RewriteResponseHeader","args":{"_genkey_0":"X-Response-Foo","_genkey_1":"password=[^&]+","_genkey_2":"password=***"}}


14、重设请求路径

请求/foo/bar,在接下来的处理中被改为/bar

yml配置

- SetPath =/{segment}

json配置

{"name":"SetPath","args":{"_genkey_0":"/{segment}"}}


15、设置响应头

在接下来的处理中修改响应头X-Response-Foo为Bar

yml配置

- SetResponseHeader =X-Request-Foo,Bar

json配置

{"name":"SetResponseHeader","args":{"_genkey_0":"X-Response-Foo","_genkey_1":"Bar"}}


16、设置Http状态

yml配置

- name: SetStatus
  args:
      status: 401

json配置

{"name":"SetStatus","args":{"_genkey_0":"302"}}


17、设置文件传输大小

yml配置

 - name: RequestSize
   args:
       maxSize: 5000000

json配置

{"name":"RequestSize","args":{"_genkey_0":"5000000"}}


18、失败重试

yml配置

- name: Retry
  args:
      retries: 3
      statuses: BAD_GATEWAY

json配置

{"name":"Retry","args":{"retries":"3","statuses":"BAD_GATEWAY"}} 

 

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
以下是一个基本的工具类,用于将路由配置数据库中读取并转换为Spring Cloud Gateway的路由定义: ```java @Component public class DatabaseRouteDefinitionProvider implements RouteDefinitionProvider { private final JdbcTemplate jdbcTemplate; public DatabaseRouteDefinitionProvider(JdbcTemplate jdbcTemplate) { this.jdbcTemplate = jdbcTemplate; } @Override public Flux<RouteDefinition> getRouteDefinitions() { List<RouteDefinition> definitions = jdbcTemplate.query("SELECT * FROM routes", rs -> { List<RouteDefinition> routes = new ArrayList<>(); while (rs.next()) { RouteDefinition route = new RouteDefinition(); route.setId(rs.getString("id")); route.setUri(URI.create(rs.getString("uri"))); route.setOrder(rs.getInt("route_order")); String predicatesJson = rs.getString("predicates"); List<PredicateDefinition> predicates = new ObjectMapper().readValue(predicatesJson, new TypeReference<List<PredicateDefinition>>() {}); route.setPredicates(predicates); String filtersJson = rs.getString("filters"); List<FilterDefinition> filters = new ObjectMapper().readValue(filtersJson, new TypeReference<List<FilterDefinition>>() {}); route.setFilters(filters); routes.add(route); } return routes; }); return Flux.fromIterable(definitions); } } ``` 这个工具类使用Spring JDBC来查询数据库中的路由配置,并使用Jackson库将JSON字符串转换为Spring Cloud Gateway的路由定义对象。然后,它将这些定义添加到一个Flux对象中,并返回它以供Spring Cloud Gateway使用。请注意,此工具类仅提供了一种从数据库中读取路由配置的方法,您可以根据需要进行修改以适应您的应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值