深入微服务框架:构建高效、可扩展与弹性的现代应用架构

news/2024/9/25 19:16:37/

前言:当今快速迭代和多变的商业环境中,传统的单体应用程序面临着一系列挑战,包括难以管理复杂性、缺乏灵活性以及无法有效扩展等问题。随着业务需求的不断增长和技术栈的不断演进,企业亟需一种更加模块化、易于管理和扩展的应用程序架构。这就是微服务框架应运而生的背景,它为开发者提供了一种将大型应用程序分解成独立、松散耦合的服务的方法。

        假如我们打算开发一个应用程序,就拿支付宝来说,我们常用的业务是支付,但是我们内部也需要其他的业务,我们实现功能AB的时候,每个子模块都是独立开发的。

        模块ABCD...都需要扫描我们的数据库,也都需要额外的实现支付功能,那么我们的这个程序过于冗余,而且每个模块在使用的时候都需要扫描一次数据库,这对于数据库来说压力过大了。

那么如何解决呢?

假如我想开发一个模块,这个模块需要六个功能,然后我们的仓库里有五个我们需要的功能,那我们直接通过平台调用即可。这里准备好的功能我们称为生产者,使用,直接调用我们已经实现的模块称为消费者,管理消费者和生产者的平台我们称为管理平台。

生产者是整个业务的核心,中央管理平台怎么确定生产者处于正常运行状态呢:心跳,每隔一段时间生产者就向中央管理平台发送心跳代表自己处于正常运行状态。

一个完整的微服务框架都需要哪些部分及功能:

中央管理平台功能:生产者,消费者,注册,服务发现,服务治理,申请调用

生产者

消费者

权限管理:能是否调通

流量管理:消费者A申请时表示我每分钟调用200次,那么框架就需要限制消费者A的流量小于等于200,如果不对他进行一个限制的话,很有可能压力过大导致服务崩溃。

负载均衡:在集群的时候,如何平衡效率更高

自定义传输协议:为了适应不同的通信需求,微服务框架可能支持自定义的传输协议

序列化反序列化:数据在网络中传输时通常需要被序列化和反序列化,这是确保不同服务间能够正确理解和交换信息的关键步骤。

流程:


http://www.ppmy.cn/news/1426663.html

相关文章

探索C语言数据结构:利用顺序表完成通讯录的实现

在好久之前我就已经学习过顺序表,但是在前几天再次温习顺序表的时候,我惊奇的发现顺序编表可以完成我们日常使用的通讯录的功能,那么今天就来好好通过博客总结一下通讯录如何完成吧。 常常会回顾努力的自己,所以要给自己的努力留…

设计模式- 建造者模式(Builder Pattern)结构|原理|优缺点|场景|示例

目录 设计模式(分类) 设计模式(六大原则) 创建型 工厂方法 抽象工厂模式 单例模式 建造者模式 原型模式 结构型 适配器模式 建造者模式(Builder Pattern)是一种创…

使用 Python 从 PDF 文件中提取、转换图像

目录: 从 PDF 中提取图像将 PDF 页面转换为图像 本文的任务是从 PDF 文件中提取图像,并使用 Python 中将 PDF 页面转换为图像。为了实现使用 Python 从 PDF 文件中提取图像,需要安装使用 Fitz、PyMuPDF 库。 Fitz 库是一个图像处理库&#xf…

vue2响应式 VS vue3响应式

Vue2响应式 存在问题: 新增属性,删除属性,界面不会更新。 直接通过下标修改数组界面不会自动更新。 Vue2使用object.defineProperty来劫持数据是否发生改变,如下: 能监测到获取和修改属性: 新增的属性…

“手撕“三大特性之一的<继承>(上)

目录 一、为什么需要继承 二、什么是继承 三、继承怎么写 四、成员的访问 1.父类与子类的成员变量不同名 2.父类与子类的成员变量同名 3.父类与子类的成员方法不同名 4.父类与子类的成员方法同名 五、super关键字 一、为什么需要继承 先让我们看一段Java代码&#…

Spring AI ETL 流水线

先纠正 Spring AI 使用本地 Ollama Embeddings 中的一个错误,当启动 Ollama 之后,Windows会有托盘图标,此时已经启动了 Ollama 的服务,访问 Embedding 时不需要运行 ollama run gemma ,只有访问 chat 时才需要启动一个…

富文本插入图片的时候直接复制链接的风险点和解决方案

业务背景 最近由于项目需要开发了一个富文本的功能其中有一个小点是插入图片到富文本中, 插入的时候是可以直接复制图片的链接地址插入的我本来觉得没啥,但是感觉哪里不太对,于是开始了风险点评估,以及对应的解决方案 风险点评…

openGauss学习笔记-265 openGauss性能调优-TPCC性能调优测试指导-操作系统配置

文章目录 openGauss学习笔记-265 openGauss性能调优-TPCC性能调优测试指导-操作系统配置265.1安装openEuler操作系统265.2 修改操作系统内核PAGESIZE为64KB。265.3 关闭CPU中断的服务irqbalance openGauss学习笔记-265 openGauss性能调优-TPCC性能调优测试指导-操作系统配置 本…