springcloud学习笔记(六):使用gateway实现路由转发

本文主要介绍如何在springcloud中通过gateway实现路由转发和微服务之间的负载均衡。本例使用的springcloud版本为:2021.0.3,springboot版本为:2.6.8。

1、创建gateway网关项目

​ 打开idea新建项目,选择maven,创建springboot项目gateway-6001。

image-20240812141229655

2、pom文件配置

​ 在项目pom中引入spring-cloud-starter-netflix-eureka-client和spring-cloud-starter-gateway依赖:

<dependencies>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-gateway</artifactId>
    </dependency>
</dependencies>

3、application.yml文件配置

​ 在项目resources文件夹下创建application.yml文件,并按如下内容进行配置:

server:
  port: 6001
 
eureka:
  client:
    service-url:
      defaultZone: http://localhost:7001/eureka
    fetch-registry: true
  instance:
    instance-id: gateway-${server.port}
    prefer-ip-address: true
 
spring:
  application:
    name: gateway
 
  cloud:
    gateway:
      routes:                         # 网关路由配置
      - id: payment                   # 路由id,自定义,只要唯一即可
        uri: lb://PAYMENT-SERVER      # 路由的目标地址 lb就是负载均衡,后面跟服务名称
        predicates:                   # 路由断言,也就是判断请求是否符合路由规则的条件
        - Path=/payment/**            # 这个是按照路径匹配,只要以/payment/开头就符合要求






扫描下方二维码,关注公众号:程序进阶之路,实时获取更多优质文章推送。


扫码关注

评论