news 2026/3/3 20:50:22

业务环境流程:开发->测试->预发布->灰度->生产

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
业务环境流程:开发->测试->预发布->灰度->生产
dev → test → staging → gray → prod

环境 = 同一套代码,在不同运行条件下的不同实例

目的:

  1. 保护线上用户
  2. 降低开发和发布风险
  3. 让问题尽量提前暴露

本地环境 dev

开发者电脑上的运行环境

通过 npm / yarn 等打开开发服务器

用于 写代码、调试,可以debugger,打印控制台、打断点

在构建方面:不压缩、不混淆

测试环境 test

由于本地环境的差异大(Node版本、依赖),只有在自己电脑能跑

所以得有一个过渡-测试环境:模拟线上环境,但不对真实用户开放的环境

部署在服务器上,使用独立域名,接近线上的配置

例如

text.example.com

进行

  • 前后端联调
  • 功能测试
  • 回归测试
  • QA测试
  • UAT 产品验收
VITE_API_BASE=https://test-api.example.com
if (import.meta.env.MODE === 'test') { enableDebugPanel(); }
本地测试
localhost真实域名
mock 接口真后端
无 Nginx有 Nginx
无 CDN有 CDN
HTTPHTTPS

预发布环境 staging

上线前最后一次、最接近真实线上环境的验证环境

一般是内部人员的真实数据(test是QA和研发,现在是其他例如产品等)

域名、环境等等都和 prod 一样

灰度 gray

新功能、新版本并不会一次性全量上线,而是只对一部分用户或环境先生效,观察效果稳定后再逐步扩大范围,最终全量发布

小范围试水 → 验证安全 → 再全面放开

  • :旧版本(完全没变)
  • :新版本(全部用户都用)
  • :介于两者之间

作用

  • 降低发布风险
  • 验证真实用户行为:本地/测试环境都不是真实用户
  • 支持快速回滚:只需要关闭灰度开关或把比例调回到0

如何实现

  1. 按「用户」灰度

常见方式:

  • 按 userId 哈希取模
  • 按账号白名单
  • 按新用户 / 老用户
**userId** % 100 < 5 → 5% 用户走新逻辑
  1. 按「流量」灰度(网关/Nginx
  • 10% 请求 → 新服务
  • 90% 请求 → 旧服务
split_clients $request_id $version { 10% new; * old; }
  1. 功能开关(Feature Flag)

是否开启由:

  • 后台配置
  • AB平台
  • 配置中心(如 Apollo / Nacos)
if (featureFlags.newPayFlow) { renderNewPay() } else { renderOldPay() }
灰度发布(金丝雀发布)安全上线
AB 测试对比效果好坏

线上环境 prod

真实用户正在使用的环境

  • 用户访问的网站
  • APP请求的接口
  • 真正产生业务数据

错误不能暴露给用户

在构建阶段会进行压缩、混淆

日志非常精简

// 线上禁止 console.log if (import.meta.env.PROD) { console.log = () => {}; }
VITE_API_BASE=https://api.example.com

不能随便进行调试、发布

徐岙发布流程 + 回滚机制

发布流程

本地环境 ↓ 测试环境(CI 自动部署) ↓ 回归测试 / 产品验收 ↓ 线上环境(灰度 / 全量)
  1. 本地 pnpm dev
  2. 提 PR → 自动部署到 test
  3. QA 验证
  4. 合并 main → CI 部署 prod(production 生产环境,用户正在真实使用的环境)

找出本地和线上的差异点

  1. 环境变量不同

.env.development 和 .env.production

如 API_BASE_URL

可以用console.log(import.meta.env)/console.log(process.env)查看

  1. 打包产物和本地运行逻辑不同

线上问题可能出现在

  • 某个函数被错误地 tree-shake 掉了
  • CDN 缓存未更新、版本不一致

解决:本地执行一次真实打包

npm run build npx serve dist
  1. 环境差异:浏览器版本

使用错误出现的环境尝试复现

Babel polyfill 补齐

  1. 网络

查看开发者工具的网络

对比 CORS 的响应头查看是否是跨域问题

对比一下 Cookie

  1. 后端的线上逻辑与本地不一致
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/3 13:51:31

21、深入解析RAC数据库的跟踪与诊断技术

深入解析RAC数据库的跟踪与诊断技术 1. 引言 在RAC(Real Application Clusters)数据库环境中,获取跟踪和诊断信息对于解决性能问题、排查故障至关重要。本文将详细介绍获取这些信息的方法,包括跟踪文件位置、DBMS_MONITOR包、ORADEBUG工具以及LKDEBUG实用程序等内容。 2…

作者头像 李华
网站建设 2026/3/3 3:38:14

【Python大数据毕设选题】基于Hadoop+Django的个人财务健康分析系统源码 毕业设计 选题推荐 毕设选题 数据分析 机器学习

✍✍计算机毕设指导师** ⭐⭐个人介绍&#xff1a;自己非常喜欢研究技术问题&#xff01;专业做Java、Python、小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目&#xff1a;有源码或者技术上的问题欢迎在评论区一起讨论交流&#xff01; ⚡⚡有什么问题可以…

作者头像 李华
网站建设 2026/3/2 18:58:19

快速掌握Faster Whisper:Whisper模型训练加速终极指南

快速掌握Faster Whisper&#xff1a;Whisper模型训练加速终极指南 【免费下载链接】faster-whisper plotly/plotly.js: 是一个用于创建交互式图形和数据可视化的 JavaScript 库。适合在需要创建交互式图形和数据可视化的网页中使用。特点是提供了一种简单、易用的 API&#xff…

作者头像 李华
网站建设 2026/3/1 12:41:50

BluetoothKit终极指南:快速构建iOS和macOS蓝牙应用

BluetoothKit终极指南&#xff1a;快速构建iOS和macOS蓝牙应用 【免费下载链接】BluetoothKit 项目地址: https://gitcode.com/gh_mirrors/blu/BluetoothKit 想要在iOS和macOS平台上快速开发强大的蓝牙应用吗&#xff1f;BluetoothKit正是你需要的终极解决方案&#xf…

作者头像 李华
网站建设 2026/3/3 13:51:35

游戏深度魔法:Flame引擎视差滚动技术的实战解析

游戏深度魔法&#xff1a;Flame引擎视差滚动技术的实战解析 【免费下载链接】flame 项目地址: https://gitcode.com/gh_mirrors/fla/flame 在2D游戏开发的世界里&#xff0c;有一个能够瞬间提升游戏品质的"魔法"——视差滚动技术。这种看似简单的视觉效果&am…

作者头像 李华
网站建设 2026/3/3 13:51:36

Nevergrad无梯度优化:5个简单步骤掌握终极优化工具

Nevergrad无梯度优化&#xff1a;5个简单步骤掌握终极优化工具 【免费下载链接】nevergrad 项目地址: https://gitcode.com/gh_mirrors/ne/nevergrad Nevergrad是一个功能强大的无梯度优化平台&#xff0c;专门为解决传统梯度方法难以处理的复杂优化问题而设计。无论你…

作者头像 李华