当前位置: 首页 > news >正文

提升交付效率:Booking.com 金融技术团队的成功实践

Booking.com 金融技术业务部门的团队对其平台的后端和前端实施了一系列改进措施,并通过 DORA 指标将交付性能提高了一倍。此外,还使用了微前端 (MFE) 模式,将单体 FE 应用程序分解为多个可单独部署的分解应用程序。

2022 年年中,Booking.com 成立了一个新的工程团队,负责财务领域的多个流程。该团队选用了一部分更广泛的平台架构,包括一个使用 Perl 和 Javascript(使用 Vue Framework)编写的单体前端应用程序,以及一个依赖于许多其他微服务的 Java 后端服务

图片

团队很快发现,对现有代码库进行更改并将其部署到生产中既有风险又耗时。为了提高交付频率,团队决定采用 DORA 提出的定制 DevOps 指标来跟踪交付流程的关键绩效指标。工程师们开始记录交付速度指标(部署频率和变更准备时间),以建立基线。他们还选择了定制的可靠性/稳定性指标,包括服务可用性和开放缺陷数量,而不是 DORA 指标(变更失败率和平均恢复时间)。根据团队的测量,在 2023 年 3 月至 11 月期间,关键的交付速度指标提高了两倍,而质量和可用性则保持稳定

图片

在整个观察期间,工程师们逐渐提高了 Java 后端服务的代码质量。他们还转向了更小的合并请求(又称为 pull requests),以确保代码审查不那么痛苦,并在团队成员之间进行优先排序。此外,开发人员还改进了部署流程,逐步减少了人工验证步骤,并更多地依赖于改进后的自动测试。最后,他们改用全自动部署,将部署时间从 40 分钟缩短到 4 分钟

Booking.com 高级工程经理 Egor Savochkin 介绍了团队为降低变更时引入问题的风险并改进代码所采取的方法:

团队采用 Boy Scout rule,通过重构和测试自动化提高代码质量,同时不停止所有功能工作。在实施变更或修复缺陷的同时,还要努力改进周围的代码。这并不需要很大的改进。这可能只是简单地为你接触过的类添加单元测试,或进行小规模重构以消除代码质量问题。

在团队选择将单体应用程序拆分为微前端(MFE)后,前端方面也得到了改进,但改进并没有像希望的那样迅速实现。在调整代码审查流程并减少对外部专家审批的依赖后,代码审查时间缩短到了 8 分钟。有了快速的代码审查,团队开始更频繁地进行小规模部署,将部署时间缩短到 1 小时

相关文章:

提升交付效率:Booking.com 金融技术团队的成功实践

Booking.com 金融技术业务部门的团队对其平台的后端和前端实施了一系列改进措施,并通过 DORA 指标将交付性能提高了一倍。此外,还使用了微前端 (MFE) 模式,将单体 FE 应用程序分解为多个可单独部署的分解应用程序。 2022 年年中,B…...

【消息队列开发】 实现ConsumerManager类——消费消息的核心逻辑

文章目录 🍃前言🌴扫描线程的实现🌲实现消费消息🌳实现addConsumer()方法🎋VirtualHost类订阅消息的完善⭕总结 🍃前言 本次开发目标 实现消费消息的核心逻辑 🌴扫描线程的实现 我们先给Cons…...

【Three.js】使用精灵图Sprite创建面朝相机的文本标注

目录 🐝前言 🐝canvas创建文字 🐝将canvas作为纹理贴图加载到sprite中 🐝封装方法 🐝前言 在Three.js中精灵Sprite是一个总是面朝摄像机的平面,它通常和纹理贴图结合使用,贴图可以是一张图…...

C++中的类模板

C中的类模板 类模板 类模板在C中是一种非常强大的工具,它允许程序员编写与数据类型无关的代码。简单来说,类模板允许你定义一个蓝图,这个蓝图可以用来生成具体类型的类。使用类模板可以提高代码的复用性,减少重复代码&#xff0…...

【每日一题】好子数组的最大分数

Tag 【单调栈】【暴力枚举】【数组】【2024-03-19】 题目来源 1793. 好子数组的最大分数 解题思路 本题和 84. 柱状图中最大的矩形 一样,计算的都是最大矩形的面积。只不过多了一个约束:矩形必须包含下标 k。 以下的方法一和方法二是 84. 柱状图中最…...

Vue2(七):超详细vue开发环境搭建(win7),nodejs下载与安装,安装淘宝镜像(报错已解决),配置脚手架

一、安装node.js 本来想粗略写一下的,但是搭建脚手架的时候,遇到了很多问题,浪费快两天时间,记录一下自己的解决办法希望对你们有帮助! 1.下载nodejs 安装包下载链接【CNPM Binaries Mirror】 下载我划线的这个&am…...

【Web】记录CISCN 2021 总决赛 ezj4va题目复现——AspectJWeaver

目录 前言 原理分析 step 0 step 1 EXP 前文:【Web】浅聊Java反序列化之AspectJWeaver——任意文件写入-CSDN博客 前言 这就是当年传说中的零解题嘛😭,快做🤮了 有了之前的经验,思路顺挺快的,中间不…...

视频技术1:使用ABLMediaServer推流rtsp

ABLMediaServer定位是高性能、高稳定、开箱即用、商用级别的流媒体服务器 下边展示了如何把1个mp3作为输入源,转换为rtsp流的过程。 作用:用rtsp模拟摄像头的视频流 1、启动ABLMediaServer ABLMediaServer-2024-03-13\WinX64\ABLMediaServer.exe 配…...

HTML5+CSS3+JS小实例:创意罗盘时钟

实例:创意罗盘时钟 技术栈:HTML+CSS+JS 效果: 源码: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=…...

设计数据库之内部模式:SQL基本操作

Chapter4&#xff1a;设计数据库之内部模式&#xff1a;SQL基本操作 笔记来源&#xff1a; 1.《漫画数据库》—科学出版社 2.SQL | DDL, DQL, DML, DCL and TCL Commands 设计数据库的步骤&#xff1a; 概念模式 概念模式(conceptual schema)是指将现实世界模型化的阶段进而&…...

Git浅谈配置文件和免密登录

一、文章内容 简述git三种配置ssh免密登录以及遇见的问题git可忽略文件git remote 相关操作 二、Git三种配置 项目配置文件(局部)&#xff1a;项目路径/.git/config 文件 git config --local user.name name git config --local user.email 123qq.cc全局配置文(所有用户): …...

【好玩的经典游戏】Docker环境下部署RPG网页小游戏

【好玩的经典游戏】Docker环境下部署RPG网页小游戏 一、react-tetris小游戏介绍1.1 react-tetris小游戏简介1.2 项目预览二、本次实践介绍2.1 本地环境规划2.2 本次实践介绍三、本地环境检查3.1 安装Docker环境3.2 检查Docker服务状态3.3 检查Docker版本3.4 检查docker compose…...

前端逻辑错误或UI崩溃解决问题

全屏错误覆盖层或UI崩溃 VueReact&#xff08;错误边界&#xff09; Vue Vue的全屏错误覆盖层解决&#xff0c;其实只需要配置Error就好&#xff0c;在开发服务器的client.overlay中设置关闭全屏覆盖层 module.exports {devServer: {client: {overlay: {warnings: false,error…...

python爬取QQ音乐评论信息

python爬取QQ音乐评论信息 python爬取QQ音乐评论信息1.随便选个音乐python爬取QQ音乐评论信息 1.随便选个音乐 https://y.qq.com/n/yqq/song/0039MnYb0qxYhV.html 当前的后台调试页面显示如下: 找到评论的数据接口: https://c.y.qq.com/base/fcgi-bin/fcg_global_comme…...

Unity构建详解(1)——SBP介绍

【前言】 Unity的资源工作流程分为导入、创建、构建、分发、加载。我们说的是其中的构建步骤。 构建是指将项目工程中的资源文件和代码整合程可执行文件的过程&#xff0c;构建的结果是生成可执行文件&#xff0c;在win平台上是exe&#xff0c;在Android平台上是apk&#xff…...

贪心算法(算法竞赛、蓝桥杯)--奶牛晒衣服

1、B站视频链接&#xff1a;A28 贪心算法 P1843 奶牛晒衣服_哔哩哔哩_bilibili 题目链接&#xff1a;奶牛晒衣服 - 洛谷 #include <bits/stdc.h> using namespace std; priority_queue<int> q;//用大根堆维护湿度的最大值 int n,a,b; int tim,maxn;int main(){s…...

Redis列表:高效消息通信与实时数据处理的利器

Redis是一个强大的开源内存数据库&#xff0c;被广泛应用于缓存、会话存储、队列等各种场景中。在Redis中&#xff0c;列表&#xff08;List&#xff09;是一种非常重要的数据结构&#xff0c;它提供了存储、获取、操作有序元素集合的功能。本文将深入探讨Redis列表的特性、使用…...

Redis中的缓存雪崩

缓存雪崩 &#x1f914;现象分析 缓存雪崩是指在同一时段大量的缓存key同时失效或者缓存服务(Redis等)宕机&#xff0c;导致大量请求到达数据库&#xff0c;带来巨大压力。 &#x1f44a; 解决方案 利用Redis集群提高服务的可用性&#xff0c;避免缓存服务宕机给缓存业务添…...

使用远程工具连接Mysql

&#xff08;若想要远程连接Mysql需要下面解决四个问题&#xff09; 1、目标地址 直接查询 2、端口号 3306 3、防火墙关闭 [rootlocalhost date]# systemctl stop firewalld.service 4、授权mysql数据库root用户权限&#xff08;因为mysql开始不允许其他IP访问&#xff0…...

2024不起眼的“致富”野路子,不想打工了,做做这些暴利创业项目。2024个人创业做什么项目好;最适合白手起家的创业项目

经济大环境差&#xff0c;并不代表就没有机会。相反&#xff0c;主流经济不好正是另一些人所看重的千载难逢的机会。就像股票市场一样&#xff0c;有人靠做多赚钱&#xff0c;有人靠做空赚钱。下面我们就来分析一下哪些行业会在这个时候崛起。 首先二手行业会迅速崛起&#xff…...

996引擎 - [开发辅助] 利用 robocopy 同步项目 dev 文件夹

996引擎 - [开发辅助] 利用 robocopy 同步项目 dev 文件夹 代码 git 管,资源统一放内网服务器。 使用以下脚本同步 岗位 同步方向 需求 策划 本地 >>> 内网服务器 提交资源 美术 本地 >>> 内网服务器 提交资源 程序 内网服务器 >>> 本地 拉取资源 …...

Janus-Pro-7B企业知识管理:基于AI的文档智能检索与摘要

Janus-Pro-7B企业知识管理&#xff1a;基于AI的文档智能检索与摘要 你是不是也遇到过这种情况&#xff1f;公司服务器里堆满了产品手册、项目报告、会议纪要&#xff0c;想找个资料得翻半天&#xff0c;最后还不一定能找到。或者&#xff0c;一份几十页的技术文档摆在面前&…...

2026年,这家大型快拼箱源头工厂直销厂家,究竟有何独特之处?

在快拼箱行业蓬勃发展的2026年&#xff0c;众多厂家如雨后春笋般涌现&#xff0c;但衡水贝客科技有限公司&#xff08;简称贝客房屋&#xff09;却凭借其独特的优势脱颖而出&#xff0c;成为行业内备受瞩目的大型快拼箱源头工厂直销厂家。接下来&#xff0c;让我们深入探究贝客…...

golang如何实现备忘录模式_golang备忘录模式实现方案

Go中备忘录模式需用非导出结构体封装快照、接口作类型标记&#xff0c;发起者控制Save/Restore&#xff1b;只备份业务字段&#xff0c;避免指针/map共享&#xff1b;限制栈长度并置空引用助GC&#xff1b;测试用reflect.DeepEqual验证隔离性。备忘录模式在 Go 里没有语言原生支…...

终极指南:5步让老款Mac安装最新macOS系统

终极指南&#xff1a;5步让老款Mac安装最新macOS系统 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 想让2008年甚至更早的MacBook也能运行最新的macOS Sequo…...

CLIP-GmP-ViT-L-14模型蒸馏实战:基于STM32F103C8T6的轻量化部署探索

CLIP-GmP-ViT-L-14模型蒸馏实战&#xff1a;基于STM32F103C8T6的轻量化部署探索 1. 引言 想象一下&#xff0c;一个只有指甲盖大小、成本低廉的微控制器&#xff0c;能够理解一张图片和一段文字是否匹配。这听起来像是科幻电影里的场景&#xff0c;但今天&#xff0c;我们就要…...

春联生成模型-中文-base应用案例:家庭布置、店铺营销、内容创作全搞定

春联生成模型-中文-base应用案例&#xff1a;家庭布置、店铺营销、内容创作全搞定 1. 春联生成模型能为你做什么&#xff1f; 春节贴春联是中国传统文化的重要组成部分&#xff0c;一副好的春联既要讲究对仗工整&#xff0c;又要蕴含美好寓意。但对于大多数人来说&#xff0c…...

Phi-4-mini-reasoning Chainlit插件开发:集成Copilot式代码补全与执行沙箱

Phi-4-mini-reasoning Chainlit插件开发&#xff1a;集成Copilot式代码补全与执行沙箱 1. 项目概述 Phi-4-mini-reasoning是一个基于合成数据构建的轻量级开源模型&#xff0c;专注于高质量、密集推理的数据处理。作为Phi-4模型家族的一员&#xff0c;它特别强化了数学推理能…...

AI Agent 可以操作哪些表单和数据收集工具?MCP 支持情况盘点

随着 MCP 协议的普及&#xff0c;越来越多的工具开始支持 AI 直接调用。本文梳理了目前已明确支持 MCP 的表单和数据收集工具&#xff0c;帮你判断哪个适合接入你的 AI 工作流。什么样的工具「支持 MCP」&#xff1f;简单说&#xff0c;就是这个工具提供了官方或可用的 MCP Ser…...

从零开始:为Pixel设备编译定制AOSP系统的完整指南

1. 环境准备&#xff1a;搭建AOSP编译基础 编译AOSP系统就像盖房子需要先打地基&#xff0c;准备工作直接影响后续所有环节的顺畅度。我曾在不同配置的电脑上尝试过十几次编译&#xff0c;深刻体会到环境配置的重要性。首先需要一台性能足够的Linux机器&#xff0c;推荐Ubuntu …...