从单体架构到微服务架构的演变,微服务带来的挑战是什么?

2024-08-28 22:36

本文主要是介绍从单体架构到微服务架构的演变,微服务带来的挑战是什么?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 微服务架构
    • 与SOA架构最大的不同就是如下的几点。
    • 微服务架构带来的挑战
      • 微服务架构的优点
      • 微服务架构面临的挑战
    • 如何实现微服务架构
      • 微服务架构图

微服务架构

在这里插入图片描述
  业务系统进行服务化改造之后,对于原有的共享类型的业务系统可以拆分成复用的服务而存在,大大提升了整体系统的资源利用率。对于服务的拆分是否越小越好,还是需要结合业务场景进行拆分,最终达到解耦合的目的,可以提升业务的容错性等等内容。

  微服务解决方案,从名字上看是面向服务的,也就是说通过一种服务化的思想来实现。如果说SOA是服务化开发思想的雏形,那么微服务架构其实就是针对可重用的微服务进行了进一步的优化。可以把SOA架构看做是微服务的超级集合,也就是说多个微服务可以组成一个SOA的服务。

  伴随着服务粒度的细粒度化,可能原本的服务会被越拆分越小,一旦服务规模越来越大随之而来的就是构建、发布、运维等工作内容的增加。所以现在出现的很多的技术就是围绕解决这个问题来进行的。例如K8S等等。微服务是一种服务化的实现思想。

与SOA架构最大的不同就是如下的几点。

  • SOA关注的是服务的重用性以及解决信息孤岛的问题。
  • 微服务则是关注与服务的解耦,从这个方面来看,服务解耦和可重用其实是一样的。但本质上是有区别的,解耦是降低业务场景之间的耦合度,而重用更关注的是服务的复用度。也就是说重用的服务已经是解耦之后的内容了。
  • 微服务会更关注DevOps的持续交付上,因为服务细粒度拆分之后,运维的难度随之升级。所以容器化技术就显得尤为重要了。

  如下图所示,我们将每个具体的业务拆分成了可独立运行的服务,每个服务只需要实现特定的功能就可以了,服务之间采用轻量级机制REST API进行通信。这与SOA中的服务的拆分粒度是不同的。例如一个用户服务在SOA架构中就是用户服务,但是在微服务架构中可以将服务继续进行拆分成,用户注册服务、用户鉴权服务等等。实际上微服务的拆分力度没有一个统一的标准,更多的时候是与业务相关联的。微服务并不是拆分得越细越好。

在这里插入图片描述

微服务架构带来的挑战

  从单体架构到微服务架构的演变,是技术架构随着产品的复杂度发展而不断进步的过程,最终的目的都是更好地提供服务。使得用户在使用产品的时候获得更好的体验,微服务架构之所以能被广泛地应用其背后可能有它独有的优势。

微服务架构的优点

  • 复杂度可控制: 通过共享服务之间的细粒度,一个服务只需要关注一个特定的业务领域解决方案,并且能更好地实现高效快速的开发内容。
  • 技术选型灵活:每个微服务可以由不同的语言来提供,可以选择适合自己的技术栈来进行实现。
  • 扩展性强:可以根据每个微服务的性能包括使用率等方面来对服务进行一个灵活的扩展。
  • 独立部署:由于每个微服务都是可以进行独立运行的,所以可以进行独立的部署。当某个微服务发生变更的时候不需要重新修改其他的服务,代码量比较小,发布更加灵活。
  • 容错性:在微服务架构中,如果一个服务器发生故障,可以使用故障隔离手段,将其进行服务隔离、服务降级等操作。

微服务架构面临的挑战

  微服务架构只是一种架构模式,并不能解决所有架构问题。虽然本身有很多的优势的地方,但是在使用过程中,经常会遇到分库分表,API交互,大量的微服务的运维与开发等问题。主要有如下的一下问题

  • 故障排查:一次请求经历了很多的不同业务场景的微服务,交互的链路很长,每个微服务会产生自己的日志,这种情况下出现一个问题的时候开发人员在查找过程中会比较困难。
  • 服务监控:在一个单体架构中很容易实现服务的监控操作,因为所有的服务资源都在一个Jar包中。但是在微服务架构中,服务的监控操作其实本身就是一件很耗资源的事情,在几百个微服务的架构中进行全链路的监控,算上服务本身对于资源的消耗,为了监控这些服务的运行情况二次消耗的资源也是比较大的。
  • 分布式架构的复杂性问题:微服务系统本身是一个分布式系统,既然是分布式系统那么不可避免的就要解决分布式系统CAP问题,包括远程通信的过程中网络上消耗等无法避免的情况的出现。
  • 服务依赖:随着服务的不断增加,会存在服务之间的相互依赖,在单体应用中服务之间的依赖只需要改变模块之间的依赖关系就可以了,但是在微服务之中不同的服务之间通过这种方式很难实现依赖的完全拆解。所以需要对于依赖进行一个合理的划分。
  • 运维成本:微服务架构中,成百上千的微服务的正常运行,离不开运维人员的支持,但是在单体应用中运维人员只需要进行简单的运维操作就可以,在微服务架构中就会有很多的问题、如何快速部署、如何统一进行服务的管理,这就需要SRE工程师的不断优化部署架构等内容。

如何实现微服务架构

微服务架构图

在这里插入图片描述
  现在网上这种微服务架构图一抓一大把,但是微服务到底如何实现,这个是关键性的问题。

  微服务架构实现需要实现的就是服务的结合操作。随着业务的发展支持微服务的组件也会越来越多,导致微服务之间的调用关系原来越复杂,同时服务之间的通信问题也就会变得复杂,难以管理,然后再要考虑到重试、容错、服务降级等情况。这个时候就需要服务治理的出现,将服务之间的相互依赖关系转化为对于服务注册中心的依赖关系。除此还要考虑如下的一些问题

  • 分布式配置
  • 服务路由
  • 负载均衡
  • 服务熔断限流
  • 全链路监控

  以上的每个问题都需要一个对应的技术栈来解决与之对应的问题。首先考虑的就是用现成的东西还是自己有研发能力进行研发,那种解决方案更好,就需要对每种解决方案进行讨论进行最终的解决方案的操作。

  现在很多的公司都是有适合自己公司的一套技术体系的东西,就算是使用了开源的中间件,后期也会因为业务的需求进行定制化的开发,毕竟很多的东西,总结出来只是普适性的内容。但是真正适合自己公司业务的内容还是需要经过公司的业务验证才能进行确定的。

  后续的分享中也会带着大家进行一个深入的探讨。

这篇关于从单体架构到微服务架构的演变,微服务带来的挑战是什么?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

如何搭建并配置HTTPD文件服务及访问权限控制

《如何搭建并配置HTTPD文件服务及访问权限控制》:本文主要介绍如何搭建并配置HTTPD文件服务及访问权限控制的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、安装HTTPD服务二、HTTPD服务目录结构三、配置修改四、服务启动五、基于用户访问权限控制六、

SpringCloud整合MQ实现消息总线服务方式

《SpringCloud整合MQ实现消息总线服务方式》:本文主要介绍SpringCloud整合MQ实现消息总线服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、背景介绍二、方案实践三、升级版总结一、背景介绍每当修改配置文件内容,如果需要客户端也同步更新,

linux服务之NIS账户管理服务方式

《linux服务之NIS账户管理服务方式》:本文主要介绍linux服务之NIS账户管理服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、所需要的软件二、服务器配置1、安装 NIS 服务2、设定 NIS 的域名 (NIS domain name)3、修改主

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

使用Node.js制作图片上传服务的详细教程

《使用Node.js制作图片上传服务的详细教程》在现代Web应用开发中,图片上传是一项常见且重要的功能,借助Node.js强大的生态系统,我们可以轻松搭建高效的图片上传服务,本文将深入探讨如何使用No... 目录准备工作搭建 Express 服务器配置 multer 进行图片上传处理图片上传请求完整代码示例

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)