什么是持续部署
管理软件开发和部署有 3 种常见的方法:持续集成、持续交付,然后是持续部署。尽管它们经常被混淆,但它们是明显不同的。
正如您将在本文后面看到的,它们相互融合,并补充彼此的风格。但这篇文章并不是关于他们三个。今天我们想重点关注持续部署:什么是持续部署,它与其他方法有何不同,甚至它的流程和工具。在本文结束时,您将了解持续部署是否适合您的组织。
那么,让我们开始吧。
什么是持续部署?
持续部署是一种将软件自动发布或部署到生产环境中的软件开发方法。在此模型中,没有人手动检查代码并将其推送到您的应用程序中。
现在,这并不意味着没有事先进行彻底检查。显然,您必须知道正在部署的代码在交付最终用户(您的客户)手中之前是否没有错误和错误。但这也可以通过软件来完成。代码会自动测试问题,如果没有发现问题,则部署代码。
为了实现这一目标,团队必须设计或实施各种其他自动化程序,以无缝地将软件从开发的后期阶段一直拉到发布。持续部署的目标应该是显而易见的:编写代码并尽快将其交到用户手中。
但这可能很危险。如果在此过程中没有适当的检查,错误的代码可能会部署到生产中并真正搞砸您的产品,这就是为什么许多使用此方法的团队只发布小的更改。更改足够小,如果确实出现问题,则存在被遗漏的错误,那么将其回滚并重新开始并不是太困难。
但这些变化也足够大,可以快速累积起来,并为开发人员节省了大量的时间,使他们可以花在重复测试上。这也意味着,为了使持续部署成功,您需要确保拥有强大的测试框架,并确信当代码通过测试时,它确实准备好立即部署,而无需任何人查看。
对于许多开发人员来说,这个概念非常可怕,这就是为什么他们选择更安全、更常见的持续交付和持续集成选项。
但这三种方法有什么区别呢?
请仔细阅读,找出答案。
持续集成和持续交付与持续部署
图片标题
持续部署经常与持续交付混淆,但两者之间存在明显的区别。
持续部署部分是持续交付的延续,部分是持续交付的替代。让我们回到它们的来源来解释:持续集成。
根据 Aaron Cois 的说法,持续集成是一种旨在不断地将“团队中所有开发人员的源代码更新合并到共享主线中”的技术。这种持续的合并可以防止开发人员的软件项目本地副本随着其他人添加新代码而偏离太远,从而避免灾难性的合并冲突。”
现在,持续交付又向前迈进了一步。持续交付创建可以随时发布到生产环境的软件,这意味着软件被编写、测试并推送到类似生产的环境中,以确保它在真实的生产环境中正确运行。它位于等待区,直到您准备好最终部署它。
现在您可能已经认识到其中的差异了。持续集成将单独的代码片段合并在一起以确保它们正常工作,经常这样做可以避免出现重大问题。持续交付测试所有合并的代码,一旦被认为准备好部署,就将其放入保留区域,直到开发人员将其推送通过。持续部署需要持续交付的自动化测试,但不会就此止步,而是将新软件自动发布到生产环境中,直接发布给最终用户。
什么是持续部署管道?
您可能了解持续交付管道,并且在谈到持续部署管道时可能会摸不着头脑。说实话,与其说它是一个管道,不如说它是一个过程。但管道有助于理解这一点,因为它是一条线性的、结构化的路径。
因此,持续部署管道有四个阶段:
部署到生产环境
验证解决方案
监控问题
响应并恢复
我们将在下面更详细地介绍每个阶段。
部署到生产环境
这是显而易见的第一步。软件自动部署到生产中。可能不太明显的是,以这种方式操作时会放弃多少。例如,可以在没有完整功能的情况下部署对软件的更改,有时甚至无需完整的用户故事。部署过程应该快速且轻松。但它也应该尽可能可靠,当您自动化整个部署过程时,从服务器配置和基础设施配置到数据库脚本编写和代码迁移,您应该在首次构建和实现它之后密切监视整个过程,以确保它有效地发挥作用。建议您将所有可部署资产保留在版本控制中,并使用部署自动化工具来编写所有部署步骤的脚本。
因此,您的持续部署流程应从软件成功构建开始,然后进行轻松集成,并进行彻底验证,最后进行全面部署。理想情况下,整个工作流程将实现自动化,并通过“一次点击”操作。但不仅仅是自动化,持续部署还应该足够可靠,可以在一年中的任何一天运行,即使是在高峰时段。
以这种方式部署软件的能力需要您做七件事:
将软件部署到生产环境,而不向最终用户发布功能
在代码中实现切换,以便您可以在新旧功能之间切换。
自动将经过全面测试的软件从前一阶段部署到生产环境。
能够根据地理位置、用户角色和其他标准将软件部署到不同的生产环境中。
“自助”部署功能允许您使用单个命令将软件从暂存阶段转移到生产环境,以防未实现完全自动化或无法正常工作。
版本控制下的环境维护。
蓝/绿部署,因此您可以在两种不同的环境之间切换:部署和实时。
验证解决方案
现在,我们一直在讨论如何将软件部署到生产环境,然后发布给最终用户,但您可能没有意识到测试可以而且应该在生产环境中进行。根据软件测试帮助:“持续部署不必是‘发布到生产’。但代码已部署到生产中,并使用“功能切换”保持静音,当代码准备就绪时,功能切换将打开。”
这意味着部署和发布有时是耦合的,并且是背靠背发生的。但其他时候,它们是解耦的,为您提供了进行最后一轮测试的空间。您可以在此处执行多种测试:
烟雾测试
用户验收测试
压力测试
性能测试
其中一些只能在生产环境中完成。
这使得持续部署对于许多团队来说不再那么可怕。
如果您遵循持续集成,那么您就已经获得了质量保证,以确保软件按其应有的方式运行。但以后最好减少不愉快的意外发生的次数。特别是因为您不想回滚或尝试快速修复可能严重扰乱生产环境和业务流程的重大错误。
监控问题
软件最终部署完成了吗?几乎不。
虽然在生产过程中没有发生任何问题,但您的工作是监视部署的新代码的性能,以确保其继续按预期方式运行。这或多或少是持续部署的真正最后一步。您收集的见解越多,就越能实现战略业务成果。这些见解来自于增强的监控功能,您应该在软件发布之前就已经具备这些功能。
当然,在软件完全发布给最终用户之前,有很多商业价值指标是无法跟踪的。无论如何,安装监控系统可以让您跟踪每个软件功能,从而提高对任何生产问题的响应能力。
响应和恢复
虽然监控是持续部署管道的官方最后一步,但如果出现问题,它不会是您采取的最后一步。除了出色的自动化测试之外,有效持续部署的秘诀在于能够响应生产和发布中不可预见的问题并从中恢复。最重要的是,任何生产问题都会影响您的客户和最终用户。这对您的团队和业务都不利。对您的应用程序的信任可能会迅速消失。
大多数软件都需要某种修复和补丁的组合。但重新开发、重新测试和重新部署是另一个令人头疼的问题,您应该尽力避免。这就是为什么能够在问题被理解为问题之前主动检测问题并快速从中恢复至关重要的原因。当您的团队对快速找到问题的根本原因并在发现问题后立即解决问题的能力充满信心时,您就已经达到了持续部署的最佳状态。
但你必须小心,因为你不想陷入仓促改变的陷阱。这可能会使问题变得更糟并导致长期风险。
这就是为什么你应该确保你正在练习以下内容:
主动在软件中创建故障,以便在可能的问题和错误出现之前发现它们。
跨价值流合作来发现和解决问题。
重播最终用户会话以更好地了解事件并再次根除问题。
能够回滚到以前的环境。
无需改变生产环境。
在版本控制下维护环境。
如何开始持续部署
持续部署是一个部分、一个过程,可能会也可能不会作为完整 DevOps 计划的一部分来实现。这意味着,在开始使用持续部署之前,您需要将团队切换到 DevOps 框架。
DevOps 最好的部分是,它将最终与新软件项目交互的所有团队聚集在一起,并允许他们同时协作、提供和接收反馈,并加快开发和部署周期。
相关文章:
什么是持续部署
管理软件开发和部署有 3 种常见的方法:持续集成、持续交付,然后是持续部署。尽管它们经常被混淆,但它们是明显不同的。 正如您将在本文后面看到的,它们相互融合,并补充彼此的风格。但这篇文章并不是关于他们三个。今天…...
【Python】Loguru模块更简洁的日志记录库
Loguru: 更优雅的日志记录解决方案! loguru 是一个Python 简易且强大的第三方日志记录库,该库旨在通过添加一系列有用的功能来解决标准记录器的注意事项,从而减少 Python 日志记录的痛苦。 使用自带自带的 logging 模块的话,则需要…...
智慧环保:科技驱动下的环境保护新篇章
智慧环保:科技驱动下的环境保护新篇章 环境保护已经成为当今社会的重要议题,而科技的飞速发展为我们开启了智慧环保的新篇章。在这篇文章中,我们将介绍智慧环保所带来的机会和创新,以及科技在环境保护中的重要作用。 智慧环保的理…...
CTF-PWN环境搭建手册
工欲善其事必先利其器,作为一名CTF的pwn手,一定要有自己的专用解题环境。本文将详细记录kali下的pwn解题环境的安装过程,B站也会配备配套视频。 目录 安装前的准备工作 虚拟机环境编辑 VM版本安装教程 1. 下载Kali的VM虚拟机文件 2. 新…...
Nginx安装配置与SSL证书安装部署
一、Nginx Nginx是一款高性能的开源Web服务器和反向代理服务器,被广泛用于构建现代化的Web应用和提供静态内容。 nginx官网 这里下载nginx-1.24.0-zip Nginx是一款高性能的开源Web服务器和反向代理服务器,被广泛用于构建现代化的Web应用和提供静态内…...
高性能面试八股文之编译流程程序调度
1. C的编译流程 C语言程序的编译过程通常包括预处理(Preprocessing)、编译(Compilation)、汇编(Assembly)、链接(Linking)四个主要阶段。下面是这些阶段的详细说明: 1.…...
opencv的MinGW-W64编译
最近使用Qt,需要用到opencv,安装详情参考下面这个网址,写的挺好: opencv的MinGW-W64编译 - 知乎 我电脑安装Qt中自带了MinGW,所以不需要像上面网址中的下载MinGw,只需要将Qt中自带的MinGW添加到环境变量即可,如&…...
在Go编程中调用外部命令的几种场景
1.摘要 在很多场合, 使用Go语言需要调用外部命令来完成一些特定的任务, 例如: 使用Go语言调用Linux命令来获取执行的结果,又或者调用第三方程序执行来完成额外的任务。在go的标准库中, 专门提供了os/exec包来对调用外部程序提供支持, 本文将对调用外部命令的几种使用方法进行总…...
python学习:break用法详解
嗨喽,大家好呀~这里是爱看美女的茜茜呐 在执行while循环或者for循环时,只要循环条件满足,程序会一直执行循环体。 但在某些场景,我们希望在循环结束前就强制结束循环。 Python中有两种强制结束循环的方法: continue语…...
【算法萌新闯力扣】:找到所有数组中消失对数字
力扣热题:找到所有数组中消失对数字 开篇 这两天刚交了蓝桥杯的报名费,刷题的积极性高涨。算上打卡题,今天刷了10道算法题了,题目都比较简单,挑选了一道还不错的题目与大家分享。 题目链接:448.找到所有数组中消失对…...
Node.js 安装配置
文章目录 安装检测Node是否可用 安装 首先我们需要从官网下载Node安装包:Node.Js中文网,下载后双击安装没有什么特殊的地方,安装路径默认是C盘,不想安装C盘的话可以选择一下其他的盘符。安装完成以后可以不用配置环境变量,Node安装已经自动给…...
前端JS 使用input完成文件上传操作,并对文件进行类型转换
使用input实现文件上传 // 定义一个用于文件上传的按钮<input type"file" name"upload1" />// accept属性用于定义允许上传的文件类型, onchange用于绑定文件上传之后的相应函数<input type"file" name"upload2"…...
探索AI交互:Python与ChatGPT的完美结合!
大家好!我是爱摸鱼的小鸿,人生苦短,我用Python!关注我,收看技术干货。 随着人工智能的迅速发展,AI交互正成为技术领域的一大亮点。在这个过程中,Python编程语言和ChatGPT模型的结合展现出强大的…...
CI/CD - jenkins
目录 一、部署 1、简介 2、部署 二、配置 三、实时触发 四、自动化构建docker镜像 五、通过ssh插件交付任务 六、添加jenkins节点 七、RBAC 八、pipeline 九、jenkins结合ansible参数化构建 1、安装ansible 2、新建gitlab项目 3、jenkins新建项目playbook 一、部…...
【【萌新的SOC学习之 VDMA 彩条显示实验之一】】
萌新的SOC学习之 VDMA 彩条显示实验之一 实验任务 : 本章的实验任务是 PS写彩条数据至 DDR3 内存中 然后通过 VDMA IP核 将彩条数据显示在 RGB LCD 液晶屏上 下面是本次实验的系统框图 VDMA 通过 HP接口 与 PS端的 DDR 存储器 进行交互 因为 VDMA 出来的是 str…...
相机通用类之海康相机,软触发硬触发(飞拍),并输出halcon格式对象
//在此之前可以先浏览我编写的通用上位机类,更方便理解 https://blog.csdn.net/m0_51559565/article/details/134403745最近完成一个关于海康采图的demo,记录并说明用法。 先上代码。using System; using System.Collections.Generic; using System.Runt…...
linux时间调整
查看当前系统时间 [rootVM-12-12-centos ~]# date Sat Nov 18 16:09:11 CST 2023 Sat:表示星期六Saturday的缩写 Nov:表示十一月November的缩写 18:表示日期18号 16:09:11:时间 CST:China Standard Time中国标准…...
C++模版初阶
泛型编程 如下的交换函数中,它们只有类型的不同,应该怎么实现一个通用的交换函数呢? void Swap(int& left, int& right) {int temp left;left right;right temp; }void Swap(double& left, double& right) {double temp…...
软考-高级-系统架构设计师教程(清华第2版)【第20章 系统架构设计师论文写作要点(P717~728)-思维导图】
软考-高级-系统架构设计师教程(清华第2版)【第20章 系统架构设计师论文写作要点(P717~728)-思维导图】 课本里章节里所有蓝色字体的思维导图...
Go 语言结构体验证详解:validate 标签与自定义规则
介绍 Go 语言中,结构体验证是保障数据完整性和正确性的重要手段之一。本文将深入探讨 validate 标签的使用方式,并介绍如何结合验证库 go-playground/validator 进行自定义验证规则。 安装与导入验证库 首先,请确保已安装验证库:…...
JavaSec-RCE
简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性,…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...
渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止
<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet: https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...
基于Docker Compose部署Java微服务项目
一. 创建根项目 根项目(父项目)主要用于依赖管理 一些需要注意的点: 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件,否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...
工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配
AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...
均衡后的SNRSINR
本文主要摘自参考文献中的前两篇,相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程,其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt 根发送天线, n r n_r nr 根接收天线的 MIMO 系…...
ip子接口配置及删除
配置永久生效的子接口,2个IP 都可以登录你这一台服务器。重启不失效。 永久的 [应用] vi /etc/sysconfig/network-scripts/ifcfg-eth0修改文件内内容 TYPE"Ethernet" BOOTPROTO"none" NAME"eth0" DEVICE"eth0" ONBOOT&q…...
Docker 本地安装 mysql 数据库
Docker: Accelerated Container Application Development 下载对应操作系统版本的 docker ;并安装。 基础操作不再赘述。 打开 macOS 终端,开始 docker 安装mysql之旅 第一步 docker search mysql 》〉docker search mysql NAME DE…...
MFC 抛体运动模拟:常见问题解决与界面美化
在 MFC 中开发抛体运动模拟程序时,我们常遇到 轨迹残留、无效刷新、视觉单调、物理逻辑瑕疵 等问题。本文将针对这些痛点,详细解析原因并提供解决方案,同时兼顾界面美化,让模拟效果更专业、更高效。 问题一:历史轨迹与小球残影残留 现象 小球运动后,历史位置的 “残影”…...
数据库正常,但后端收不到数据原因及解决
从代码和日志来看,后端SQL查询确实返回了数据,但最终user对象却为null。这表明查询结果没有正确映射到User对象上。 在前后端分离,并且ai辅助开发的时候,很容易出现前后端变量名不一致情况,还不报错,只是单…...
