微服务技术栈——生产环境发布管理

简介: 本文介绍大型团队中多环境发布流程及自动化部署方案。涵盖DEV、TEST、PRE、PROD各环境职责,并对比Linux原生、Jenkins+K8S自动化部署模式,以及基于Skywalking的日志排查实践,提升发布效率与系统稳定性。

前言

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

每个环境做什么

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

DEV:也叫开发环境

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

TEST:也叫测试环境

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

PRE:也叫灰度环境

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

PROD:也叫生产环境

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

如何回答相关问题

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,我输入进去就可以看到完整的调用链路和报错的堆栈信息,然后就可以分析报错原因并修复了

相关文章
|
1天前
|
存储 NoSQL 关系型数据库
MongoDB相关概念
MongoDB是一款高性能、无模式的文档型数据库,适用于社交、游戏、物流、物联网等高并发、大数据量场景。它以BSON格式存储数据,支持灵活的数据模型、丰富的查询及水平扩展,尤其适合对事务要求不高但需高效读写的应用。
MongoDB相关概念
|
1天前
|
存储 弹性计算 网络安全
阿里云新手必看:2026年云服务器购买全流程与配置选型指南
对阿里云新手来说,选云服务器不用追求高配置,核心是 “匹配需求、控制成本、简化操作”,重点关注 “选购买路径、配核心参数、搭基础环境” 这三方面。下面结合实操经验,给新手梳理清晰的选型框架,帮大家快速选到合适的服务器。
|
1天前
|
XML 移动开发 前端开发
HTML基础强化
HTML是网页的结构基础,类似文档框架,通过标签构建内容结构。Web标准由结构(HTML/XHTML)、表现(CSS)和行为(DOM/ECMAScript)三部分组成,强调三者分离。W3C规范要求代码语义化、标签闭合、命名规范。HTML5新增语义标签如header、nav、article等,提升可读性与SEO。布局方式多样,支持多种元素分类与嵌套规则。
|
1天前
|
存储 数据可视化 BI
什么是CMS系统
本文介绍 CMS 系统的定义、五大核心作用,并举 PageAdmin、ECreator 低代码平台、QuickSSO 统一身份认证平台三例,说明其在各类网站搭建与企业数字化管理中的应用。
|
1天前
|
数据采集 存储 Web App开发
Redis 在定时增量爬虫中的去重机制与过期策略
Redis 在定时增量爬虫中的去重机制与过期策略
|
1天前
【Azure App Service】App Service 遇见 not enough space on the disk
App Service应用提示“磁盘空间不足”时,可通过PowerShell脚本快速统计c:\home和c:\local目录下各文件夹大小,定位大文件并删除,释放空间。
|
1天前
|
运维 安全 开发工具
微服务技术栈—生产环境缺陷管理
针对大型团队中多分支开发导致的bug管理难题,我们基于go-git开发了通用化工具git-poison,实现分布式源码级bug追溯与防控。通过“投毒-解毒-银针”机制,自动化识别bug影响范围,避免漏修复、重复故障等问题,已成功集成至发布平台,显著提升发布安全与协作效率。
|
1天前
|
机器学习/深度学习 监控 算法
基于深度学习的车牌识别系统
在智能交通快速发展背景下,传统车牌识别技术受限于复杂环境,难以满足高精度需求。深度学习凭借强大特征学习能力,显著提升识别准确率与鲁棒性,成为主流技术方向。本文综述基于YOLOv8等先进模型的研究进展,探讨系统实现关键步骤,推动智慧交通与城市治理智能化升级。

热门文章

最新文章