微服务架构的优势

微服务架构是一种面向服务的架构体系,其中应用程序按功能分解为小型的、松耦合的各种服务。其重点在于,单个服务被划分的足够小,相互间耦合度很低,并围绕业务功能进行分解。

微服务架构经常与单体架构相比较:单体架构一份代码库与数据库和数据结构共享。微服务架构的每一个服务应用的开发、测试、部署、运行都是完全独立,通过API进行相互同信。应用程序的代码库是小型的。微服务的架构示意图:

微服务架构的优势_第1张图片 微服务的架构

 微服务架构的优势如下:

正确实施的微服务架构有助于提升大型应用的发布频率,使得企业能够更快地为客户提供更可靠的服务。

1.敏捷性

对大型的单体应用而言,快速、可靠地部署是一件具有挑战性的事情。一个模块中的改动可能会阻碍你部署另一个功能模块的小改动。随着应用的成长,测试的工作量也会随之增加,这就会导致可能需要相当长的时间才能使得新改动的价值得以体现。一个功能改动会需要整个应用的重新部署,而当出现问题时需要回滚整个应用。通过把一个应用拆分成多个小服务,那么改动所需的验证时间会被缩短,发布速度可以得到提高,同时也会更可靠。

2.持续创新

为了保持领先性,如今的企业需要保持高速的发展,这就要求企业组织必须具备敏捷性以及快速响应市场的能力。企业在为客户提供新产品或新服务时,再也无法以年或者月为周期。他们常常必须按天来上线新功能。微服务架构可以帮助企业更容易和可靠地交付新功能和服务。小型的独立团队甚至可以在业务最繁忙的时候仍旧发布新的功能,同时进行 A/B 测试,以便提升转化率或改善用户体验。

3.渐进式设计

对于单体应用而言,想要引入新的技术或方法可能是非常困难的。因为这通常需要重写整个应用程序,或者需要花费额外的精力确保新引入的依赖项与以前的程序可以同时运行。松耦合和高凝聚是系统设计很重要的两个方面,它们可以保障应用可以通过新技术不断地进行演进。通过把应用按功能拆分成小的、松耦合的服务,可以更轻松地更改单个服务而避免对整个应用程序的影响。根据业务需求,可以在不同的服务中使用不同的编程语言、框架和库。

4.小而专的团队

构建一个大规模的研发团队,还要让他们保持足够的专注和高效率是非常有挑战的事情。如果一个人构建的东西和其他人构建的内容交织在一起,那么你想让他负责其构建的这部分内容的设计、运行和维护也是一项挑战。通过把应用拆分成更小的服务,小的敏捷开发团队可以聚焦在更小的功能点上,并且快速地行动起来。团队成员可以更轻松地维护这个服务并对他们构建的服务负责。

5.故障隔离

在单体应用中,一个库或者模块的故障可能会导致整个应用的故障。一个模块的内存泄露不仅会影响整个应用的稳定性和性能,同时也很难去定位和隔离。通过把应用拆分成小的服务,开发团队就可以把故障限定在这个服务中,而避免对其他服务的影响。

6.更好的扩容和资源利用能力

应用通常可以通过纵向或者横向扩容。纵向扩容是指增加机器的资源或者更换一种更好的机器来实现扩容。而横向扩容是指部署更多的实例,然后通过路由的配置来使用户可以访问这些实例,从而达到扩容的目的。一个应用的不同功能有时候会对资源有不同的需求,例如,内存、CPU 和磁盘等。应用的功能常常会有不同的扩展需求,某些功能可能可以通过增加小规格的实例数量实现横向扩容,而另一些功能可能需要大量的内存,本身也很难使用横向扩容。通过把这些功能拆分成独立的服务,开发人员就可以把服务放在最合适的环境中运行,以满足每个服务的扩容和资源使用的需求。

7.改善可观察性

通过把应用拆分独立的服务,团队可以使用工具深入了解各个功能的运行状况以及和其他服务的交互情况。系统指标(如进程的 CPU 利用率和内存使用量)也更容易和功能关联在一起,因为服务是在一个单独容器或者说是进程中运行的。

你可能感兴趣的:(云原生技术,微服务,java,分布式,云原生)