Spring Cloud Alibaba微服务实战十 - 服务网关

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO

联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬

学习必须往深处挖,挖的越深,基础越扎实!

阶段1、深入多线程

阶段2、深入多线程设计模式

阶段3、深入juc源码解析


阶段4、深入jdk其余源码解析


阶段5、深入jvm源码解析

码哥源码部分

码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】

码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】

码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】

​​​​​​码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】

码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】

码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】

码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】

终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!

打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】

在SpringCloud体系架构中,我们需要部署一个单独的网关服务对外提供访问入口,然后网关服务根据配置好的规则将请求转发至具体的后端服务,本章内容主要是给我们的微服务加上网关SpringCloud Gateway。

前言背景

我们有了三个服务account-serviceproduct-serviceorder-service。现在有客户端WEB应用APP应用需要访问后端服务获取数据那么就需要在客户端维护好三个服务的访问路径。

这样的架构会有如下几个典型的问题:

  • 每个微服务都需要配置单独的访问域名,开通外网访问权限,每新增一个服务都需要先让运维人员配置好域名映射
  • 客户端需要维护所有微服务的访问地址,试想一下如果微服务有几十几百个呢?
  • 当服务需要对接口进行权限控制,必须要认证用户才能调用,那么所有的权限逻辑在服务端都要重新编写一套。
  • 。。。

所以我们需要在微服务之前加一个网关服务,让所有的客户端只要访问网关,网关负责对请求进行转发;将权限校验逻辑放到网关的过滤器中,后端服务不需要再关注权限校验的代码;只需要对外提供一个可供外网访问的域名地址,新增服务后也不需要再让运维人员进行网络配置了,这样上面的架构就变成了如下所示:

创建网关模块

在项目中建立cloud-gateway模块, spring-cloud-gateway 作为微服务体系中的一环也需要将自身注册进Nacos并集成Nacos配置中心。

  • pom.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <parent>
            <artifactId>cloud-aliaba</artifactId>
            <groupId>com.jianzh5.cloud</groupId>
            <version>1.0.0</version>
        </parent>
    
        <modelVersion>4.0.0</modelVersion>
    
        <artifactId>cloud-gateway</artifactId>
    
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            </dependency>
    
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-gateway</artifactId>
            </dependency>
    
        </dependencies>
    
    </project>
  • 启动类
    @SpringBootApplication
    @EnableDiscoveryClient
    public class GateWayApplication {
        public static void main(String[] args) {
            SpringApplication.run(GateWayApplication.class, args);
        }
    }
  • bootstap.yml
    spring:
      application:
        name: cloud-gateway
      cloud:
        nacos:
          config:
            server-addr: 10.0.10.48:8848
            file-extension: yml
            namespace: 7e8ccc22-6f51-42fa-bcf1-db45f99dbf57
  • 在nacos中建立网关的路由配置
    server:
      port: 8090
    spring:
      cloud:
        nacos:
          discovery:
            server-addr: 10.0.10.48:8848
        gateway:
          discovery:
            locator:
              enabled: true
          routes:
          - id: product-service
            uri: lb://product-service
            predicates:
              - Path=/product/**
          - id: account-service
            uri: lb://account-service
            predicates:
              - Path=/account/**
          - id: order-service
            uri: lb://order-service
            predicates:
              - Path=/order/**

配置详解:

id: 在所有路由定义中需要唯一,不能重复
uri: lb://** lb://为固定写法,表示开启负载均衡; ** 即服务在Nacos中注册的名字
predicates:- Path=/product/** 使用"Path Route Predicate Factory",规则为/product/** 的请求都还转发至微服务product-service中。

上面的配置逻辑为:
① 以http://localhost:8090/product/** 的访问路径会转发到product-service微服务的/**
② 以http://localhost:8090/account/** 的访问路径会转发到account-service微服务的/**
③ 以http://localhost:8090/order/** 的访问路径会转发到order-service微服务的/**

  • 启动所有服务,确认是否转发

    正如日志所示,SpringCloud Gateway 负责后端转发并开启了负载均衡。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值