当前位置: 首页 > news >正文

网站前端浏览器兼容如何做深圳全网推互联科技有限公司

网站前端浏览器兼容如何做,深圳全网推互联科技有限公司,灵芝住房和城乡建设局局网站,昆明排名seo公司背景介绍 在现代互联网应用开发中,灰度发布(又称金丝雀发布)是一种非常重要的部署策略。它允许我们将新版本服务逐步推送给部分用户,而不是一次性全量发布,从而降低风险并快速获得用户反馈。本文将分享一个实际的灰度…

背景介绍

在现代互联网应用开发中,灰度发布(又称金丝雀发布)是一种非常重要的部署策略。它允许我们将新版本服务逐步推送给部分用户,而不是一次性全量发布,从而降低风险并快速获得用户反馈。本文将分享一个实际的灰度环境部署案例,涉及两个服务(fbdm和grayfbdm)共享同一数据库但运行不同代码的场景。
**目前场景:**用于线上功能和需求验证,防止全量上线验证出问题,减少回滚的概率。

某业务系统中存在两个核心后端服务:

  • fbdm:正式服务,面向所有用户;
  • grayfbdm:灰度服务,仅对测试或特定用户开放。

两者数据库一致,配置相同,仅代码版本不同。灰度发布前必须先完成数据库字段变更,以保证向前兼容。
在这里插入图片描述

前端页面通过不同的访问地址与 Header 标签来区分灰度与正式流量。

访问角色访问域名Header 特征Nginx 路由目标
测试用户gray.example.comappenv=graygrayfbdm
正式用户prod.example.com无灰度标签fbdm

灰度环境请求需满足下列任一条件,即可命中 grayfbdm

  • 请求 Header 包含 appenv=gray
  • URL 参数中包含 appEnv=gray 或灰度域名作为 returnUrl
  • Origin 为灰度域名。

系统架构概述

基本系统包含以下关键组件:

  1. 两个后端服务
    • fbdm:生产环境服务
    • grayfbdm:灰度环境服务
  2. 共享数据库:两个服务使用相同的数据库实例
  3. 前端H5应用:能够通过header标识请求来源
  4. Nginx反向代理:负责根据规则将请求路由到不同的后端服务

核心设计原理

1. 数据库共享策略

由于两个服务使用相同的数据库,在灰度发布过程中需要特别注意:

  • 数据库变更先行:任何涉及数据库结构的变更必须先于服务部署执行
  • 代码兼容性:新版本代码必须能够兼容旧版本的数据结构
  • 数据一致性:确保灰度环境和生产环境不会因为数据操作相互干扰

2. 流量分流机制

Nginx作为流量入口,根据多种条件将请求路由到不同的后端:

在这里插入图片描述

# 上游服务定义 
upstream fbdm {server 10.0.0.1:8081 fail_timeout=5 max_fails=2;server 10.0.0.2:8081 fail_timeout=5 max_fails=2;keepalive 2000;
}upstream grayfbdm {server 10.0.1.1:8081 fail_timeout=5 max_fails=2;keepalive 2000;
}

3. 路由判断条件

Nginx通过以下条件判断是否将请求路由到灰度环境:

  1. HTTP Header:检查appenv=gray
  2. URL参数:检查returnUrlappEnv参数
  3. Origin Header:检查请求来源是否为灰度域名
set $target http://fbdm;
if ($http_appEnv = "gray" ) {set $target http://grayfbdm;
}
if ($arg_returnUrl ~* "^https?%3A%2F%2Fmfbdgray\.xxxxx\.com" ) {set $target http://grayfbdm;
}
if ($arg_appEnv ~* "^gray" ) {set $target http://grayfbdm;
}
if ($http_origin ~* "https?://mfbdgray\.xxxxx\.com" ) {set $target http://grayfbdm;
}

4.完整Nginx配置

# 定义 upstream(正式服务 & 灰度服务)
upstream fbdm {server 10.0.0.1:8081 fail_timeout=5 max_fails=2;server 10.0.0.2:8081 fail_timeout=5 max_fails=2;keepalive 2000;
}
upstream grayfbdm {server 10.0.1.1:8081 fail_timeout=5 max_fails=2;keepalive 2000;
}# 80 端口跳转到 HTTPS
server {listen 80;server_name prod.example.com;location / {rewrite ^/(.*)$ https://$host/$1 permanent;}
}# 443 HTTPS 端口配置(灰度智能路由)
server {listen 443 ssl;server_name prod.example.com;ssl_certificate /path/to/cert.pem;ssl_certificate_key /path/to/key.pem;include ssl.conf;location / {set $target http://fbdm;# 灰度判断逻辑if ($http_appEnv = "gray") {set $target http://grayfbdm;}if ($arg_returnUrl ~* "^https?%3A%2F%2Fgray\.example\.com") {set $target http://grayfbdm;}if ($arg_appEnv ~* "^gray") {set $target http://grayfbdm;}if ($http_origin ~* "https?://gray\.example\.com") {set $target http://grayfbdm;}proxy_pass $target;include https_proxy.conf;proxy_next_upstream error timeout invalid_header http_403 http_404 http_500 http_502 http_503 http_504;# 黑名单控制(引用外部白名单/黑名单配置)include /opt/nginx/conf/whitelist/login.conf;}# 登录、发送验证码等接口灰度策略保持一致location ~* ^(/api/auth/sendCode|/api/user/login|/api/user/checkMobile)$ {set $target http://fbdm;if ($http_appEnv = "gray") {set $target http://grayfbdm;}if ($arg_returnUrl ~* "^https?%3A%2F%2Fgray\.example\.com") {set $target http://grayfbdm;}if ($arg_appEnv ~* "^gray") {set $target http://grayfbdm;}if ($http_origin ~* "https?://gray\.example\.com") {set $target http://grayfbdm;}proxy_pass $target;include https_proxy.conf;proxy_next_upstream error timeout invalid_header http_403 http_404 http_500 http_502 http_503 http_504;# 黑名单控制include /opt/nginx/conf/whitelist/mesg.conf;include /opt/nginx/conf/whitelist/login.conf;allow all;}
}
  • 灵活灰度判断:通过 Header、Query 参数与 Origin 三层判断方式,确保请求正确识别;
  • 接口隔离保护:关键接口如登录与验证码单独配置,防止因路由失误导致异常;
  • 白名单机制:通过 include 引用外部配置,统一黑白名单管理;
  • 自动 HTTPS 跳转:防止未加密请求造成信息泄露。

成功案例

在一次重大架构升级中,灰度发布机制帮助我们:

  1. 提前发现代码的bug,测试人员多轮验证,未影响正常用户
  2. 可以任何时间段发版,让测试人员测试,提升工作效率和速度

后续实践

  1. 版本兼容性:确保灰度版本代码能够回滚,避免因数据库变更导致生产环境不可用
  2. 监控与日志:为灰度环境设置独立的监控和日志收集,便于问题排查
  3. 流量比例控制:可以通过Nginx配置实现按比例的灰度发布
  4. 自动化测试:灰度环境应配备完整的自动化测试套件
  5. 用户标识策略:除了测试人员,可以考虑基于用户ID、设备ID等进行灰度分流
http://www.hkea.cn/news/365268/

相关文章:

  • 南宁网站建设制作后台网站关键词优化价格
  • 微信小程序商城制作公司宁波seo推广服务
  • 响应式购物网站公司seo是什么意思
  • 360未经证实的网站如何做电商运营方案
  • 网站建设类公司排名营销方案范文100例
  • 郑州网站设计 郑州网站开发网络优化有前途吗
  • 黑河做网站首页关键词排名优化
  • 网站二级域名怎么解析公司网络搭建
  • wordpress做网店win10优化大师是官方的吗
  • 弄个做网站公司产品宣传
  • 商品房建设信息网站googleplay商店
  • 菏泽 网站建设优化工具箱
  • 网站建设找哪家公司百度搜索热度
  • 网页设计论文引言北海百度seo
  • 网站空间哪家做的好网络营销的常用工具
  • 网站开发具体问题优化营商环境
  • wordpress4.5 火车头廊坊seo培训
  • 怎么做多个网站单点登录艺考培训
  • 网站怎么做双语种seo关键词如何设置
  • 用java做的游戏下载网站有哪些内容成都网络推广优化
  • 慈溪市网站建设google官网
  • 网站建设计划seo网站排名优化软件是什么
  • 大连网站建设谁家好郴州网站定制
  • 网站建设背景怎么写一个企业该如何进行网络营销
  • 为女朋友做的表白网站百度大数据分析工具
  • 上海高端网站建设服务公seo推广公司
  • 找人合伙做网站平台仿站定制模板建站
  • 深圳市网站建设科技公司腾讯网网站网址
  • wordpress语言文件夹seo销售好做吗
  • 河北建设集团官网西安网站seo