曾经参与的,服务再拆分和转发

2024-06-12 23:32

本文主要是介绍曾经参与的,服务再拆分和转发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.为什么要做服务再拆分

第一篇就说到我们后台是微服务架构,我们的服务有十几个,一年多来都是这么沿用的,但其中也存在问题,就是有些服务业务比较混乱,比如用户服务中有非用户模块,于是每次修改这些非用户模块时,都要发布用户服务,但用户服务是比较核心的模块,有的时候不和我们版本基线走,就造成了一些崴脚的局面。另一方面这也违背领域驱动模型DDD的原则,服务边界不清会导致服务混乱,耦合不当的问题,于是在今年3月初,经过我的建议和同事间的讨论,主管同意我们做服务拆分。

思路:我们都知道,如果一个业务从一个服务迁移到了另一个服务,那么前端路由势必会变,但是必须兼容前端,否则前端也要修改,但这其实是后端的改造,对前端应该是透明的。于是我们架构同事在zuul新增了转发规则:如果一个请求在请求变化记录表中有,就转发到新的服务

2.实施过程

2.1 服务划分

上面说到为了使服务更合理,粒度更准确,我们对一些业务模块进行了再细分。比如我负责的经费模块从用户模块迁移到一个新的服务,funding。其它要拆分的业务模块也是一样,有的是迁移到新的

2.2 建立新服务模块

  

2.3 如果要换库,就建立新的库。准备脚本迁移表

开发和测试环境自己建,生产环境运维去建

2.4 准备数据迁移脚本,将原表的数据insert into到新表

注意:必须保证开发、测试、各线上环境数据表结构一模一样,否则可能出现不可预期的问题

2.5 加新服务的配置文件,如果不是新服务就不用加

2.6 修改与原服务相关的业务,注意修改表名或文件路径

2.7 记录原服务对应业务的路由到请求变化记录表中

这一篇说到我们用的是Swagger管理Api,还有导出功能,于是我稍微改造了下这里的导出,按要求输出我要的url格式,转换为insert into语句插入到请求变化记录表中。

设置转发规则

这是至关重要的一点,过程大概是这样:

将请求变化记录表初始化redis中

在zuul中转发

读取redis中转发信息

根据当前请求转发

转发并设置缓存

RequestContext设置新的ServiceId,dest表示请求url

思考与回顾:

为什么把请求变化记录表初始化Redis中?

因为请求变化记录表一般不会变,如果每次请求来了还要去查这个表,显然不合理,查缓存是符合要求的。

通过设置Zuul的RequestContext进行转发,学习了。希望后面能够应用。

这篇关于曾经参与的,服务再拆分和转发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1055645

相关文章

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

SysMain服务可以关吗? 解决SysMain服务导致的高CPU使用率问题

《SysMain服务可以关吗?解决SysMain服务导致的高CPU使用率问题》SysMain服务是超级预读取,该服务会记录您打开应用程序的模式,并预先将它们加载到内存中以节省时间,但它可能占用大量... 在使用电脑的过程中,CPU使用率居高不下是许多用户都遇到过的问题,其中名为SysMain的服务往往是罪魁

解决若依微服务框架启动报错的问题

《解决若依微服务框架启动报错的问题》Invalidboundstatement错误通常由MyBatis映射文件未正确加载或Nacos配置未读取导致,需检查XML的namespace与方法ID是否匹配,... 目录ruoyi-system模块报错报错详情nacos文件目录总结ruoyi-systnGLNYpe

基于Python实现进阶版PDF合并/拆分工具

《基于Python实现进阶版PDF合并/拆分工具》在数字化时代,PDF文件已成为日常工作和学习中不可或缺的一部分,本文将详细介绍一款简单易用的PDF工具,帮助用户轻松完成PDF文件的合并与拆分操作... 目录工具概述环境准备界面说明合并PDF文件拆分PDF文件高级技巧常见问题完整源代码总结在数字化时代,PD

Nginx进行平滑升级的实战指南(不中断服务版本更新)

《Nginx进行平滑升级的实战指南(不中断服务版本更新)》Nginx的平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法,这种升级方式确保了服务的高可用性,避免了因升... 目录一.下载并编译新版Nginx1.下载解压2.编译二.替换可执行文件,并平滑升级1.替换可执行文件

Spring Boot 与微服务入门实战详细总结

《SpringBoot与微服务入门实战详细总结》本文讲解SpringBoot框架的核心特性如快速构建、自动配置、零XML与微服务架构的定义、演进及优缺点,涵盖开发环境准备和HelloWorld实战... 目录一、Spring Boot 核心概述二、微服务架构详解1. 微服务的定义与演进2. 微服务的优缺点三

RabbitMQ消息总线方式刷新配置服务全过程

《RabbitMQ消息总线方式刷新配置服务全过程》SpringCloudBus通过消息总线与MQ实现微服务配置统一刷新,结合GitWebhooks自动触发更新,避免手动重启,提升效率与可靠性,适用于配... 目录前言介绍环境准备代码示例测试验证总结前言介绍在微服务架构中,为了更方便的向微服务实例广播消息,