读发布!设计与部署稳定的分布式系统(第2版)笔记31_版本问题

news2025/1/10 11:26:17

 

1. 在软件与外部环境之间的许多交汇点上,版本控制基本上处于混乱状态

1.1. 不应该为了更新自身系统的API,而让服务消费者被迫与你同时发布新版本

1.2. 多数服务新版本的发布应该具有兼容性

2. 分层的“约定”栈

2.1. 连接握手和持续时间

2.2. 请求组帧

2.3. 内容编码

2.4. 消息语法

2.5. 消息语义

2.6. 鉴权和身份验证

3. 对请求要协变

3.1. covariant request

4. 对响应要逆变

4.1. contravariant response

5. 即

5.1. 可以比以往提出的要求更少

5.2. 可以比以往接受的可选信息更多

5.3. 可以比以往返回的响应更多

5.4. 可以类比必填参数和可选参数

6. 安全的变更

6.1. 在参数上强制执行以前所需约束的子集

6.2. 返回以前可返回值的超集

6.3. 接受以前可以接受的参数的超集

6.4. 要求必须填写以前必填参数的一个子集

7. 生成式测试技术

8. 破坏API的变更

8.1. 减少API破坏性变更影响的第一个先决条件是在请求和回复消息格式中添加一个版本号字段

8.2. 为URL添加版本辨别字段,可以用前缀形式或查询参数来实现

8.2.1. 同一实体的不同表示看起来像是不同的资源,而这在REST世界中是禁忌

8.3. 使用PUT和POST上的Content-Type标头指示正在发送的版本

8.3.1. 可以为版本定义一个媒体类型application/vnd.lendzit.loan-request.v1和一个新的媒体类型application/vnd.lendzit.loan-request.v2

8.3.2. 优点

8.3.2.1. 在数据库中存储的所有URL都可以继续工作,客户端无须更改路由就可升级

8.3.3. 缺点

8.3.3.1. 单单凭借URL已经不够区分版本了,像application/json和text/xml这样的通用媒体类型根本提供不了任何帮助

8.3.3.2. 客户端必须事先知道存在这种特殊的媒体类型,以及所有允许的媒体类型

8.3.3.3. 一些框架虽然支持基于媒体类型的路由,但配置起来会有难度

8.4. 仅针对PUT和POST,在请求正文中添加一个字段来指示预期版本

8.4.1. 优点是不需要路由,易于实施

8.4.2. 缺点是无法涵盖所需要的所有场景

8.5. 使用特定于应用程序的自定义标头指示所需的版本

8.5.1. 可以定义一个类似api-version的标头

8.5.2. 优点是具有完全的灵活性,并且与媒体类型和URL正交

8.5.3. 缺点

8.5.3.1. 要为特定框架编写路由处理器

8.5.3.2. 这个标头是另一个必须与服务消费者分享的秘密

8.6. 服务提供方都必须在一段时间内同时支持旧版本和新版本

8.7. 如果要在一些URL中添加版本信息,那么务必同时在所有路由中都添加这个版本

8.7.1. 即使这次变更只涉及一个路由,也不要强制用户记住哪些版本号对应哪些API

8.8. 只要不影响未来进行的变更,尽可能地减少代码重复

9. 处理其他系统的版本问题

9.1. 软件应该保持杞人忧天的状态

9.2. 虽然请求规范中添加了一些新字段,但并不意味着所有人都会遵守新规范

9.3. 请求端与响应端检查自己是否符合规范

9.4. 将测试分为不同的部分,有助于隔离通信中的故障,并能使代码更加稳健

9.4.1. 我们不会再对另一方的行为做出不合理的假设

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/874406.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

华为在ospf area 0单区域的情况下结合pbr对数据包的来回路径进行控制

配置思路: 两边去的包在R1上用mqc进行下一跳重定向 两边回程包在R4上用mqc进行下一跳重定向 最终让内网 192.168.10.0出去的数据包来回全走上面R-1-2-4 192.168.20.0出去的数据包来回全走 下面R1-3-4 R2和R3就是简单ospf配置和宣告,其它没有配置&#…

Python爬虫(十一)_案例:使用正则表达式的爬虫

本章将结合先前所学的爬虫和正则表达式知识,做一个简单的爬虫案例,更多内容请参考:Python学习指南 现在拥有了正则表达式这把神兵利器,我们就可以进行对爬取到的全部网页源代码进行筛选了。 下面我们一起尝试一下爬取内涵段子网站&#xff1…

《C语言深度解剖》.pdf

🐇 🔥博客主页: 云曦 📋系列专栏:深入理解C语言 💨吾生也有涯,而知也无涯 💛 感谢大家👍点赞 😋关注📝评论 C语言深度解剖.pdf 提取码:yunx

使用cloud-int部署nginx

参考 azure创建虚拟机,创建虚拟机注意入站端口规则开放80端口,高级中使用自定义数据,初始化虚拟机,安装nginx 连接CLI,验证是否安装成功 访问虚拟机IP查看是否部署成功 参考文档: https://learn.microsoft.com/zh-cn…

代码随想录算法训练营之JAVA|第二十八天|122. 买卖股票的最佳时机 II

今天是第28天刷leetcode,立个flag,打卡60天。 算法挑战链接 122. 买卖股票的最佳时机 IIhttps://leetcode.cn/problems/best-time-to-buy-and-sell-stock-ii/ 第一想法 题目理解:找到一个升序的段,然后累加每一个升序的段头尾的…

ORCA优化器浅析——CXform base class for all transformations

CXform CXforml类作为所有transformation的基础类,其包含了pattern成员m_pexpr。主要是在exploration和implementation expression流程中使用,主要调用Transform函数。其还包含返回相关xforms的集合函数,比如PbsIndexJoinXforms等。 class …

Centos7多台服务器免密登录

准备四台服务器: docker0 docker1 docker2 docker3 在docker0服务器上生成公钥和私钥 [rootwww ~]# ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/root/.ssh/id_rsa): Created directory /root/.ssh. Enter passp…

2023年03月 C/C++(一级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题:字符长方形 给定一个字符,用它构造一个长为4个字符,宽为3个字符的长方形,可以参考样例输出。 时间限制:1000 内存限制:65536 输入 输入只有一行, 包含一个字符。 输出 该字符构成的长方形…

Mysql主从分离

一、前言 某个应用场景中,在操作数据库这部分,往往是数据库的读取往往大于数据库的写入,当读取数据达到数据库的瓶颈时,性能下滑,影响数据的写入,导致整个应用的不可用。为了解决这个问题,这时&…

java热插拔组件 SPI机制

文章目录 前言一、热插拔(spi机制)是什么?二、使用步骤1.利用java META-INF2.利用google spi3. 测试效果 总结 前言 在项目中,如果想要增加项目的灵活性,健壮性, 高逼格,那么你要对于java中的一些机制有了解; 例如: java中的spi机制spring中的spring.factories 等…

QtCreator ui设置界面 Layout 的属性 layoutStretch

layoutStretch 用于控制Layout在被用户进行缩放时。里面控件的缩放比例。如一个水平布局里面有两个控件 一个 QLineEdit 和 QPushButton。首先将两个控件的尺寸策列的水平策略都设置为Expanding。此时在将包含这两个控件的水平布局的 layoutStretch 进行如下设置。 运行程序就…

权衡与选择:如何巧妙管理项目需求的优先级

在项目管理领域,处理和管理需求可能是最具挑战性的环节之一。每一个项目都充满了各种需求,从业务需求到技术需求,从用户需求到系统需求。而如何有效地为这些需求排列优先级,不仅会影响项目的进度和资源分配,还会直接关…

Azure创建第一个虚拟机

首先,登录到 Azure 门户 (https://portal.azure.com/)。在 Azure 门户右上角,点击“虚拟机”按钮,并点击创建,创建Azure虚拟机。 在虚拟机创建页面中,选择所需的基本配置,包括虚拟机名称、操作系统类型和版…

threejs纹理的使用

实现地板的效果,需要导入3张图片,第一种样式,第二种,木板间的间隙,第三种,木板的粗细图片。先注册一个物体属性,在物体属性上加上图片,注册代码如下图: const floorMat …

乡村振兴指数与其30余个原始变量数据(2000-2022年)

乡村振兴是当下经济学研究的热点之一,对乡村振兴进行测度,是研究基础。测度乡村振兴水平的学术论文广泛发表在《数量经济技术经济研究》等顶刊上。整理了2000-2022年城市层面的乡村振兴指数与其30余个原始变量数据,供大家使用。 数据来源&…

大数据Flink(六十二):批处理的入门案例

文章目录 批处理的入门案例 一、示例 二、​​​​​​​开发步骤

Ae 效果:CC Environment

透视/CC Environment Perspective/CC Environment CC Environment(CC 环境)主要用于创建 3D 环境映射,可以将一个 2D 图像转换为 3D 空间的反射或折射。该效果通常用于模拟真实世界的全景相机镜头和环境反射。 在实际操作中,可将效…

阿里云服务器带宽计费模式怎么选?有什么区别?

阿里云服务器公网带宽计费模式按固定带宽和按使用流量哪个划算?阿里云百科以北京地域为例,按固定带宽计费1M带宽一个月23元,按使用流量计费1GB流量0.8元,如果云服务器带宽使用率低于10%,那么首选按使用流量计费&#x…

中国省级、城市-数字经济创新创业、分项指数(2010-2020年)

一、数据介绍 数据名称:中国省级、城市-数字经济创新创业、分项指数 数据年份:2010-2020年 数据范围:31省、336个城市 数据来源:北大企业大数据研究中心 二、参考文献 参考文献: 戴若尘,王艾昭,陈斌开.中国数字…

【C++】模拟实现map和set(用红黑树进行封装)

模拟实现map和set 前言正式开始简单框架data的比较迭代器operatoroperator-\-[ ]重载 前言 本篇以前一篇红黑树模拟实现插入功能为基础:【C】红黑树模拟实现插入功能(包含旋转和变色) 本篇中不会再讲解关于旋转和变色的知识。只是对于红黑树进行简单的封装。 如果…