1 什么是微服务?
微服务的概念最早是在2014年由MartinFowler和JamesLewis共同提出,他们定义了微服务是由单一应用程序构成的小服务,拥有自己的进程与轻量化处理,服务依业务功能设计,以全自动的方式部署与其他服务使用HTTPAPI通讯.同时,服务会使用最小规模的集中管理(例如Docker)技术,服务可以用不同的编程语言与数据库等.
简单举例:看军事新闻的同学应该都知道,一艘航空母舰作战能力虽然很强,但是弱点太明显,就是防御能力太差,单艘的航空母舰很少单独行动,通常航空母舰战斗群才是主要军事力量,你可以把单艘航母理解为的单体应用(防御差,机动性不好),把航母战斗群(调度复杂,维护费用高)理解为微服务.
2 为什么使用微服务?
2.1 单体应用特点
- 大部分的开发者经历和开发过单体应用,无论是传统的Servlet+JSP,还是SSM,还是现在的SpringBoot,它们都是单体应用,那么长期陪伴我们的单体应用有什么弊端?我们是面临了什么问题,导致我们要抛弃单体应用转向微服务架构?
主要原因如下:
部署成本高(无论是修改1行代码,还是10行代码,都要全量替换).
改动影响大,风险高(不论代码改动多小,成本都相同).因为成本高,风险高,所以导致部署频率低(无法快速交付客户需求).无法满足快速扩容,弹性伸缩,无法适应云环境特性等问题.
2.2微服务特点
微服务架构的特点:针对特定服务发布,影响小,风险小,成本低;频繁发布版本,快速交付需求;低成本扩容,弹性伸缩,适应云环境.我们知道一个朴素的理念,没有任何事物是完美的,任何东西都有两面性,有得必有失,那么在选择微服务在解决了快速响应和弹性伸缩的问题同时,它又给我们带来了什么问题?
简单总结如下:
- 分布式系统的复杂性
- 部署,测试和监控的成本问题
- 分布式事务和CAP的相关问题
- 系统应用由原来的单体变成几十到几百个不同的工程,会所产生例如包括服务间的依赖,服务如何拆封,内部接口规范,数据传递等等问题,尤其是服务拆分,需要团队熟悉业务流程,懂得取舍,要保证拆分的粒度服务既符合“高内聚,低耦合”的基本原则,还要兼顾业务的发展以及公司的愿景,要还要说服团队成员为之努力,并且积极投入,在多方中间取得平衡.
对于分布式系统,部署,测试和监控都需要大量的中间件来支撑,而且中间件本身也要维护,原先单体应用很简单的事务问题,转到分布式环境就变得很复杂,分布式事务是采用简单的重试+补偿机制,还是采用二阶段提交协议等强一致性方法来解决,就要取决对业务场景的熟悉加上反复的权衡了,相同问题还包括对CAP模型的权衡,总之微服务对团队整体的技术栈水平整体要求更高.
其中有一个概念叫上游服务和下游服务。也就是越和用户打交道的为上游服务,和数据库打交道的为下游服务。
3 应用架构变迁图
4 SpringCloud 简介
- SpringCloud是Spring旗下的一个顶级项目.
- SpringCloud是一个服务治理平台,提供了一些服务框架.包含了:服务注册与发现、配置中心、消息中心、负载均衡、数据监控等等.
- SpringCloud是一系列框架的有序集合.它利用SpringBoot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用SpringBoot的开发风格做到一键启动和部署.
- SpringCloud并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过SpringBoot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包.
- SpringCloud是一个微服务框架,相比RPC/SOA框架而言,SpringCloud提供的全套的分布式系统解决方案.
- SpringCloud对Netflix的多个微服务基础框架开源组件进行了封装,同时又实现了和云端平台以及和SpringBoot开发框架的集成.
- SpringCloud为微服务架构开发涉及的配置管理,服务治理,熔断机制,智能路由,微代理,控制总线,一次性token,全局一致性锁,leader选举,分布式session,集群状态管理等操作提供了一种简单的开发方式.
- SpringCloud为开发者提供了快速构建分布式系统的工具,开发者可以快速的启动服务或构建应用、同时能够快速和云平台资源进行对接
5 Netflix简介
Netflix(Nasdaq NFLX)成立于1997年,是一家在线影片租赁提供商,主要提供Netflix超大数量的DVD并免费递送,总部位于美国加利福尼亚州洛斯盖图.
Netflix经过几年的开源实践,推出最新开源改革计划,打造了全新的Netflix开源门户,并且会继续开源更多好项目,增加Netflix项目开源透明度.
互联网流媒体播放商Netflix在几年前就开始创建自己的开源门户Netflix OpenSource(别名NetflixOSS,http://netflix.github.io/)了,他们并不知道这会如何发展;也不知道开源贡献者是否会使用,改进或者是忽略;更没想到的是就这样拥有了公司的社区,开发者会给予反馈,一些中间供应商会把这些开源软件集成到他们的解决方案中.
到了今天,Netflix拥有上百个开源软件,从基础设施平台到大数据工具,再到自动化部署软件.随着时间的发展,OSS网站也由于越来越多的组件而变得越来越复杂.现在,Netflix还会继续开源更多的软件.
Netflix发布在Github中的项目库地址:https://github.com/netflix
6 Spring Cloud框架结构
7 SpringCloud和Dubbo的对比
Spring Cloud和Dubbo都是微服务开发框架.不是新的技术就一定是好的技术.
Dubbo优势在于开发简单,效率高.
Spring Cloud优势在于功能全面且可靠性高.
对比内容 | Dubbo | SpringCloud |
出身 | 阿里系核心框架是服务化治理 | Spring社区核心框架是Netflix开源微服务架构体 |
文档 | 集中,健全,中文 | 较多,内容大部分是英本版 |
性能 | Dubbo的性能大约是Spring Cloud的2~3倍 |
功能 | Dubbo | SpringCloud |
服务注册中心 | zookeeper | Spring Cloud Netflix Eureka |
服务调用方式 | RPC | REST API |
服务网关 | 无 | Spring Cloud Netflix Zuul |
断路由 | 集群容错 | Spring Cloud Netflix Hystrix |
分布式配置 | 无 | Spring Cloud Config |
服务跟踪 | 无monitor | Spring Cloud Sleuth |
消息总线 | 无 | Spring Cloud Bus |
数据流 | 无 | Spring Cloud Stream |
批量任务 | 无 | Spring Cloud Task |
分析:
由于Spring Cloud与Dubbo天生使用的协议层面不一样,前者是HTTP,后者是TCP(使用的是Netty NIO框架,序列化使用的阿里定制版Hessian2),导致两个框架的性能差距略大。基本上是三比一的差距!Dubbo官方TPS是1W左右,这和我们的测试最高值是接近的。在之前我们还进行过一次测试,那次测试是真实的项目测试,包含了对数据库的访问,最后二者的结果相差并不是很大。由此也得出,框架的性能可能对一个真实的请求(Request)影响并不是很大,或者说并不起决定性作用,也许真正影响性能的是你的业务代码,比如数据库访问以及IO,当然了,框架的性能在一些对性能要求敏感的应用来说也是要考虑的。
另外根据Dubbo官方说法,Dubbo在小数据量的情况下表现卓越,这和我们的测试也是吻合的,在50个属性的pojo对象下,Dubbo性能确实下降了。
另外Spring Cloud默认的feigh client是使用jdk的urlconnection来做HTTP的请求,考虑这种做法的性能问题,我们尝试接入了httpclient包来测试,结果发现httpclient更慢,最后我们引入了开源的okhttp包,综合发现,okhttp和Spring Cloud的feign client结合是性能最高的。
还有就是我们之前也测试过用RestTemplate进行测试,性能要比用Feigh还要好一些。大概能提升百分之十到十五。
虽然Spring Cloud在性能上与Dubbo有天生的劣势,但考虑到Spring Cloud作为一套专门的微服务框架,再加上RESTful风格的API的趋势,从综合的角度,Spring Cloud无疑是你所在的公司未来微服务化进程中不可缺少的选择之一!
以上测试仅供参考!
8 Spring Cloud版本号说明
8.1 常见版本号说明
开发中,使用的框架版本,最好是RELEASE版本或Final版本.常见版本号格式为:
x.y.z.stage
x-数字格式主版本号,当功能模块有较大更新或者整体架构发生变化时,主版本号会更新.
y-数字格式次版本号,次版本表示只是局部的一些变动.
z-数字格式修正版本号,一般是bug的修复或者是小的变动.
stage-希腊字母版本号,也称为阶段版本号.用于标注当前版本的软件处于哪个开发阶段.(常用的阶段版本包括:BASE、ALPHA、BATE、RELEASE/FINAL.)
BASE-设计阶段.只有相应的设计没有具体的功能实现.
ALPHA-软件的初级版本.存在较多的bug.
BATE-表示相对ALPHA有了很大的进步,消除了严重的bug,还存在一些潜在的bug.
RELEASE/FINAL-该版本表示最终版,即正式发布版本.
2 Spring Cloud 版本号说明
Spring Cloud是一个包含若干子框架的框架集合体,是一个完整的微服务框架体系,如果使用场景版本号来进行标记,容易混淆主框架版本和子框架版本标记.所以SpringCloud使用一种全新的版本号来对主框架进行版本标记,而子框架的版本标记大多还是使用常用版本号标记的.
Spring Cloud版本格式如:
版本号命名.stage
版本号命名:Spring Cloud主框架版本号是使用英国伦敦地铁站名称来进行标记的,并根据地铁站名称的首字母的英文自然升序排列来识别版本的递增.
如:Angle、Brixton、Camden、Dalston、Edgware、Finchley等.后续版本提升会继续根据首字母升序排列.
stage:阶段版本号.常用的阶段版本包括:BUILD-XXX[SNAPSHOT]、GA、PRE(M1、M2等)、RC、SR.
BUILD-XXX[SNAPSHOT]-开发版本、一般是开发团队内部使用.
GA-稳定版,内部开发到一定阶段了,各个模块集成后,经过全面测试发现没有问题,可对外发行了.这个时候叫GA(General Availability).基本上可以使用了.没有严重的BUG问题,但是有未测出的BUG隐患.不推荐商业使用.
PRE-里程碑版,由于GA还不属于公开发行版,里面还有些功能不完善或者bug,
于是就有了milestone(里程碑版).milestone版主要修复了一些bug.一个GA后,一般会有多个里程本版.例如M1 M2 M3…不推荐商业使用.
RC-候选发布版,从BUILD后到GA在到M基本上系统就算定型了,这个时候系统就进入Release Candidate(候选发布版).该阶段的软件类似于最终发行前的一个观察期,该期间只对一些发现的等级高的bug进行修复.发布RC1 RC2等版本.可以考虑RC版本.
SR-正式发布版,公开正式发布.正式发布版一般也有多个发布,例如SR1 SR2 SR3等等,一般是用来修复大bug或者优化.最好使用SR版本.