搭建Gateway网关服务

1.创建新的module,引入SpringCloudGateway的依赖和nacos的服务发现依赖:

<!--网关依赖-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<!--nacos服务发现依赖-->
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> 
</dependency>

2.编写路由配置及nacos地址(新创建的module中的application.yaml中)

server:
  port: 10010 # 网关端口
spring:
  application:
    name: gateway # 服务名称
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos地址
    gateway:
      routes: # 网关路由配置
        - id: user-service # 路由id,自定义,只要唯一即可
          # uri: http://127.0.0.1:8081 # 路由的目标地址 http就是固定地址
          uri: lb://userservice # 路由的目标地址 lb就是负载均衡,后面跟服务名称
          predicates: # 路由断言,也就是判断请求是否符合路由规则的条件
            - Path=/user/** # 这个是按照路径匹配,只要以/user/开头就符合要求

3.补充:Gateway网关执行的顺序

Gateway网关分为默认过滤器、路由过滤器、全局过滤器;在请求路由后,会将当前路由过滤器和DefaultFilterGlobalFilter,合并到一个过滤器链(集合)中,排序后依次执行每个过滤器。

排序的顺序按照order优先级从高到低排序(注:order值越小,则优先级越高)

当order值相同时,按照 默认过滤器>路由过滤器>全局过滤器 的顺序执行

(注:全局路由器的order值为自定义值;路由过滤器和默认过滤器的order值由Spring指定,默认是按照声明顺序从1递增

猜你喜欢

转载自blog.csdn.net/m0_47233175/article/details/121699290