生产环境发布管理

简介: 本文介绍大型团队中生产环境发布管理的全流程,涵盖从开发到生产的多环境部署策略(dev→test→pre→prod),基于自动化CI/CD平台实现分支管理、一键发布与回滚。结合Jenkins、Docker、K8S等技术,实现构建部署自动化,并通过Skywalking、ELK等工具高效排查日志,提升发布效率与系统稳定性。

生产环境发布管理
前言
在一个大型团队中,生产发布是一件复杂的事情,从dev(前后端联调)-->test(测试集成&压力测试)-->pre(灰度测试)-->prod(生产环境)的多环境推进,以及生产环境的热更新、回滚等问题一直在困扰着各个公司,今天我将基于公司的自动化部署平台为大家讲解下我们是如何做到多环境部署。每个环境做什么在明确发布之前,我们需要明确一下每个环境的主要职责和角色:DEV:也叫开发环境事项:前后端接口联调,修复代码基础缺陷角色:前端-后端TEST:也叫测试环境事项:测试集成测试、压力测试,开发修复bug角色:开发(前端后端)、测试PRE:也叫灰度环境事项:生产环境冒烟测试,切5个左右真实生产数据,回归流程是否有问题角色:开发(前端后端)、测试PROD:也叫生产环境事项:发布代码,做真实环境验证,有问题第一时间修复(sql止血订正或代码回滚)角色:开发(前端后端)、测试、运维大型公司如何管控代码发布随着自动化部署CI/CD(DevOPS)成熟,目前大型公司都开始搭建自动化部署平台,形如下图:
1-应用主页.jpg
图1 (自动化部署平台应用主页)当用户进入应用主页后,会发现有不同的发布环境,每一个环境对应一台服务器、一个访问域名、一组中间件环境(即dev、test等环境的nacos-mysql等都是分环境部署的)。
2-环境管理.jpg
图2 (自动化部署平台多环境)同时自动化部署平台会自动整合公司的gitlab,将分支展现在发布平台,以便用户可以界面化操作和部署
3-分支管理.jpg
图3 (自动化部署平台分支管理)当用户需要创建分支时,不再需要像传统的那样去git创建,或者idea创建,而是可以直接在当前发布平台创建(底层是一样的,都是创建一个新的git分支)
4-新建分支.jpg
图4 (自动化部署平台分支创建)当用户需要发布时,只需要进入对应的环境(这里我们以test为例),勾选所需要发布的分支,即可实现自动化部署。下图可以看到test环境同时部署分支约20个。
5-发布界面.jpg
图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进行日志查看
7-日志追踪.jpg
图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,我输入进去就可以看到完整的调用链路和报错的堆栈信息,然后就可以分析报错原因并修复了

相关文章
|
2月前
|
人工智能 自然语言处理 数据中心
2026AI元年:人工智能从技术突破走向规模化应用
AI 走向规模化的最大障碍,并不在于模型是否足够聪明,而在于是否足够确定、足够稳定、足够工程化。
183 5
|
3月前
|
监控 算法 5G
室内外融合定位技术从核心架构、技术原理到部署实施流程等详解(二)
本文详解室内外融合定位系统核心技术,涵盖北斗RTK厘米级定位、UWB高精度测距、场景自适应切换与多源数据融合四大模块。通过终端-网络-平台三层架构,实现室外高精度、室内无缝衔接的连续定位,支持化工、矿山等高危场景下的精准管控与安防联动,解决“进车间失联”难题。如果您想进一步了解室内外融合定位技术的案例,欢迎搜索维构lbs智能定位~
|
5月前
|
存储 弹性计算 监控
如何实现配置跨区域复制?
超68%企业因无异地容灾致数据丢失。阿里云跨区域复制功能,实现数据双活、合规存储与低延迟访问。本文详解OSS与ECS跨区域配置步骤,助力企业构建高可用架构。
|
11天前
|
人工智能 API 开发者
用 LangChain 驱动本地 Ollama 模型
本文详解如何用LangChain(基于最新Runnable API)调用本地Ollama模型,构建真正可用的私有化大模型应用。涵盖Ollama部署、OpenAI协议对接、Prompt编排、状态化对话(Memory)、工程实践建议等,兼顾安全性、可控性与落地性。(239字)
203 2
|
2月前
|
人工智能 JSON API
告别“玩具”:如何构建具备业务闭环能力的AI Agent?(附智能体来了西南总部技术实践路径)
2025年被视为“智能体元年”,LLM正从对话走向行动。本文基于“智能体来了(西南总部)”实践经验,提出“感知-决策-执行”三层架构,详解Agent开发的全栈路径:从Prompt工程、Workflow编排到Python代码集成,助力开发者掌握“Prompt + Python + Workflow”核心技能,推动企业数字化转型。
286 1
|
7月前
|
JavaScript 前端开发 API
PHP 发展简史:从个人工具到互联网基石
PHP 起源于 1994 年,由 Rasmus Lerdorf 为简化网页开发而创建,后逐步演变为功能强大的编程语言。从最初的个人工具到支撑全球 77.4% 的服务器端脚本市场,PHP 凭借易用性、稳定性和广泛的生态支持,在 Web 开发领域占据重要地位。经历 PHP 6 的挫折后,PHP 7 实现性能飞跃,如今已更新至 PHP 8.2,持续为 WordPress、Facebook、Wikipedia 等大型项目提供动力。PHP 的发展历程,不仅是一部技术演进史,更映射了互联网时代的变迁。
367 8
|
6月前
|
机器学习/深度学习 数据采集 算法
【风电功率预测】【多变量输入单步预测】基于RVM-Adaboost的风电功率预测研究(Matlab代码实现)
【风电功率预测】【多变量输入单步预测】基于RVM-Adaboost的风电功率预测研究(Matlab代码实现)
369 129
|
7月前
|
Ubuntu Linux
计算机基础知识:linux系统怎么安装?
在虚拟机软件中创建一个新的虚拟机,并选择相应操作系统类型和硬盘空间大小等参数。将下载的 ISO 镜像文件加载到虚拟机中。启动虚拟机,进入安装界面,并按照步骤进行安装。安装完成后,可以在虚拟机中使用 Linux 系统。
|
6月前
|
人工智能 监控 安全
智慧工地平台的核心功能有哪些?
智慧工地依托物联网、AI与大数据,集成人员、安全、环保、质量全流程智能管理,实现施工全过程数字化、可视化与风险预控,提升效率、保障安全、推动绿色建造。
368 2

热门文章

最新文章