当前位置: 首页 > news >正文

认识微服务

目录

一.单体架构

1.定义

2.优点

3.缺点

4.结论

二.微服务

1.定义

三.SpringCloud

1.定义

2.版本要求


一.单体架构

1.定义

将业务的所有功能集中在一个项目中开发,打成一个包部署。

2.优点

  • 架构简单:基本没什么架构,打开项目就写
  • 部署成本低:打成jar包,放到linux中,一行执行命令就能运行

3.缺点

  • 团队协作成本高:复杂项目如果采用单体架构,几十个开发人员都在一个Java工程中写代码,提交git时,很容易造成冲突,每天不是在解决冲突就是在制造冲突。
  • 系统发布效率低:每当项目添加一点点新功能后,就需要重新打jar包、重新部署,这样耗时太长,效率低
  • 系统可用性差:单体架构的项目,打成1个jar包,只有一台tomcat服务器,扛不住大量用户的访问,导致后端接口响应速度慢,甚至导致后端崩溃

4.结论

        单体架构,不适合大型、复杂、用户量大的项目,而适合功能简单、开发人员少、用户量小的项目。

二.微服务

1.定义

        微服务架构,是服务化思想(把单体架构中的功能,拆分成一个个独立的项目)指导下的一套最佳架构方案。

举例:

  • 拆分前:所有功能,放到一个项目中,打成一个jar包

  • 拆分后:每一个功能,打成一个jar包,都有独立的tomcat服务器和数据库。这样一个功能响应慢/崩溃,就不会影响到其他功能,做到了服务自治

三.SpringCloud

1.定义

SpringCloud是目前国内使用最广泛的微服务框架。

SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了这些组件的自动装配,从而提供了良好的开箱即用体验。

2.版本要求

由于SpringCloud要基于SpringBoot做自动装配,因此二者的版本必须要匹配,如下:

 

http://www.xdnf.cn/news/655885.html

相关文章:

  • 区块链与Web3:如何有效保障个人数据安全
  • 扩容的未来:Web3 并行计算赛道全景图谱
  • moviepy视频添加中文水印
  • 网络原理 | TCP与UDP协议的区别以及回显服务器的实现
  • 热门大型语言模型(LLM)应用开发框架
  • yolov8分割任务的推理和后处理解析
  • HMI仿真报错
  • 【MATLAB例程】声纳信号处理与目标测距的程序|信号频率、信噪比、采样率和声速均可自行调整|附代码下载链接
  • 【Bug】--node命令加载失败
  • 安卓端智能耗材柜系统可行性方案(基于uniapp + Vue3)
  • 数据的六个特性以及由于独特性产生的一些有趣的想法
  • 【C/C++】基于 Docker 容器运行的 Kafka + C++ 练手项目
  • Vue条件渲染
  • JavaScripts console.log和console.dir区别
  • Linux基本指令篇 —— clear指令
  • Vue 前端全方位性能优化指南
  • 【Hive基础】01.数据模型、存储格式、排序方式
  • FFmpeg 时间戳回绕处理:保障流媒体时间连续性的核心机制
  • 双11、618大促要做什么?
  • vs2022 调试时 控制台界面不出来
  • 基于离散元仿真软件DEMms的双锥水力旋流器-颗粒分离性能分析
  • 白平衡校正中冯・克里兹参数计算过程详解
  • 通过Jflash合并Boot和App两个hex为一个hex的办法
  • C++11——智能指针
  • Django压缩包形式下载文件
  • Halcon 图像预处理②
  • (11)Service Mesh架构下Java应用实现零信任安全模型
  • 运维_麒麟_国产系统桌面版安装
  • 编程日志5.21
  • ScrollView 嵌套 RecyclerView 滑动处理方案