赞
踩
gateway相当于所有服务的门户,将客户端请求与服务端应用相分离,客户端请求通过gateway后由定义的路由和断言进行转发,路由代表需要转发请求的地址,断言相当于请求这些地址时所满足的条件,只有同时符合路由和断言才给予转发
gateWay是微服务的API网关,能够实现服务的路由,过滤,断言,流量控制,日志监控等操作。是zuul1.0的升级版。Gateway是基于异步非阻塞开发的。
1.id 属性,ID 编号,唯一。
2.断言predicates :请求通过 predicates, 判断是否匹配,就是我们匹配的条件。
3.filters 属性,可以在请求被路由前或者之后对请求进行修改。。
4.uri 属性,路由重定向的 URI,将请求转发到制定的服务上。 。
5.order 属性,顺序。当请求匹配到多个路由时,使用顺序小的。
断言就是定义了一组匹配规则,让请求过来后找到对应的router进行处理。这里可以设置时间让其生效,设置cookie,设置请求方式等规则
例:请求 http://localhost:6001/tool/test/get 会转发到tool-service-ly服务的test/get接口
即: http://localhost:6001/tool/test/get =====》 http://tool-service-ly/test/get
代码部分:
- spring:
- cloud:
- gateway:
- routes:
- #唯一识别号 ,例:请求 http://localhost:6001/tool/test/get 会转发到tool-service-ly服务的test/get 接口
- - id: TOOL-SERVICE-ly
- #在服务注册中心找服务名为 tool-service-ly的服务
- uri: lb://tool-service-ly
- #设置路由断言,代理servicerId为TOOL-SERVICE-ly的 /tool/* 路径
- predicates:
- - Path=/tool/**
- #前缀, 在当前路径匹配中表示去掉第一个前缀 /tool 即请求从/tool/test/get 变成 /test/get
- filters:
- - StripPrefix=1
gateway根据路由与断言去转发请求到指定的服务。predicate就是我们匹配的条件,fiter是一个无所不能的拦截器,再加上uri,就可以实现 一个具体的路由。
Springcloud之网关gateway_gateway的作用_java满杯百香果的博客-CSDN博客
默认情况下:gateway会根据注册中心上的微服务名为路径,创建动态路由进行转发,从而实现动态路由的功能。
uri的配置为协议为lb,表示启用gateway的负债均衡功能。如lb://seviceName为spricloud gateway在微服务中自动为我们创建的负债均衡的uri。
- <!--eureka-client-->
- <dependency>
- <groupId>org.springframework.cloud</groupId>
- <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
- </dependency>
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-web</artifactId>
- </dependency>
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-actuator</artifactId>
- </dependency>
- <dependency>
- <groupId>org.mybatis.spring.boot</groupId>
- <artifactId>mybatis-spring-boot-starter</artifactId>
- </dependency>
- <dependency>
- <groupId>com.alibaba</groupId>
- <artifactId>druid-spring-boot-starter</artifactId>
- <version>1.1.10</version>
- </dependency>
- <!--mysql-connector-java-->
- <dependency>
- <groupId>mysql</groupId>
- <artifactId>mysql-connector-java</artifactId>
- </dependency>
- <!--jdbc-->
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-jdbc</artifactId>
- </dependency>
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-devtools</artifactId>
- <scope>runtime</scope>
- <optional>true</optional>
- </dependency>
- <dependency>
- <groupId>org.projectlombok</groupId>
- <artifactId>lombok</artifactId>
- <optional>true</optional>
- </dependency>
- <dependency>
- <groupId>org.springframework.boot</groupId>
- <artifactId>spring-boot-starter-test</artifactId>
- <scope>test</scope>
- </dependency>
- </dependencies>
方式1:yml配置文件
- server:
- port: 9007
-
- spring:
- application:
- name: mscloud-cluster-gateway9007
- cloud:
- gateway:
- discovery:
- locator:
- enabled: true #开启从注册中心动态创建路由的功能,利用微服务名进行路由
- routes:
- - id: payment_routh #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名
- #uri: http://localhost:8001 #匹配后提供服务的路由地址
- uri: lb://mscloud-cluster-providers #匹配后提供服务的路由地址
- predicates:
- - Path=/payment/get/** # 断言,路径相匹配的进行路由
-
- - id: payment_routh2 #payment_route #路由的ID,没有固定规则但要求唯一,建议配合服务名
- #uri: http://localhost:8001 #匹配后提供服务的路由地址
- uri: lb://mscloud-cluster-providers #匹配后提供服务的路由地址
- predicates:
- - Path=/payment/lb/** # 断言,路径相匹配的进行路由
- #- After=2020-02-21T15:51:37.485+08:00[Asia/Shanghai]
- #- Cookie=username,zzyy
- #- Header=X-Request-Id, \d+ # 请求头要有X-Request-Id属性并且值为整数的正则表达式
- eureka:
- client:
- #表示是否将自己注册进EurekaServer默认为true。
- register-with-eureka: true
- #是否从EurekaServer抓取已有的注册信息,默认为true。单节点无所谓,集群必须设置为true才能配合ribbon使用负载均衡
- fetchRegistry: true
- service-url:
- #单机版
- #defaultZone: http://localhost:8003/eureka/
- # 集群版
- defaultZone: http://mscloud-euk1:9001/eureka/,http://mscloud-euk2:9002/eureka/
- instance:
- instance-id: gateway9007
- #访问路径可以显示IP地址
- prefer-ip-address: true
- #Eureka客户端向服务端发送心跳的时间间隔,单位为秒(默认是30秒)
- #lease-renewal-interval-in-seconds: 1
- #Eureka服务端在收到最后一次心跳后等待时间上限,单位为秒(默认是90秒),超时将剔除服务
- #lease-expiration-duration-in-seconds: 2
方式2:硬编码实现方式:了解即可
1.先启动9001,9002 eureka服务;2.再启动9003,9004 提供者;3.启动网关9007;最后查看启动效果图:
2.查看eureka服务器
1.不使用gateway代理情况下: 直接调用服务
可以正确访问到
1.请求地址1,实现网关路由转发,并实现负载均衡 本次9004提供服务
本次9003提供服务
2.请求地址2,实现网关路由转发,多刷新几次,出现负载均衡效果
本次9004提供服务
本次9003提供服务
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。