开发者学堂课程干货总结——Spring Cloud微服务架构设计与开发实战(七)

本文涉及的产品
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: Spring Cloud微服务架构设计与开发实战课时1.7—微服务架构的经典开发框架 。Java Spring Cloud是全球范围内最成熟、最完善、最流行的微服务架构方案体系。被众多的互联网大公司采用,包括阿里巴巴、腾讯、支付宝、网易、IBM、谷歌、京东、百度、滴滴等。电子书+视频为同学带来最佳学习效果,文字、课程链接、图谱地址统统为大家放送了哦!

哈喽各位同学们大家好呀,小编今天带着开发者学院中课程微服务架构的经典开发框架”干货总结来了~一起学习新课程吧!

课程链接以及图谱地址小编已经为大家指路了,搭配学习效果更佳👇

课程名称:微服务架构的经典开发框架

课程地址:https://developer.aliyun.com/learning/course/60/detail/1110

图谱名称:Alibaba Java 技术图谱

图谱地址:https://developer.aliyun.com/graph/java


微服务架构的经典开发框架


各位同学大家好,我们继续来学习微服务架构设计课程,咱们今这一节课来讲一下微服务架构,经典的开发框架,咱们这个系列课程是以Java Spring Cloud的为主导的重点的开发框架,目前微服务生态经过5年以上的这种发展历程,其中也出现了其他语言,包括Java本身Spring Cloud也在不断迭代,也出现新的贡献微服务架构的框架。 

Spring Cloud是出现的时间比较早框架,并且它的生态也是最完善的,咱们选择了Spring Cloud作为目前我们课程的主要的实践案例的练习的框架。 

下面一起来看下微服务架构有哪些经典的开发框架,以及他们有什么差异,做实际的项目选择的时,大家应该怎么来进行选择。如果技术选型的话,可能直接会影响后面一个架构的落地,因为有些架构并非完善,需要话很大精力去处理相同的问题。 

 

  1. 微服务架构的开发框架 

1. Spring Cloud:最早最成熟,Java开源微服务框架方案 

2. Dubbo : 阿里巴巴开源Java服务治理框架 

3. Spring Cloud Alibaba 阿里开源Java微服务框架方案 

4. SOFA:蚂蚁金服开源Java金融微服务框架方案 

5. Go MicroGo语言开源微服务框架 

6. Seneca Microservices Node.js微服务框架 

7. KumuluzEEJava的微服务框架 

8. Enduro/X C/C++/Go 

image.png 

目前Spring Cloud是最早的开源的版本,主要几个核心框架是谁贡献的呢?是叫麦飞美国的视频网站公司,他们把自己公司内部实践的开发的微服务的解决方案框架贡献给了社区。它主要也是想体现云计算的这样的时代的特征,这个核心框架基本上都是用 Java来进行编写的,而且也现经过这么多年的发展,目前在全球范围内来看的,它是最成熟的一套生态。像国内的阿里巴巴、蚂蚁金服、京东、微博、拼多多、美团等新崛起的互联网公司都在使用 Spring Cloud微服务框架体系。 

像淘宝、阿里的发展实际代表、Java或者来讲分布式架构,不断发展历程。淘宝做双十一在商业上非常成功运营模式,但是它在另外一个技术层次来说是倒逼着阿里的技术团队去不断的迎接各种技术挑战,并解决这些问题。 

除了Dubbo以外,内部还有hsf框架,早期是解决大规模服务治理的问题,后面进行在内部不断优化协议、性能。Dubbo在开源以后,国内有很多互联网公司都在用,影响也比较大。作为微服务架构设计的选型的话,Dubbo不会作为首选,但是Dubbo是一个有效的补充。它的优点:经过阿里巴巴集团大规模验证、在不断的迭代、支持高频发,成为响应式框响应式框架、Java在不断的升级演化,Dubbo也不例外,协议支持的更多。 

 

并不是所有的场景,用HTTP协议是最优秀的,后续Spring Cloud的版本或者其他的微服务框架,会在协议,通讯协议,数据格式类型尝试做一些优化,因为阿里打包开源一些列的微服务给Spring Cloud作为贡献的一部分。外国就是麦飞,国内就是阿里巴巴作为最大的贡献者。像蚂蚁金服的SOFAGO语言的Go Micro都是仿制Spring Cloud。生态都不是很完善,没办法和Spring Cloud一样的流行,成熟。Java并不是强在语法,开发工具都不是最好的,强在框架和生态,升级模式。新的设计模式的书都是率先在Java实践出来的。 

 

  1. 微服务开发框架对比 

image.png 

服务框架本身也有存在各种差异,Spring Cloud是出现最早的,最成熟最完善的一套微服务架构综合解决方案。它协议上HTTP为主,国内外公司大部分都在使用。阿里的Dubbo也开源了,并向微服务进发,开始也支持其他的框架的集成。虽然Go语言和C++都有微服务框架,但是出现的比较晚,生态并不是太完善。作为微服务架构师来说,Spring CloudDubbo体系最完善。 

 

  1. Spring Cloud微服务架构生态最完善、最成熟 

image.png 

 

另外Spring Cloud本身成长于Java Spring整个平台体系中来,之前Java Spring积累的所有生态工具都可以拿过使用。可快速开发、集成、安全设计模块工具、容器的工具可直接使用。加上国内互联网公带头扩展实践落地。Spring Cloud是架构选型风险成本最低的。如需单独开发新的框架或者新的协议,费时费力。所有的技术发展一定是和公司的业务发展紧密结合,工程师本身是帮别人去开发系统解决问题的。做架构师的话选型一定要选成熟的、完善的、风险最小的、资料多的,遇到问题的时候更容易解决问题 

 

image.png 

Java Spring开发平台 

Spring BootSpring Data 都在协助Spring Cloud维护开发,拥有一套很大,并完善生态。 

 

  1. Spring Cloud微服务架构 

 

image.png 

 

框架它是在不断迭代不断发展的,微服务开发的话不仅仅是 Spring VC或者Spring Boot,还有各种工具 ,也可以来开发这种微服务,实现各种需求:网关、熔断、注射、包括数据库交互、前端对应APP、小程序。微服务拆分好处在于走小块零的路线,也可以单独进行部署。比如:有的系统订单服务支付服务用的比较多,比如淘宝单独做大规模集群,客服投诉服务使用就比较少,拆分之后占用的服务器少。拆分的原因取决业务需求,存在差异之后,可以分开处理问题。 

image.png 

每个环节解决不同的问题,无论是注册、发现、部署、网关都有自己的对应解决方案框架。 

目前的话就是选型的话,首推是Spring Cloud,因为是一个成熟完善的生态。在技术选型的时候还要尊重业务需求、技术落地、风险问题、考虑公司研发成本等综合考虑,单单是自己语言的喜好的问题。 

 

image.png 

 

目前来讲,这里面给大家介绍了系统各个不同语言的微服务开发方向,但是目前Spring Cloud还是最成熟最完善的。下节课的话咱们也看看微服务架构里面经典的设计模式,包括我们整个的拆分的微服的一些原则 

相关文章
|
4天前
|
存储 JavaScript 开发工具
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
本次的.HarmonyOS Next ,ArkTS语言,HarmonyOS的元服务和DevEco Studio 开发工具,为开发者提供了构建现代化、轻量化、高性能应用的便捷方式。这些技术和工具将帮助开发者更好地适应未来的智能设备和服务提供方式。
基于HarmonyOS 5.0(NEXT)与SpringCloud架构的跨平台应用开发与服务集成研究【实战】
|
15天前
|
弹性计算 Java 数据库
Web应用上云经典架构实战
本课程详细介绍了Web应用上云的经典架构实战,涵盖前期准备、配置ALB、创建服务器组和监听、验证ECS公网能力、环境配置(JDK、Maven、Node、Git)、下载并运行若依框架、操作第二台ECS以及验证高可用性。通过具体步骤和命令,帮助学员快速掌握云上部署的全流程。
|
2月前
|
消息中间件 Java Kafka
实时数仓Kappa架构:从入门到实战
【11月更文挑战第24天】随着大数据技术的不断发展,企业对实时数据处理和分析的需求日益增长。实时数仓(Real-Time Data Warehouse, RTDW)应运而生,其中Kappa架构作为一种简化的数据处理架构,通过统一的流处理框架,解决了传统Lambda架构中批处理和实时处理的复杂性。本文将深入探讨Kappa架构的历史背景、业务场景、功能点、优缺点、解决的问题以及底层原理,并详细介绍如何使用Java语言快速搭建一套实时数仓。
200 4
|
2月前
|
运维 NoSQL Java
后端架构演进:微服务架构的优缺点与实战案例分析
【10月更文挑战第28天】本文探讨了微服务架构与单体架构的优缺点,并通过实战案例分析了微服务架构在实际应用中的表现。微服务架构具有高内聚、低耦合、独立部署等优势,但也面临分布式系统的复杂性和较高的运维成本。通过某电商平台的实际案例,展示了微服务架构在提升系统性能和团队协作效率方面的显著效果,同时也指出了其带来的挑战。
87 4
|
3月前
|
存储 前端开发 API
DDD领域驱动设计实战-分层架构
DDD分层架构通过明确各层职责及交互规则,有效降低了层间依赖。其基本原则是每层仅与下方层耦合,分为严格和松散两种形式。架构演进包括传统四层架构与改良版四层架构,后者采用依赖反转设计原则优化基础设施层位置。各层职责分明:用户接口层处理显示与请求;应用层负责服务编排与组合;领域层实现业务逻辑;基础层提供技术基础服务。通过合理设计聚合与依赖关系,DDD支持微服务架构灵活演进,提升系统适应性和可维护性。
|
4月前
|
运维 持续交付 API
深入理解并实践微服务架构:从理论到实战
深入理解并实践微服务架构:从理论到实战
159 3
|
4月前
|
存储 缓存 负载均衡
亿级流量架构理论+秒杀实战系列(二)
亿级流量架构理论+秒杀实战系列(二)
|
4月前
|
运维 监控 持续交付
深入浅出:微服务架构的设计与实战
微服务,一个在软件开发领域如雷贯耳的名词,它代表着一种现代软件架构的风格。本文将通过浅显易懂的语言,带领读者从零开始了解微服务的概念、设计原则及其在实际项目中的运用。我们将一起探讨如何将一个庞大的单体应用拆分为灵活、独立、可扩展的微服务,并分享一些实践中的经验和技巧。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和深入的理解。
91 3
|
4月前
|
SQL 缓存 运维
亿级流量架构理论+秒杀实战系列(一)
亿级流量架构理论+秒杀实战系列(一)
|
4月前
|
消息中间件 应用服务中间件 数据库
亿级流量架构理论+秒杀实战系列(三)
亿级流量架构理论+秒杀实战系列(三)