Spring Cloud Alibaba - Gateway 入门案例(二)(Gateway 整合 nacos /(非阿里组件))

Spring Cloud Alibaba - Gateway 入门案例(二)(Gateway 整合 nacos)(非阿里组件)

回溯

上一篇博文讲述了 Gateway 的简单使用,但是有遗留的问题,就是调用的微服务地址竟然是写死的,这样一旦微服务的地址发生更改,那么配置文件也需要更改。

对于这个问题,是不是有点眼熟?对的,前面的博文有讲述,就是为了解决这个问题所以我们引进了服务治理 Nacos 。这篇博文我们就讲述一下 Gateway 和 Nacos 的整合。

Gateway 整合 nacos

在市面上,对于 Gateway 整合 nacos 的用法通常有两种,这边简要介绍一下。

这里的操作都是基于上一篇博客的操作,若有疑问,可以参考SpringCloud Alibaba - Gateway 入门案例(一)(网关介绍 / Gateway 介绍 / Gateway 快速入门)

方式一(复杂/灵活/常用)

首先添加pom依赖,完整pom如下

  <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.3.RELEASE</version>
    </parent>
    
    <dependencies>
        <!--gateway网关 不能引入starter-web-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
            <version>2.1.0.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.1.0.RELEASE</version>
        </dependency>
    </dependencies>

然后在启动类添加 @EnableDiscoveryClient

在这里插入图片描述
在配置文件中加上

spring:
	cloud:
	    nacos:
      		discovery:
        		server-addr: 127.0.0.1:8848 #nacos地址
		gateway:
      		discovery:
        		locator:
          			enabled: true #让 gateway可以发现nacos中的微服务

修改之前uri的值,之前的uri值是写死的路径,现在我们可以放上微服务注册在nacos上的服务名。

最终修改后的配置文件如下:

server:
  port: 7777
spring:
  application:
    name: api-gateway
  cloud:
    gateway:
      discovery:
        locator:
          enabled: true #让gateway可以发现nacos中的微服务
      routes: # 路由数组  指当请求满足什么样的条件的时候,转发到哪个微服务上
        - id: nacosxfz_route #当前路由标识,要求唯一 (默认值uuid,一般不用,需要自定义)
          uri: lb://test-scz #请求最终要被转发的地址   lb指的是从nacos中按照名称获取微服务,并遵循负载均衡策略
          order: 1 #路由优先级,数字越小,优先级越高
          predicates: #断言 判断条件,返回值是boolean 转发请求要返回的条件 (可以写多个)、
            - Path=/scz_server/** #当请求路径满足path指定的规则时,此路由信息才会正常转发
          filters: #过滤器(在请求传递过程中,对请求做一些手脚)
            - StripPrefix=1 # 在请求转发之前去掉一层路径
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

ps(lb指的是从nacos中按照名称获取微服务,并遵循负载均衡策略)

test-scz 是需要调用的微服务注册在nacos上的名字。

接下来进行测试

在这里插入图片描述
在这里插入图片描述
请求成功,证明 Gateway 整合 nacos 成功。

此方式企业中运用的比较多,原因是 predicatesfilters 可以自定义配置,相对而言较为灵活。这两个参数在后面的章节会进行较为详细的讲解。

方式二(简单/死板/不常用)

为什么简单?因为真的非常简单,步骤和方式一一样,但是!配置文件不用那么多花里胡哨的配置。

routes 可以不用配置!!!

最终yml配置:

server:
  port: 7777
spring:
  application:
    name: api-gateway
  cloud:
    gateway:
      discovery:
        locator:
          enabled: true #让gateway可以发现nacos中的微服务
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848

在这里插入图片描述

访问成功!

但是:我们要注意,此时它默认 predicates Path 和需要调用的微服务名称相同,所以可以根据访问微服务名称作为路径访问微服务。

因为方便,而抛弃了更灵活的配置,是不是有一点吃了芝麻丢了西瓜呢???

猜你喜欢

转载自blog.csdn.net/qq_29064815/article/details/107203396