持续演进的Cloud Native (读书笔记02)

简介: 微服务架构并不是什么技术创新,而是开发过程发展到一定阶段对技术架构的要求,是在实践中不断摸索而来的。

微服务架构的起源


     可以说微服务架构并不是什么技术创新,而是开发过程发展到一定阶段对技术架构的要求,是在实践中不断摸索而来的。


为什么采用微服务架构


单体架构与微服务架构对比

4.jpg


5.jpg


什么时候开始微服务架构


单体、组件化、微服务架构成本趋势


6.jpg


如何决定微服务架构的拆分粒度


微服务架构中的微字,并不代表足够小,应该解释为合适


微服务拆分粒度决策参考表


7.jpg


微服务设计原则


  • 垂直划分优先原则


下图简单描述了一个按业务领域垂直划分的微服务架构示例,在业务垂直方向切分服务,通过API Gateway聚合内容。


8.jpg


  • 持续演进原则
    应逐步划分、持续演进,避免服务数量的爆炸性增长。
  • 服务自治、接口隔离原则
    服务通过标准的接口隔离,隐藏内部实现细节
  • 自动化驱动原则


微服务架构实施的先决条件


  • 研发环境和流程上的转变
  • 自动化工具链
  • 微服务框架
  • 快速申请资源
  • 故障发现反馈机制
  • 研发流程上的转变
  • 拆分前先做好解耦
  •   状态外置
  • 无状态(Statelessness)指的是服务内部变量值的存储。有状态的服务伸缩起来非常复杂,可以通过将服务的状态外置到数据库、分布式缓存中,使服务变成无状态
  • 无状态不代表状态消失,只是把状态转移到分布式缓存和数据库中了
  • 并不是所有的业务服务都能设计成无状态,例如客户端与服务端的长连接,这种状态很难外置。
  • 以下三种常见的状态需要和业务服务拆分开来,否则扩展性将受到很大限制。定时任务  本地存储   本地缓存
  •    去触发器、存储过程
  • 解决方案通常是通过外部的业务服务或者定时任务替换触发器及存储过程。
  •    通过接口隔离
  • 如果存在多个系统共享一个数据库,就会导致耦合,影响可用性和扩展性。


微服务划分模式


  • 基于业务复杂度选择服务划分方法
    当业务复杂度足够高的时候,应该基于领域驱动划分服务,而领域驱动本身足够复杂,很多概念比较抽象,应用范围并不是特别广泛,所以当业务复杂度较低时,可以选择基于数据驱动划分服务。数据驱动更容易理解和上手。也就是说,除非业务复杂度非常高,否则应该优先以数据驱动划分服务。


9.jpg


  • 基于数据驱动划分服务
    数据驱动是一个自下而上的架构设计方法,数据驱动强调的是数据结构,也就是通过分析需求,确定整体数据结构,根据表之间的关系划分服务
  • 基于领域驱动划分服务
    领域驱动是一个自上而下的架构设计方法,通过和领域专家建立统一的语言,不断交流,确定关键业务场景,逐步确定边界上下文。
  • 从已有单体架构中逐步划分服务
  • 微服务拆分策略
  • 比较独立的新业务优先采用微服务架构。
  • 优先抽象通用服务。
  • 优先抽象比较容易识别的、边界比较明显的服务。
  • 优先抽象核心服务。
  • 优先抽象具有独立属性的服务
  • 采用绞杀者模式,在遗留系统外围,随着时间的推移,让新的服务逐渐“绞杀”老的系统。
  • 如何衡量服务划分的合理性
  • 一个小功能的修改从需求到上线需要多长时间?正常情况下的微服务架构交付周期应该是以天为单位的。
  • 大多数功能修改是否可以在一个服务内完成?
  • 是否要频繁修改接口?
  • 响应时间是否能满足要求?
  • 是否存在大量的跨服务更新?


微服务划分反模式


  • 根据代码行数划分服务
  • 划分粒度越小越好
  • 一次性划分服务
  • 服务划分一旦完成,不能改变
  • 先实施组件化,再实施微服务架构



微服务API设计


  • 优秀API的设计原则
  • 简单
  • 易懂
  • 一致
  • 稳定
  • 安全
  •  服务间通信——RPC

           影响RPC性能的因素

  • 序列化
  • 传输协议
  • 连接
  • IO模型
  • 服务间通信——RESTful
      API如何设计才能满足RESTful的要求呢?
  • 协议
  • 域名
  • 版本
  • 路径
  • 方法
  • 参数
  • 编码
  • HTTP协议的进化---HTTP/2
  • 在HTTP/1.x的协议中,浏览器在同一时间对同一域名下的请求数量是有限制的,这会导致大量并发请求阻塞,这个问题也被称为线端阻塞(head-of-lineblocking)。如表所示。HTTP/1.1对不同浏览器连接数的限制不同,很多互联网公司为了解决这个问题,做了大量优化,包括建立多域名,通过CDN缓存大量静态资源等。


10.jpg


  • HTTP/2是基于二进制协议的
  • HTTP/2的多路复用机制(Multiplexing)


11.jpg


  • HTTP/2完全兼容HTTP/1.1的语义
  • HTTP/2引入服务端推送模式,即服务端向客户端发送数据


  • HTTP/2和Protobuf的组合——gRPC
  • HTTP/2支持流(streaming),在批量发送数据的场景下使用流可以显著提升性能——服务端和客户端在接收数据的时候,可以不必等所有的消息全收到后才开始响应,而是在接收到第一条消息的时候就可以及时响应
  • gRPC默认使用Protobuf进行序列化和反序列化
  • gRPC默认采用HTTP/2进行传输
  • gRPC 的流可以分为三类:客户端流式发送、服务器流式返回,以及客户端/服务器同时流式处理,也就是单向流和双向流
  • HTTP/2相比于基于TCP的通信协议,性能上也有显著的差距。


微服务框架

  • 微服务框架有很多,综合起来看需要实现如下几个重要的功能。
  • 需要微服务框架能够设定最大容量,采用洪峰策略,隔离关键服务,控制版本,对服务分级,优雅降级。
  • 服务治理
  • 容量规划
  • 高效通信
  • 负载均衡
  • 基于Dubbo框架实现微服务


12.jpg

  • 基于Spring Cloud框架实现微服务
  • 微服务部署策略
  • 服务独享数据库
  • 服务独享虚拟机/容器

相关文章
|
XML 前端开发 Cloud Native
Spring Framework 5.3.0正式发布,在云原生路上继续发力(下)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(下)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(下)
|
2月前
|
Kubernetes Cloud Native Ubuntu
庆祝 .NET 9 正式版发布与 Dapr 从 CNCF 毕业:构建高效云原生应用的最佳实践
2024年11月13日,.NET 9 正式版发布,Dapr 从 CNCF 毕业,标志着云原生技术的成熟。本文介绍如何使用 .NET 9 Aspire、Dapr 1.14.4、Kubernetes 1.31.0/Containerd 1.7.14、Ubuntu Server 24.04 LTS 和 Podman 5.3.0-rc3 构建高效、可靠的云原生应用。涵盖环境准备、应用开发、Dapr 集成、容器化和 Kubernetes 部署等内容。
73 5
|
4月前
|
Kubernetes Cloud Native Java
探索未来编程新纪元:Quarkus带你秒建高性能Kubernetes原生Java应用,云原生时代的技术狂欢!
Quarkus 是专为 Kubernetes 设计的全栈云原生 Java 框架,凭借其轻量级、快速启动及高效执行特性,在 Java 社区脱颖而出。通过编译时优化与原生镜像支持,Quarkus 提升了应用性能,同时保持了 Java 的熟悉度与灵活性。本文将指导你从创建项目、编写 REST 控制器到构建与部署 Kubernetes 原生镜像的全过程,让你快速上手 Quarkus,体验高效开发与部署的乐趣。
63 0
|
存储 关系型数据库 数据库
分布式系统开发实战:CloudNative架构,Cloud Native成功案例分析
有非常多的公司在使用Cloud Native,这些公司包括国外知名企业如Amazon、Netflix等,也包括国内的知名企业淘宝。本节介绍这些企业如何从小企业转变成为Cloud Native的实践者?
|
消息中间件 运维 监控
太香了!Alibaba内部架构师进阶指南,理论+实践双飞
很多技术大会上的分享大多“高大上” 亿级流量、 超大型研发团队,虽然值得借鉴,但由于应用场景与研发资源的差异 般企业并不容易落地。其实 ,中小型研发团队在IT还是占大多数 他们在技术架构方面的问题较多 技术阻碍业务、跟不上业务发展的情况很常见。
|
消息中间件 Cloud Native Java
【深入浅出SpringCloud原理及实战】「SpringCloud-Alibaba系列」微服务模式搭建系统基础架构实战指南及版本规划踩坑分析
【深入浅出SpringCloud原理及实战】「SpringCloud-Alibaba系列」微服务模式搭建系统基础架构实战指南及版本规划踩坑分析
724 1
【深入浅出SpringCloud原理及实战】「SpringCloud-Alibaba系列」微服务模式搭建系统基础架构实战指南及版本规划踩坑分析
|
消息中间件 缓存 算法
持续演进的Cloud Native (读书笔记03)
可靠性公式:A=MTBF /(MTBF+MTTR)。其中,MTBF的全称是Mean Time Between Failure,即平均无故障工作时间,指上一次故障恢复后开始正常运行到这次故障的时间平均值。MTTR的全称是Mean Time ToRepair,即平均故障修复时间,是指从出现故障到完全恢复的这段时间。
持续演进的Cloud Native (读书笔记03)
|
运维 监控 UED
持续演进的Cloud Native (读书笔记01)
观察任何一个企业都可以从三个角度出发,这三个角度分别是技术、流程、文化,三个方面都做好才能成为伟大的企业。Cloud Native也一样,需要从架构、研发流程、团队文化三个角度来实现,三者需要相互配合,缺一不可。
持续演进的Cloud Native (读书笔记01)
|
Cloud Native Java API
Spring Framework 5.3.0正式发布,在云原生路上继续发力(上)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(上)
Spring Framework 5.3.0正式发布,在云原生路上继续发力(上)