Spring Cloud Alibaba多实例定向路由

Spring Cloud Alibaba多实例定向路由

概述

在实际开发和部署中,可能遇到想要定向路由到某个服务的多实例中的某一个实例。有点灰度部署的感觉。

还有就是在开发环境,可能想要将请求路由到本地的实例进行Debug。

此时,我们就需要根据不同的请求,路由到想要的实例。

实现方式

运维层面实现

如果使用了k8s之类能够在比应用更高的维度 实现定向路由的基础环境,那也可以借助此类工具实现。它们的原理基本是通过给pod 打标,然后路由到指定pod,进而路由到指定实例。在这个层面对应用是无感的

应用层面实现

如果我们的部署环境不支持在应用外定向路由。那么也可以在应用层面实现类似的功能。

  • 首先,要做的是给应用打标。要让注册中心(通常为Nacos)知道这个实例的是有特殊含义实例。这一步可以通过 Registration Bean追加元数据的方式实现
  • 其次,需要自定义查找是实例的逻辑,根据自定义逻辑查找到想要的实例。这个逻辑就完全自定义了(比如:针对特定请求头、特定设备、甚至特定用户(必须是在已经认证的前提下)等等都是可以的)。可以参考ServiceInstanceChooser
    • 根据当前请求中请求头。只要包含特定请求头,那么就去注册中的实例中匹配上面定义的元数据。
    • xxx其他方式类似。

总结

大致分析下来。简单来讲就两步:

  • 给实例打标
  • 自定义查找实例的逻辑,匹配上面给实例分配的标记
相关推荐
荔枝吻22 分钟前
【抽丝剥茧知识讲解】引入mybtis-plus后,mapper实现方式
java·sql·mybatis
在未来等你27 分钟前
互联网大厂Java求职面试:构建高并发直播平台的架构设计与优化
java·spring boot·微服务·kubernetes·高并发·分布式系统·直播平台
轮到我狗叫了1 小时前
力扣.1471数组的k个最强值,力扣.1471数组的k个最强值力扣1576.替换所有的问号力扣1419.数青蛙编辑力扣300.最长递增子序列
java·数据结构·算法
秋野酱1 小时前
基于SpringBoot的家政服务系统设计与实现(源码+文档+部署讲解)
java·spring boot·后端
趁你还年轻_1 小时前
常用的Java工具库
java
不再幻想,脚踏实地1 小时前
Spring Boot 日志
java·spring boot·后端
风象南2 小时前
SpringBoot中10种动态修改配置的方法
java·spring boot·后端
金斗潼关2 小时前
基于OAuth2+SpringSecurity+Jwt实现身份认证和权限管理后端服务
java·鉴权
代码小将5 小时前
Leetcode209做题笔记
java·笔记·算法
专注_每天进步一点点5 小时前
idea 启动Springboot项目在编译阶段报错:java: OutOfMemoryError: insufficient memory
java·spring boot·intellij-idea