您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息
免费发信息
三六零分类信息网 > 阳泉分类信息网,免费分类信息发布

中小型互联网公司微服务实践-经验和教训

2022/7/17 22:02:41发布70次查看
上次写了一篇文章叫spring cloud在国内中小型公司能用起来吗?介绍了spring cloud是否能在中小公司使用起来,这篇文章是它的姊妹篇。其实我们在这条路上已经走了一年多,从16年初到现在。在使用spring cloud之前我们对微服务实践是没有太多的体会和经验的。从最初的开源软件云收藏来熟悉spring boot,到项目中的慢慢使用,再到最后全面拥抱spring cloud。这篇文章就给大家介绍一下我们使用spring boot/cloud一年多的经验。
在开始之前我们先介绍一下几个概念,什么是微服务,它的特点是什么?spring boot/cloud都做了那些事情?他们三者之间又有什么联系?
技术背景
什么是微服务
微服务的概念源于2014年3月martin fowler所写的一篇文章“microservices”。
微服务架构是一种架构模式,它提倡将单一应用程序划分成一组小的服务,服务之间互相协调、互相配合,为用户提供最终价值。每个服务运行在其独立的进程中,服务与服务间采用轻量级的通信机制互相沟通(通常是基于http的restful api)。每个服务都围绕着具体业务进行构建,并且能够被独立地部署到生产环境、类生产环境等。另外,应尽量避免统一的、集中式的服务管理机制,对具体的一个服务而言,应根据业务上下文,选择合适的语言、工具对其进行构建。
微服务是一种架构风格,一个大型复杂软件应用由一个或多个微服务组成。系统中的各个微服务可被独立部署,各个微服务之间是松耦合的。每个微服务仅关注于完成一件任务并很好地完成该任务。在所有情况下,每个任务代表着一个小的业务能力。
微服务架构优势
复杂度可控:在将应用分解的同时,规避了原本复杂度无止境的积累。每一个微服务专注于单一功能,并通过定义良好的接口清晰表述服务边界。由于体积小、复杂度低,每个微服务可由一个小规模开发团队完全掌控,易于保持高可维护性和开发效率。
独立部署:由于微服务具备独立的运行进程,所以每个微服务也可以独立部署。当某个微服务发生变更时无需编译、部署整个应用。由微服务组成的应用相当于具备一系列可并行的发布流程,使得发布更加高效,同时降低对生产环境所造成的风险,最终缩短应用交付周期。
技术选型灵活:微服务架构下,技术选型是去中心化的。每个团队可以根据自身服务的需求和行业发展的现状,自由选择最适合的技术栈。由于每个微服务相对简单,故需要对技术栈进行升级时所面临的风险就较低,甚至完全重构一个微服务也是可行的。
容错:当某一组件发生故障时,在单一进程的传统架构下,故障很有可能在进程内扩散,形成应用全局性的不可用。在微服务架构下,故障会被隔离在单个服务中。若设计良好,其他服务可通过重试、平稳退化等机制实现应用层面的容错。
扩展:单块架构应用也可以实现横向扩展,就是将整个应用完整的复制到不同的节点。当应用的不同组件在扩展需求上存在差异时,微服务架构便体现出其灵活性,因为每个服务可以根据实际需求独立进行扩展。
什么是spring boot
spring boot是由pivotal团队提供的全新框架,其设计目的是用来简化新spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。用我的话来理解,就是spring boot其实不是什么新的框架,它默认配置了很多框架的使用方式,就像maven整合了所有的jar包,spring boot整合了所有的框架(不知道这样比喻是否合适)。
spring boot简化了基于spring的应用开发,通过少量的代码就能创建一个独立的、产品级别的spring应用。 spring boot为spring平台及第三方库提供开箱即用的设置,这样你就可以有条不紊地开始。spring boot的核心思想就是约定大于配置,多数spring boot应用只需要很少的spring配置。采用spring boot可以大大的简化你的开发模式,所有你想集成的常用框架,它都有对应的组件支持。
spring cloud都做了哪些事
spring cloud是一系列框架的有序集合。它利用spring boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用spring boot的开发风格做到一键启动和部署。spring并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过spring boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包
以下为spring cloud的核心功能:
分布式/版本化配置
服务注册和发现
路由
服务和服务之间的调用
负载均衡
断路器
分布式消息传递
我们再来看一张图:
通过这张图,我们来了解一下各组件配置使用运行流程:
1、请求统一通过api网关(zuul)来访问内部服务.
2、网关接收到请求后,从注册中心(eureka)获取可用服务
3、由ribbon进行均衡负载后,分发到后端具体实例
4、微服务之间通过feign进行通信处理业务
5、hystrix负责处理服务超时熔断
6、turbine监控服务间的调用和熔断相关指标
spring cloud体系介绍
上图只是spring cloud体系的一部分,spring cloud共集成了19个子项目,里面都包含一个或者多个第三方的组件或者框架!
spring cloud 工具框架
1、spring cloud config 配置中心,利用git集中管理程序的配置。
2、spring cloud netflix 集成众多netflix的开源软件
3、spring cloud bus 消息总线,利用分布式消息将服务和服务实例连接在一起,用于在一个集群中传播状态的变化
4、spring cloud for cloud foundry 利用pivotal cloudfoundry集成你的应用程序
5、spring cloud cloud foundry service broker 为建立管理云托管服务的服务代理提供了一个起点。
6、spring cloud cluster 基于zookeeper, redis, hazelcast, consul实现的领导选举和平民状态模式的抽象和实现。
7、spring cloud consul 基于hashicorp consul实现的服务发现和配置管理。
8、spring cloud security 在zuul代理中为oauth2 rest客户端和认证头转发提供负载均衡
9、spring cloud sleuth springcloud应用的分布式追踪系统,和zipkin,htrace,elk兼容。
10、spring cloud data flow 一个云本地程序和操作模型,组成数据微服务在一个结构化的平台上。
11、spring cloud stream 基于redis,rabbit,kafka实现的消息微服务,简单声明模型用以在spring cloud应用中收发消息。
12、spring cloud stream app starters 基于spring boot为外部系统提供spring的集成
13、spring cloud task 短生命周期的微服务,为springbooot应用简单声明添加功能和非功能特性。
14、spring cloud task app starters
15、spring cloud zookeeper 服务发现和配置管理基于apache zookeeper。
16、spring cloud for amazon web services 快速和亚马逊网络服务集成。
17、spring cloud connectors 便于paas应用在各种平台上连接到后端像数据库和消息经纪服务。
18、spring cloud starters (项目已经终止并且在angel.sr2后的版本和其他项目合并)
19、spring cloud cli 插件用groovy快速的创建spring cloud组件应用。
当然这个数量还在一直增加…
三者之间的关系
微服务是一种架构的理念,提出了微服务的设计原则,从理论为具体的技术落地提供了指导思想。spring boot是一套快速配置脚手架,可以基于spring boot快速开发单个微服务;spring cloud是一个基于spring boot实现的服务治理工具包;spring boot专注于快速、方便集成的单个微服务个体,spring cloud关注全局的服务治理框架。
spring boot/cloud是微服务实践的最佳落地方案。
实战经历
遇到问题,寻找方案
2015年初的时候,因为公司业务的大量发展,我们开始对原有的业务进行拆分,新上的业务线也全部使用独立的项目来开发,项目和项目之间通过http接口进行访问。15年的业务发展非常迅速,项目数量也就相应急剧扩大,到了15底的时候项目达60多个,当项目数达到30几个的时候,其实我们就遇到了问题,经常某个项目因为扩展增加了新的ip地址,我们就需要被动的更新好几个相关的项目。服务越来越多,服务之间的调用关系也越来越复杂,有时候想画一张图来表示项目和项目之间的依赖关系,线条密密麻麻无法看清。网上有一张图可以表达我们的心情。
这个时候我们就想找一种方案,可以将我们这么多分布式的服务给管理起来,到网上进行了技术调研。我们发现有两款开源软件比较适合我们,一个是dubbo,一个是spring cloud。
其实刚开始我们是走了一些弯路的。这两款框架我们当时都不熟悉,当时国内使用spring cloud进行开发的企业非常的少,我在网上也几乎没找到太多应用的案例。但是dubbo当时在国内的使用还是挺普遍的,相关的资料各方面都比较完善。因此在公司扩展新业务线众筹平台的时候,技术选型就先定了dubbo,因为也是全新的业务没有什么负担,这个项目我们大概开发了六个月投产,上线之初也遇到了一些问题,但最终还比较顺利。
在新业务线选型使用dubbo的同时,我们也没有完全放弃spring cloud,我们抽出了一两名开发人员学习spring boot我也参与其中,为了验证spring boot是否可以到达实战的标准,我们在业余的时间使用spring boot开发了一款开源软件云收藏,经过这个项目的实战验证我们对spring boot就有了信心。最重要的是大家体会到使用spring boot的各种便利之后,就再也不想使用传统的方式来进行开发了。
但是还有一个问题,在选择了spring boot进行新业务开发的同时,并没有解决我们上面的那个问题,服务于服务直接调用仍然比较复杂和传统,这时候我们就开始研究spring cloud。因为大家在前期对spring boot有了足够的了解,因此学习sprig cloud就显得顺风顺水了。所以在使用dubbo半年之后,我们又全面开始拥抱spring cloud。
为什么选择使用spring cloud而放弃了dubbo
可能大家会问,为什么选择了使用dubbo之后,而又选择全面使用spring cloud呢?其中有几个原因:
1)从两个公司的背景来谈:dubbo,是阿里巴巴服务化治理的核心框架,并被广泛应用于中国各互联网公司;spring cloud是大名鼎鼎的spring家族的产品。阿里巴巴是一个商业公司,虽然也开源了很多的顶级的项目,但从整体战略上来讲,仍然是服务于自身的业务为主。spring专注于企业级开源框架的研发,不论是在中国还是在世界上使用都非常广泛,开发出通用、开源、稳健的开源框架就是他们的主业。
2)从社区活跃度这个角度来对比,dubbo虽然也是一个非常优秀的服务治理框架,并且在服务治理、灰度发布、流量分发这方面做的比spring cloud还好,除过当当网在基础上增加了rest支持外,已有两年多的时间几乎都没有任何更新了。在使用过程中出现问题,提交到github的issue也少有回复。
相反spring cloud自从发展到现在,仍然在不断的高速发展,从github上提交代码的频度和发布版本的时间间隔就可以看出,现在spring cloud即将发布2.0版本,到了后期会更加完善和稳定。
3) 从整个大的平台架构来讲,dubbo框架只是专注于服务之间的治理,如果我们需要使用配置中心、分布式跟踪这些内容都需要自己去集成,这样无形中使用dubbo的难度就会增加。spring cloud几乎考虑了服务治理的方方面面,更有spring boot这个大将的支持,开发起来非常的便利和简单。
4)从技术发展的角度来讲,dubbo刚出来的那会技术理念还是非常先进,解决了各大互联网公司服务治理的问题,中国的各中小公司也从中受益不少。经过了这么多年的发展,互联网行业也是涌现了更多先进的技术和理念,dubbo一直停滞不前,自然有些掉队,有时候我个人也会感到有点可惜,如果dubbo一直沿着当初的那个路线发展,并且延伸到周边,今天可能又是另一番景象了。
spring 推出spring boot/cloud也是因为自身的很多原因。spring最初推崇的轻量级框架,随着不断的发展也越来越庞大,随着集成项目越来越多,配置文件也越来越混乱,慢慢的背离最初的理念。随着这么多年的发展,微服务、分布式链路跟踪等更多新的技术理念的出现,spring急需一款框架来改善以前的开发模式,因此才会出现spring boot/cloud项目,我们现在访问spring官网,会发现spring boot和spring cloud已经放到首页最重点突出的三个项目中的前两个,可见spring对这两个框架的重视程度。
总结一下,dubbo曾经确实很牛逼,但是spring cloud是站在近些年技术发展之上进行开发,因此更具技术代表性。
如何进行微服务架构演进
当我们将所有的新业务都使用spring cloud这套架构之后,就会出现这样一个现象,公司的系统被分成了两部分,一部分是传统架构的项目,一部分是微服务架构的项目,如何让这两套配合起来使用就成为了关键,这时候spring cloud里面的一个关键组件解决了我们的问题,就是zuul。在spring cloud架构体系内的所有微服务都通过zuul来对外提供统一的访问入口,所有需要和微服务架构内部服务进行通讯的请求都走统一网关。如下图:
从上图可以看出我们对服务进行了分类,有四种:基础服务、业务服务、组合服务、前置服务�...
阳泉分类信息网,免费分类信息发布

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录