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

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

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

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

课程名称:什么是微服务架构Microservice

课程地址:https://developer.aliyun.com/learning/course/60/detail/1105?spm=a2c6h.21258778.0.0.72ae43db9RXbsI

图谱名称:Alibaba Java 技术图谱

图谱地址:https://developer.aliyun.com/graph/java?spm=a2c6h.21110250.J_5703890090.6.700e3c67EjOBeJ


什么是微服务架构Microservice



微服务架构目前非常火爆,在架构领域属于当红的明星架构,那么什么是微服务架构? 

image.png 

微服架构是在移动互联网时代崛起的新架构模式现在架构模式一般称为Microservice,本身叫微服务现在的互联网公司,尤其是国内阿里、腾讯、微博、京东、拼多多等,严格来说都是微服务架构。 

回顾历史,这么多年架构的发展最具有代表性是淘宝腾讯,但是腾讯更像QQ微信的架构,后台主要以C++为主,是典型的分布式架构软件直播类、社交类的抖音也是一个典型的微服架构。 

起步较早的淘宝经历过三大阶段,单体到SOA,再到微服务。微服务架构是2000年到2010年之间非常火爆的架构,尤其是一些大型的银行项目。同时,它分布式架构非常重要的阶段,是一个代表性的架构。 

当年无论是IBM,还是各大银行的架构师,在技术峰会上基本上讨论的都是SOA相关的概念。微服架构作为现阶段比较火爆的架构,是在其他的架构基础上演化而来,诞生于分布式SOA的技术架构,淘宝是典型的案例 

淘宝早期是单体的,后面开始往分布式,转Java去Oracle,并开始用Microservice,包括引入其他的分布式解决方案,逐步构造今天的微服务架构。后续诞生的电商公司,大部分都借鉴了淘宝的架构发展历史经验,例如京东在2010年开始转Java,也有类似的微服务框架和解决方案。 

为什么国内大公司都是通过Java语言来进行编写 

本身编程语言没有优劣之分,对于项目的开发人员、工程师、架构师而言,解决问题,帮公司创造价值,在技术选型上满足公司不同阶段不同业务的需求,这是基本出发点。合格的架构师在技术选型时,需要考虑方案落地性,招人成本,组建团队成本以及后续开发过程中对应的解决方案。 

目前来看,微服务架构是Spring Cloud出现最早,参与公司最多,开源社区最活跃最成熟的微服务架构解决方案,并且还在不断的迭代演化。 

基于Java、Mysql、Linux等阿里不断摸索分布式架构的解决方案,并把积累的经典解决方案框架都开源供其他公司借鉴学习 

 

一、什么是微服务架构Microservice 

微服务的定义 

1. 微服务架构模式 

2. Microservice 

3. Dr. Peter Rodgers2005 Cloud Computing Expo技术大会上提出概念 

4. 2007, Netflix开始向微服务架构师进发 

5. 并最终开源了自己研发的Java微服务框架 

6. 开源社区命名为Spring Cloud 

7. 微服务是一种新型的 软件架构风格 

8. 把单个巨型服务应用,分解为多个独立的、微小的服务程序 

9. 单独部署 

10.单独伸缩 

11.去中心化:数据中心、管理中心 

12.敏捷性、灵活性、需求变化,更加高效的软件架构模式 

 

微服务架构生在SOS,最早的时候并不叫微服务架构,而是叫Micro Web Service,指微小的web service程序,使用Java写了一套轻量级的微服务架构的解决方案,是移动互联网时代很重要的一个标志,服务端的接口的应用程序的开始轻量计划。 

目前微服务框架以recipe风格为主的一个很重要的原因,后续无论是去中心化、敏捷开发、单独部署等都是随着程序的微服务化快速开发与部署,逐步诞生了一系列的经典的工具,辅助用户提升业务应用的开发部署模式效率。 

 

微小的服务 

1.微服务架构:将单个应用拆分成多个独立的、微小的服务。 

2.每个小服务程序运行在独立的进程中。 

3.服务与服务之间通过轻量协议通信。 

4.通信机制互相协作、互相配合,从而为终端用户提供业务价值。 

5.每个小服务,可以采用不同的语言、框架、工具 独立开发、测试、部署、运维 

6.微服务:独立的小服务。 

 

Michael Service的简称过来就是微服务,实际指微小的服务程序,之前各个服务程序都在一个项目中,现在拆开方便进行各个功能单独迭代升级。移动互联网中微服务迭代的非常快,无论是淘宝的支付宝,还是微信、微博,其他的APP都是微服务加工。设置手机默认浏览器也是,子功能模块它其实都在单独的进行功能迭代的,尤其是国内定制的浏览器,360浏览器,腾讯浏览器,百度浏览器其实里面在各种功能基本上也都单独进行迭代的。杀毒软件也有各种不同的背后通信数据采集的机制。 

 

Microservices 

In short, the microservice architectural style is an approach to developing a single application as a suite of small services, each running in its own process and communicating with lightweight mechanisms, often an HTTP resource API. 

These services are built around business capabilities and independently deployable by fully automated deployment machinery. There is a bare minimum of centralized management of these services, which may be written in different programming languages and use different data storage technologies. 

 

-- James Lewis and Martin Fowler 

 

image.png 

詹姆斯里维斯            Money Follow              

除了麦飞公司是微服务架构的先驱公司以外,还有几个重要的技术专家他们不断宣传微服务架构,他们工作sort of works软件咨询架构,中国也有分公司。从他们做的架构可以看到,咨询师使用微服务架构,微服务架构已成为时代的潮流。 

 

微服务 

简而言之,微服务架构风格是一种将单个应用程序开发为一套小服务程序的方法,每个小服务都在自己的进程中运行,并使用轻量级协议(通常是HTTP协议)进行通信。 

这些服务围绕业务功能构建,可通过全自动部署机制独立部署。这些服务很少使用中心化管理模式,可以用不同的编程语言开发,也可能使用不同的数据存储技术。 

 

-- James Lewis 与 Martin Fowler 

 

现在看到关于微服务架构的一些书籍或公开文章里面,基本上认为现在微服务架构,通信的接口都是 Recipe,HTTP+Jason格式进行交互。相比传统的 rpc、double、web service重量级的框架来说,有些业务场景需要更高性能的通信协议后续会看到一些新版本的微服务框架在不断迭代和进化。 

 

Wikipedia定义 

1. In computing, microservices is a software architecture style in which complex applications are composed of small, independent processes communicating with each other using language-agnostic APIs.  

2. 在计算机领域中,微服务是一种软件架构风格,复杂的应用程序由语言无关的API、相互通信的小型独立服务进程组成 

3. These services are small building blocks, highly decoupled and focused on doing a small task, facilitating a modular approach to system-building. 

  1. 这些服务是小型构建模块,高度解耦,专注于完成一项小任务,是一种便捷的模块化系统构建方法。 

在协议这个层次上进行了迭代改造,微服务架构并不是只一种架构,它是复杂架构的一个代表,里面涉及到很多种设计模式与框架。 

 

 

二、微服务的发展历史 

1. Dr. Peter Rodgers introduced the term “Micro-Web-Services”during a presentation at the Web Services Edge conference in 2005. On slide #4 

2. In 2007, Netflix started on a long road towards fully operating in thecloud. 

3. A workshop of software architects held near Venice in May 2011used the term “microservice” 。 

4. All of these Netflix libraries and systems were open-sourced around20125. In May 2012, the same group decided on“microservices” as the most appropriate name。 

6. James Lewis presented some of those ideas as a case study in March2012 at 33rd Degree in Kraków in Microservices - Java, the UnixWay, as did Fred George about the same time. 

7. Adrian Cockcroft at Netflix, describing this approach as "fine grained SOA“ 

8. 2014年4月25号,Martin Fowler发表Microservices a definition of this new architectural term 

9. In 2015, Spring Cloud Netflix reached 1.0. 

10.2018年10月31日Spring Cloud Alibaba宣布正式开源,提交给Spring 方孵化器 

 

微服务并非全新的架构,回顾计算机历史发展史,会发现基本上无论算法框架还是理论知识都有一个明显的时间线或者依赖关系。后续出现的框架一定比前面的框架设计的更好,因为它是借鉴或者总结前面经典的设计思想模式,然后进行改进,代表性公司麦飞,内部实践并且把框架全部贡献给社区,做出了很大贡献 

麦飞后续将微服务架构的解决方案全部开源,是Spring Cloud 最早的一批微服务框架,目前社区也在用阿里也把自己的方案打包进行了开源。 

 

微服务架构的发展历史 

1. Dr. Peter Rodgers 在2005年的Web Services Edge conference 大会上演讲,PPT第4页引入了“Micro-Web-Services一词 

2. 2007年,Netflix开始走向全面拆分巨型SOA服务的漫长道路。 

3. 2011年5月在威尼斯附近举办的软件架构师研讨会使用了“微服务”“microservices”一词。 

4. 2012 Netflix 开源了所有的微服务相关工具框架的源码 

5. 2012年5月, 同一个组织宣布“microservices是最恰当的名词 

6. James Lewis 在2012年4月 第33届 Degree in Kraków in Microservices- Java, the Unix Way,大会上案例研究分享时提出了类似的想法, Fred George 也大约在这个时间提出了类似观点. 

7. Netflix公司的Adrian Cockcroft, 称为:“fine grained SOA“ 

8. 2014年4月25号,Martin Fowler发表Microservices a definition of this new architectural term 

9. 2015, Spring Cloud Netflix 正式发布1.0版本. 成为微服务架构的首选 

10.2018年10月31日Spring Cloud Alibaba 宣布正式开源 

 

微服务架构先驱 

image.png 

Money Follow (图右1),写了很多经典的书:企业应用架构模式重构等、敏捷宣言17发起人之一,目前一直活跃软件架构领域。他是在技术大会上公开进行与演讲、推广,为领域做出了很大贡献 

詹姆斯里维斯(上图下方)微服务架构发明人,在work PSL主要负责服务架构宣传与咨询 

阿德里安(左一麦飞的技术总监,将理论和实践结合先驱,基于Java框架做出了一套自研微服务解决方案,并且开源给社区 

相关文章
|
21天前
|
数据可视化 Java BI
将 Spring 微服务与 BI 工具集成:最佳实践
本文探讨了 Spring 微服务与商业智能(BI)工具集成的潜力与实践。随着微服务架构和数据分析需求的增长,Spring Boot 和 Spring Cloud 提供了构建可扩展、弹性服务的框架,而 BI 工具则增强了数据可视化与实时分析能力。文章介绍了 Spring 微服务的核心概念、BI 工具在企业中的作用,并深入分析了两者集成带来的优势,如实时数据处理、个性化报告、数据聚合与安全保障。同时,文中还总结了集成过程中的最佳实践,包括事件驱动架构、集中配置管理、数据安全控制、模块化设计与持续优化策略,旨在帮助企业构建高效、智能的数据驱动系统。
将 Spring 微服务与 BI 工具集成:最佳实践
|
25天前
|
Java 数据库 数据安全/隐私保护
Spring 微服务和多租户:处理多个客户端
本文介绍了如何在 Spring Boot 微服务架构中实现多租户。多租户允许单个应用实例为多个客户提供独立服务,尤其适用于 SaaS 应用。文章探讨了多租户的类型、优势与挑战,并详细说明了如何通过 Spring Boot 的灵活配置实现租户隔离、动态租户管理及数据源路由,同时确保数据安全与系统可扩展性。结合微服务的优势,开发者可以构建高效、可维护的多租户系统。
254 127
|
21天前
|
存储 安全 Java
管理 Spring 微服务中的分布式会话
在微服务架构中,管理分布式会话是确保用户体验一致性和系统可扩展性的关键挑战。本文探讨了在 Spring 框架下实现分布式会话管理的多种方法,包括集中式会话存储和客户端会话存储(如 Cookie),并分析了它们的优缺点。同时,文章还涵盖了与分布式会话相关的安全考虑,如数据加密、令牌验证、安全 Cookie 政策以及服务间身份验证。此外,文中强调了分布式会话在提升系统可扩展性、增强可用性、实现数据一致性及优化资源利用方面的显著优势。通过合理选择会话管理策略,结合 Spring 提供的强大工具,开发人员可以在保证系统鲁棒性的同时,提供无缝的用户体验。
|
21天前
|
消息中间件 Java 数据库
Spring 微服务中的数据一致性:最终一致性与强一致性
本文探讨了在Spring微服务中实现数据一致性的策略,重点分析了最终一致性和强一致性的定义、优缺点及适用场景。结合Spring Boot与Spring Cloud框架,介绍了如何根据业务需求选择合适的一致性模型,并提供了实现建议,帮助开发者在分布式系统中确保数据的可靠性与同步性。
|
2月前
|
监控 Java API
Spring Boot 3.2 结合 Spring Cloud 微服务架构实操指南 现代分布式应用系统构建实战教程
Spring Boot 3.2 + Spring Cloud 2023.0 微服务架构实践摘要 本文基于Spring Boot 3.2.5和Spring Cloud 2023.0.1最新稳定版本,演示现代微服务架构的构建过程。主要内容包括: 技术栈选择:采用Spring Cloud Netflix Eureka 4.1.0作为服务注册中心,Resilience4j 2.1.0替代Hystrix实现熔断机制,配合OpenFeign和Gateway等组件。 核心实操步骤: 搭建Eureka注册中心服务 构建商品
375 3
|
22天前
|
消息中间件 Java Kafka
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
本文深入解析了 Kafka 和 RabbitMQ 两大主流消息队列在 Spring 微服务中的应用与对比。内容涵盖消息队列的基本原理、Kafka 与 RabbitMQ 的核心概念、各自优势及典型用例,并结合 Spring 生态的集成方式,帮助开发者根据实际需求选择合适的消息中间件,提升系统解耦、可扩展性与可靠性。
消息队列比较:Spring 微服务中的 Kafka 与 RabbitMQ
|
22天前
|
Prometheus 监控 Java
日志收集和Spring 微服务监控的最佳实践
在微服务架构中,日志记录与监控对系统稳定性、问题排查和性能优化至关重要。本文介绍了在 Spring 微服务中实现高效日志记录与监控的最佳实践,涵盖日志级别选择、结构化日志、集中记录、服务ID跟踪、上下文信息添加、日志轮转,以及使用 Spring Boot Actuator、Micrometer、Prometheus、Grafana、ELK 堆栈等工具进行监控与可视化。通过这些方法,可提升系统的可观测性与运维效率。
日志收集和Spring 微服务监控的最佳实践
|
15天前
|
监控 安全 Java
Spring Cloud 微服务治理技术详解与实践指南
本文档全面介绍 Spring Cloud 微服务治理框架的核心组件、架构设计和实践应用。作为 Spring 生态系统中构建分布式系统的标准工具箱,Spring Cloud 提供了一套完整的微服务解决方案,涵盖服务发现、配置管理、负载均衡、熔断器等关键功能。本文将深入探讨其核心组件的工作原理、集成方式以及在实际项目中的最佳实践,帮助开发者构建高可用、可扩展的分布式系统。
58 1
|
22天前
|
jenkins Java 持续交付
使用 Jenkins 和 Spring Cloud 自动化微服务部署
随着单体应用逐渐被微服务架构取代,企业对快速发布、可扩展性和高可用性的需求日益增长。Jenkins 作为领先的持续集成与部署工具,结合 Spring Cloud 提供的云原生解决方案,能够有效简化微服务的开发、测试与部署流程。本文介绍了如何通过 Jenkins 实现微服务的自动化构建与部署,并结合 Spring Cloud 的配置管理、服务发现等功能,打造高效、稳定的微服务交付流程。
使用 Jenkins 和 Spring Cloud 自动化微服务部署
|
14天前
|
Java 数据库 数据安全/隐私保护
Spring Boot四层架构深度解析
本文详解Spring Boot四层架构(Controller-Service-DAO-Database)的核心思想与实战应用,涵盖职责划分、代码结构、依赖注入、事务管理及常见问题解决方案,助力构建高内聚、低耦合的企业级应用。
267 0