认识微服务
随着互联网行业的发展,对服务的要求也越来越高,服务架构也从单体架构逐渐演变为现在流行的微服务架构。这些架构之间有怎样的差别呢?
优点:
- 
架构简单 
- 
部署成本低 
缺点:
- 
耦合度高(维护困难、升级困难) 
优点:
- 
降低服务耦合 
- 
有利于服务升级和拓展 
缺点:
- 
服务调用关系错综复杂 
分布式架构虽然降低了服务耦合,但是服务拆分时也有很多问题需要思考:
- 
服务拆分的粒度如何界定? 
- 
服务之间如何调用? 
- 
服务的调用关系如何管理? 
人们需要制定一套行之有效的标准来约束分布式架构。
- 
单一职责:微服务拆分粒度更小,每一个服务都对应唯一的业务能力,做到单一职责 
- 
自治:团队独立、技术独立、数据独立,独立部署和交付 
- 
面向服务:服务提供统一标准的接口,与语言和技术无关 
- 
隔离性强:服务调用做好隔离、容错、降级,避免出现级联问题 

因此,可以认为微服务是一种经过良好架构设计的分布式架构方案 。
但方案该怎么落地?选用什么样的技术栈?全球的互联网公司都在积极尝试自己的微服务落地方案。
其中在Java领域最引人注目的就是SpringCloud提供的方案了。
SpringCloud集成了各种微服务功能组件,并基于SpringBoot实现了这些组件的自动装配,从而提供了良好的开箱即用体验。

另外,SpringCloud底层是依赖于SpringBoot的,并且有版本的兼容关系:
- 
- 
分布式架构:松耦合,扩展性好,但架构复杂,难度大。适合大型互联网项目,例如:京东、淘宝 
- 
①优点:拆分粒度更小、服务更独立、耦合度更低 ②缺点:架构非常复杂,运维、监控、部署难度提高 
- 
SpringCloud是微服务架构的一站式解决方案,集成了各种优秀微服务功能组件 
- 
 
                     
                    
                 
                    
                

 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号