生产环境发布管理

简介: 本文介绍大型团队中多环境自动化发布流程,涵盖dev、test、pre、prod各环境职责,结合CI/CD平台实现高效部署,并通过Skywalking等工具实现日志追踪与问题排查。

前言

在一个大型团队中,生产发布是一件复杂的事情,从dev(前后端联调)-->test(测试集成&压力测试)-->pre(灰度测试)-->prod(生产环境)的多环境推进,以及生产环境的热更新、回滚等问题一直在困扰着各个公司,今天我将基于公司的自动化部署平台为大家讲解下我们是如何做到多环境部署。

每个环境做什么

在明确发布之前,我们需要明确一下每个环境的主要职责和角色:

DEV:也叫开发环境

  • 事项:前后端接口联调,修复代码基础缺陷
  • 角色:前端-后端

TEST:也叫测试环境

  • 事项:测试集成测试、压力测试,开发修复bug
  • 角色:开发(前端后端)、测试

PRE:也叫灰度环境

  • 事项:生产环境冒烟测试,切5个左右真实生产数据,回归流程是否有问题
  • 角色:开发(前端后端)、测试

PROD:也叫生产环境

  • 事项:发布代码,做真实环境验证,有问题第一时间修复(sql止血订正或代码回滚)
  • 角色:开发(前端后端)、测试、运维

大型公司如何管控代码发布

随着自动化部署CI/CD(DevOPS)成熟,目前大型公司都开始搭建自动化部署平台,形如下图:

图1 (自动化部署平台应用主页)

当用户进入应用主页后,会发现有不同的发布环境,每一个环境对应一台服务器、一个访问域名、一组中间件环境(即dev、test等环境的nacos-mysql等都是分环境部署的)。

图2 (自动化部署平台多环境)

同时自动化部署平台会自动整合公司的gitlab,将分支展现在发布平台,以便用户可以界面化操作和部署

图3 (自动化部署平台分支管理)

当用户需要创建分支时,不再需要像传统的那样去git创建,或者idea创建,而是可以直接在当前发布平台创建(底层是一样的,都是创建一个新的git分支)

图4 (自动化部署平台分支创建)

当用户需要发布时,只需要进入对应的环境(这里我们以test为例),勾选所需要发布的分支,即可实现自动化部署。下图可以看到test环境同时部署分支约20个。

图5 (自动化部署平台提交发布)

需要注意的是:假设我们需要对A分支进行发布,只需要勾选A分支,底层Jenkins会自动完成jar包构建,并执行底层的Docker run指令完成容器部署,这里部署的jar包每个环境都是隔离的。

即dev的jar跟test无关,每次都是新构建自己的。即使是test,点击两次发布也是构建了两个jar,只不过第二次的会覆盖第一次。这点各位需要明晰。

当测试提出我们有bug时,对应的开发人员就需要在idea中,A分支上完成代码修复并push,然后在自动化部署平台重新勾选分支,然后提交部署,完成一次重新发布,循环此过程,直至缺陷被修复。

如何排查日志

当测试提出某个环境有bug时,如果是传统Linux直接部署,我们会登录到指定的服务器用cat、grep、vim等指令进入日志文件,然后找到错误的堆栈信息。如果有结合Arthas的(Arthas排查错误)可以启动Arthas查看错误信息。但是现在一般都是会借助于Skywalking或ELK进行日志查看

图6 (自动化部署平台日志排查)

在上图中我们就可以看到:一个GET请求,请求路径是:/dict/default/staff,然后一个远程服务调用,使用的dubbo,最后查询mysql数据库,这样就完成一个完整的日志链路追踪。

如何回答相关问题

1.你们公司如何部署发布

方案一:Linux原生部署

我们公司的部署呢,还是比较原始的,就是直接部署在原生的Linux系统,我们平时dev发布就在idea构建好一个jar包,然后用XShell上传上去,用指令:nohup java -jar tj-learning.jar启动。测试环境和生产也是一样的操作

方案二:基于Jenkins的自动化部署平台

我们公司的部署都已经非常成熟了,有一套自动部署平台,底层是Jenkins+K8S实现自动化部署发布,我们只需要在dev、test、prod等环境勾选需要发布的分支就行,它全帮我们做好了自动部署。

2.你们公司怎么排查错误

方案一:Linux原生环境

我们公司的部署呢,还是比较原始的,就是直接部署在原生的Linux系统,所以排查日志也需要自己去找到error.log,然后手动找到报错的堆栈信息,分析出原因。比如有个NPE(NullPointException-空指针异常),就会显示具体哪行报错,我们就会分析、修复。

方案二:基于Docker的原生平台

我们公司目前的部署就是原生的Docker,通过docker logs命令人肉排查

方案三:基于Skywalking的日志检索平台(CI/CD平台)

对于日志排查,我们公司是有Skywalking的,只需要测试给我对应的traceId,我输入进去就可以看到完整的调用链路和报错的堆栈信息,然后就可以分析报错原因并修复了

相关文章
|
6月前
|
前端开发 程序员 开发者
常见注解及使用说明
本文介绍SpringMVC中@RequestMapping注解的作用与原理,讲解如何通过注解将HTTP请求映射到控制器方法,实现前后端接口对接,并简述@GetMapping等派生注解的封装关系,帮助开发者快速掌握接口路径定义机制。
常见注解及使用说明
|
8月前
|
数据采集 关系型数据库 MySQL
如何从零开发一款 OneAgent
Databuff自研轻量级OneAgent,专为智能可观测时代打造。具备低资源占用、自动服务发现、SQL查询支持与采集即治理等特性,兼容多语言插件扩展,助力AI-Agent集成与全栈监控统一管理。
|
5月前
|
存储 弹性计算 小程序
阿里云 2 核 2G 云服务器:价格、性能与适用场景解析
在云服务器选型中,2 核 2G 是典型的入门级配置 —— 既不会像 1 核 1G 那样受限于基础性能,又比 4 核 4G 更贴近个人和小微企业的预算,适合搭建个人博客、小型网站或运行轻量应用。下面从价格构成、性能表现、适用场景三方面,用通俗语言拆解这款配置,帮助判断是否契合需求。
|
7月前
|
JSON 供应链 API
获取中国制造网商品详情数据的 API 接口指南
中国制造网提供商品详情API,支持通过RESTful接口获取商品信息。开发者需申请权限,使用api_key与secret_key进行身份验证,并按规则生成签名。接口以JSON格式返回商品标题、价格、图片、属性等数据,适用于数据分析、供应链管理等场景。调用时需注意频率限制与参数规范,确保请求合法有效。
|
5月前
|
SQL 人工智能 分布式计算
轻松体验MaxCompute SQL AI:用SQL调用大模型
本报告通过三步实践演示如何用SQL调用大模型:领取MaxCompute资源、创建项目与测试表、使用AI_TEXT_COMPLETE函数实现文本摘要和情感分析。全程无需复杂代码,仅用标准SQL即可在数据环境中直接调用AI能力,显著降低应用门槛,提升分析效率,验证了SQL+AI融合处理文本的可行性。
187 8
|
5月前
|
Ubuntu 关系型数据库 MySQL
基于Ubuntu 24编译部署开源PolarDB-X
作者介绍: 韦玮 浙江宇视科技有限公司分布式存储开发工程师 浙江宇视科技有限公司是全球AIoT产品、解决方案与全栈式能力提供商,以“ABCI”(AI人工智能、BigData大数据、Cloud云计算、IoT物联网)技术为核心。
|
5月前
|
弹性计算 运维 安全
2026年阿里云 ECS 云服务器的定义、购买流程、功能优势与使用指南说明
阿里云 ECS(Elastic Compute Service)是阿里云提供的 IaaS(基础设施即服务)级云计算服务,用户无需提前采购物理服务器,就能像使用水电一样便捷地获取计算资源,实现 “即开即用” 和弹性伸缩,适配从个人开发到企业核心业务的全场景需求。以下从核心定义、购买方式、产品优势、使用途径及部署建议等维度,用通俗语言展开解析,帮助用户全面了解 ECS。
|
5月前
|
弹性计算 人工智能 测试技术
2026年阿里云服务器优惠购买攻略:折扣力度与实用指南
在选购阿里云服务器时,合理利用优惠政策能显著降低成本。阿里云针对不同用户群体(新用户、老用户、学生)推出差异化折扣,覆盖首购、续费、升级等全场景。以下结合最新信息,详解各群体可享受的折扣力度、获取方式及使用技巧,帮助用户高效把控预算。
|
5月前
|
存储 弹性计算 人工智能
租用阿里云服务器一年要多少钱?2026年最新费用价格全解析
租用阿里云服务器的成本受配置、实例类型、地域等因素影响,不同需求对应不同价格区间。以下结合最新优惠信息,梳理轻量应用服务器、ECS 云服务器及 GPU 服务器的热门配置与一年费用,帮助用户根据业务场景选择合适方案,避免盲目消费。