案例:微服务从Java/SpringBoot迁移到Golan
基于 Java 的微服务,特别是那些使用 Spring Boot 的微服务,长期以来因其强大的功能和广泛的社区支持而闻名。Spring Boot 的约定优于配置方法简化了微服务的部署和开发,提供了大量开箱即用的功能,例如自动配置、独立功能和简单的依赖关系管理,使其成为许多人的首选开发工具。该生态系统为构建有弹性和可扩展的服务提供了成熟且有据可查的途径。
然而,尽管有这些实质性的好处,但仍然存在一些痛点,例如较长的启动时间、内存消耗以及管理基于 JVM 的应用程序带来的复杂性,这可能会阻碍云环境中的性能和成本效率。
在维护 Java 生态系统的最后努力中,我们尝试了 Quarkus,希望它优化运行时和减少内存占用的承诺能够解决我们的担忧。。Quarkus 能够将应用程序编译为本机可执行文件,这似乎是希望的灯塔。
然而,现实却是错综复杂的。使我们的应用程序本地编译的过程充满了许多调整和解决方法。更令人沮丧的是原生构建的脆弱性。
与 Quarkus 的本机镜像不完全兼容的单个第三方库可能会破坏整个设置,迫使我们重新将其作为标准 JDK 应用程序运行。性能增益和操作稳定性之间的这种不稳定的平衡凸显了对更精简、更少约束的解决方案的需求。
目标
我们需要一个能够快速构建本机镜像的解决方案:
- 包含 SDK 本身内的所有必要的微服务组件。
- 它需要拥有令人印象深刻的快速启动时间,
- 轻松打包到从头开始生成的 Docker 映像中,并保持轻量级占用空间,容器映像大小和
- RAM 使用量均低于 100 MB。
Golang:简化微服务以提高效率和可靠性
Golang 是一种为现代计算挑战而设计的语言。与 Java 相关的复杂性和开销以及 Quarkus 中本机编译的不稳定性质不同,Golang 提供了一种简单、高效的方法来构建微服务。
-
其编译为本机二进制文件消除了对 JVM 的需求,从而大大减少了内存占用和启动时间。
-
Golang 凭借其强大的并发支持和简单、干净的语法,简化了开发过程并增强了性能。
-
此外,其强大的标准库和简约的本质意味着更少的依赖性和更低的兼容性问题机会。
Golang 不仅解决了前面提到的痛点,还推动应用程序进入更高效率和可靠性的领域。
如何计划迁移
最初,我们遵循领域驱动设计 (DDD) 原则将业务分解为各个子域,旨在为每个子域分配专用的微服务。具体来说,我们专注于为人力资源管理、财务管理和资产管理创建独特的微服务。接下来,我们确定了共享内核微服务来管理多个子域使用的域实体的需求。我们共同使用白板在微服务中描绘了这些域实体,确保了清晰且逻辑的分布。
为了可视化并更好地组织我们的架构,我们制作了一个依赖关系图。该图根据微服务的相互依赖性将微服务分层,其中共享内核形成基础层,而更加孤立的、特定于子域的微服务占据较高层。
我们准备阶段的最后一步涉及为每个微服务编制完整的用例列表。我们根据测试用例和遗留后端中的现有用例精心映射这些内容,确保彻底、无缝地过渡到我们新的、更高效的微服务架构。
如何执行迁移
我们选择了 monorepo 方法,将所有微服务组织为名为“ems-backend”的单个存储库下的单独文件夹。此外,我们制作并开源了一个简单的框架式包。该包有助于实现 Golang 微服务,配有 HTTP 服务器和 Mongo 数据库,同时遵循干净架构的原则。
利用我们的框架,主要任务是将用例开发为系统内命令和查询的函数。然而,我们确实为特定的 HTTP 任务(例如文件上传)编写了自定义处理程序。在我们的设置中,用例是后端的核心方面,协调多个域实体以有效地满足用户需求。
基于我们的成功,我们还使用 Go 开发了一个异常快速的 API 网关。该网关执行符合 OWASP 微服务安全标准的边缘身份验证。每个微服务都配备了自己的中间件,这是一个简单的功能,可以根据 Passport 令牌中嵌入的角色验证传入请求 URL。这确保了服务之间安全、高效的交互。
迁移后我们的成就
我们修改了 Kubernetes 清单来部署应用程序,将 RAM 限制从 500 MB 减少到仅 50 MB。
这次转变非常显着:我们的 32 GB 后端现在可以在 8 GB 集群上顺利运行,仅使用 2 GB RAM。
如果您当前正在管理 RAM 限制为 2 GB 或更多的 JDK 应用程序,那么我们的故事可能会为您带来希望的灯塔。
相关文章:
案例:微服务从Java/SpringBoot迁移到Golan
基于 Java 的微服务,特别是那些使用 Spring Boot 的微服务,长期以来因其强大的功能和广泛的社区支持而闻名。Spring Boot 的约定优于配置方法简化了微服务的部署和开发,提供了大量开箱即用的功能,例如自动配置、独立功能和简单的依…...
小波变换模拟
小波变换是一种信号处理技术,通过在时间-频率域中使用基于小波的函数进行信号分析。小波变换在处理非平稳信号和图像时特别有用,可以将信号分解为不同频率的成分。它在数据压缩、去噪、特征提取等领域有广泛应用。 MATLAB中提供了用于二维离散小波变换的…...
cv::Mat图像操作
图像读写 //include header #include <opencv2/imgcodecs.hpp>/** Currently, the following file formats are supported: Windows bitmaps - *.bmp, *.dib (always supported) JPEG files - *.jpeg, *.jpg, *.jpe (see the Note section) JPEG 2000 files - *.jp2 (s…...
【机器学习基础】一元线性回归(适合初学者的保姆级文章)
🚀个人主页:为梦而生~ 关注我一起学习吧! 💡专栏:机器学习 欢迎订阅!后面的内容会越来越有意思~ 💡往期推荐: 【机器学习基础】机器学习入门(1) 【机器学习基…...
2024年软件测试岗位-面试
第一部分: 1、自我介绍:简历写到的快速描述,学校、学历、工作经验等(注意:不要过度优化简历,你不写别人可能会问,但你写了别人一定会问!) 第二部分: 1、功能测…...
【坑】Spring Boot整合MyBatis,一级缓存失效
一、Spring Boot整合MyBatis,一级缓存失效 1.1、概述 MyBatis一级缓存的作用域是同一个SqlSession,在同一个SqlSession中执行两次相同的查询,第一次执行完毕后,Mybatis会将查询到的数据缓存起来(缓存到内存中…...
J7 - 对于ResNeXt-50算法的思考
🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 | 接辅导、项目定制 J6周有一段代码如下 思考过程 首先看到这个问题的描述,想到的是可能使用了向量操作的广播机制然后就想想办法验证一下&…...
R3F(React Three Fiber)基础篇
之前一直在做ThreeJS方向,整理了两篇R3F(React Three Fiber)的文档,这是基础篇,如果您的业务场景需要使用R3F,您又对R3F不太了解,或者不想使用R3F全英文文档,您可以参考一下这篇&…...
torch\tensorflow在大语言模型LLM中的作用
文章目录 torch\tensorflow在大语言模型LLM中的作用 torch\tensorflow在大语言模型LLM中的作用 在大型语言模型(LLM)中,PyTorch和TensorFlow这两个深度学习框架起着至关重要的作用。它们为构建、训练和部署LLM提供了必要的工具和基础设施。 …...
设计模式-创建型模式-单例模式
0 引言 创建型模式(Creational Pattern)关注对象的创建过程,是一类最常用的设计模式,每个创建型模式都通过采用不同的解决方案来回答3个问题:创建什么(What),由谁创建(W…...
备战蓝桥杯—— 双指针技巧巧答链表1
对于单链表相关的问题,双指针技巧是一种非常广泛且有效的解决方法。以下是一些常见问题以及使用双指针技巧解决: 合并两个有序链表: 使用两个指针分别指向两个链表的头部,逐一比较节点的值,将较小的节点链接到结果链表…...
微信小程序返回上一级页面并自动刷新数据
文章目录 前言一、获取小程序栈二、生命周期触发总结 前言 界面由A到B,在由B返回A,触发刷新动作 一、获取小程序栈 界面A代码 shuaxin(){//此处可进行接口请求从而实现更新数据的效果console.log("刷新本页面数据啦")},界面B代码 // 返回触…...
Spring⼯⼚创建复杂对象
文章目录 5. Spring⼯⼚创建复杂对象5.1 什么是复杂对象5.2 Spring⼯⼚创建复杂对象的3种⽅式5.2.1 FactoryBean 接口5.2.2 实例⼯⼚5.2.3 静态工厂 5.3 Spring 工厂的总结 6. 控制Spring⼯⼚创建对象的次数6.1 如何控制简单对象的创建次数6.2 如何控制复杂对象的创建次数6.3 为…...
Top-N 泛型工具类
一、代码实现 通过封装 PriorityQueue 实现,PriorityQueue 本质上是完全二叉树实现的小根堆(相对来说,如果比较器反向比较则是大根堆)。 public class TopNUtil<E extends Comparable<E>> {private final PriorityQ…...
Java 后端面试指南
面试指南 TMD,一个后端为什么要了解那么多的知识,真是服了。啥啥都得了解 MySQL MySQL索引可能在以下几种情况下失效: 不遵循最左匹配原则:在联合索引中,如果没有使用索引的最左前缀,即查询条件中没有包含…...
142.环形链表 ||
给定一个链表的头节点 head ,返回链表开始入环的第一个节点。 如果链表无环,则返回 null。 如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整…...
Nacos、Eureka、Zookeeper注册中心的区别
Nacos、Eureka和Zookeeper都是常用的注册中心,它们在功能和实现方式上存在一些不同。 Nacos除了作为注册中心外,还提供了配置管理、服务发现和事件通知等功能。Nacos默认情况下采用AP架构保证服务可用性,CP架构底层采用Raft协议保证数据的一…...
CSS重点知识整理1
目录 1 平面位移 1.1 基本使用 1.2 单独方向的位移 1.3 使用平面位移实现绝对位置居中 2 平面旋转 2.1 基本使用 2.2 圆点转换 2.3 多重转换 3 平面缩放 3.1 基本使用 3.2 渐变的使用 4 空间转换 4.1 空间位移 4.1.1 基本使用 4.1.2 透视 4.2 空间旋转 4.3 立…...
【Langchain多Agent实践】一个有推销功能的旅游聊天机器人
【LangchainStreamlit】旅游聊天机器人_langchain streamlit-CSDN博客 视频讲解地址:【Langchain Agent】带推销功能的旅游聊天机器人_哔哩哔哩_bilibili 体验地址: http://101.33.225.241:8503/ github地址:GitHub - jerry1900/langcha…...
算法学习(十二)并查集
并查集 1. 概念 并查集主要用于解决一些 元素分组 问题,通过以下操作管理一系列不相交的集合: 合并(Union):把两个不相交的集合合并成一个集合 查询(Find):查询两个元素是否在同一…...
嘎嘎降AI和PaperRR深度对比:2026年学术期刊SCI论文降AI性能完整评测报告
嘎嘎降AI和PaperRR深度对比:2026年学术期刊SCI论文降AI性能完整评测报告 总有人问我选哪个降AI工具,这篇文章把主流的几款对比清楚。 综合推荐嘎嘎降AI(www.aigcleaner.com),4.8元,99.26%达标率。不同需求…...
树莓派BlueZ源码编译安装与蓝牙协议栈深度配置指南
1. 项目概述与背景 如果你手头有一块树莓派,并且想用它来玩点物联网或者智能硬件项目,蓝牙功能几乎是绕不开的一环。无论是连接一个BLE温湿度传感器读取数据,还是控制一个蓝牙音箱,底层都需要一个稳定、功能完整的蓝牙协议栈来支…...
MATLAB调用C/C++库报错?手把手教你配置Visual Studio 2022编译器(含低版本MATLAB适配指南)
MATLAB调用C/C库报错?手把手教你配置Visual Studio 2022编译器(含低版本MATLAB适配指南) 当你在MATLAB中尝试调用C/C库时,突然弹出一个令人头疼的错误提示:"未找到支持的编译器或 SDK"。这种情况在工程开发和…...
Win10/Win11网络适配器出问题?试试这个重置TCP/IP和Winsock的终极命令(netsh winsock reset)
彻底解决Windows网络协议栈故障:netsh命令深度指南 当你的Windows 10或11设备突然无法联网,甚至连网络适配器都显示异常时,大多数人会本能地尝试重启电脑或切换飞行模式。但如果你发现这些常规操作毫无效果,甚至Windows自带的网络…...
layerJS与现代前端框架集成:Vue、React、Angular中的最佳实践指南 [特殊字符]
layerJS与现代前端框架集成:Vue、React、Angular中的最佳实践指南 🚀 【免费下载链接】layerJS layerJS: Javascript UI composition framework 项目地址: https://gitcode.com/gh_mirrors/la/layerJS layerJS是一个创新的JavaScript UI组合框架&…...
BLE AT指令实战:从GAP广播到GATT服务构建的嵌入式蓝牙开发指南
1. 项目概述与BLE AT指令核心价值如果你正在捣鼓物联网设备、可穿戴硬件或者任何需要无线连接的嵌入式项目,蓝牙低功耗(BLE)技术大概率是你绕不开的一环。它功耗低、连接快,非常适合那些需要长时间运行、间歇性传输少量数据的场景…...
Midjourney现代主义风格提示词工程(2024权威白皮书首发):覆盖12类先锋流派+87个已验证prompt模板
更多请点击: https://intelliparadigm.com 第一章:Midjourney现代主义风格的美学基因与范式跃迁 现代主义风格在Midjourney中的生成并非对包豪斯或构成主义的简单复刻,而是通过扩散模型对20世纪视觉语法进行概率性重编码——其核心在于将“简…...
WELearn网课助手:5分钟告别熬夜刷课,实现高效学习自由的终极指南
WELearn网课助手:5分钟告别熬夜刷课,实现高效学习自由的终极指南 【免费下载链接】WELearnHelper 显示WE Learn随行课堂题目答案;支持班级测试;自动答题;刷时长;基于生成式AI(ChatGPT)的答案生成 项目地址…...
构建智能增量更新插件:Softer-Delta算法与工程实践
1. 项目概述与核心价值最近在折腾一些自动化工作流,发现很多场景下,我们都需要一个能“聪明”地处理文件差异、生成补丁,并且能无缝集成到现有工具链里的插件。这让我想起了之前用过的一个叫pear-plugin的工具,它挂在Softer-delta…...
保姆级教程:用R的ggstatsplot包,一键生成带统计检验的SCI级小提琴图
科研绘图革命:用ggstatsplot一键生成统计检验小提琴图的终极指南 在生物医学和生物信息学研究中,数据可视化与统计分析是论文写作中不可或缺的环节。传统流程中,研究者需要先进行统计检验,再将结果手动添加到图表中,这…...
