当前位置:首页 > 科技  > 软件

我们一起聊聊前端接口容灾

来源: 责编: 时间:2023-11-30 09:29:28 303观看
导读开篇你说,万一接口挂了会怎么样?还能咋样,白屏呗。有没有不白屏的方案?有啊,还挺简单的。容我细细细细分析。原因就是接口挂了,拿不到数据了。那把数据储存起来就可以解决问题。思考存哪里?第一时间反应浏览器本地存储,想起

开篇

你说,万一接口挂了会怎么样?QkH28资讯网——每日最新资讯28at.com

还能咋样,白屏呗。QkH28资讯网——每日最新资讯28at.com

有没有不白屏的方案?QkH28资讯网——每日最新资讯28at.com

有啊,还挺简单的。QkH28资讯网——每日最新资讯28at.com

容我细细细细分析。QkH28资讯网——每日最新资讯28at.com

原因就是接口挂了,拿不到数据了。那把数据储存起来就可以解决问题。QkH28资讯网——每日最新资讯28at.com

思考

存哪里?

第一时间反应浏览器本地存储,想起了四兄弟。QkH28资讯网——每日最新资讯28at.com

选型对比

特性
QkH28资讯网——每日最新资讯28at.com

cookie
QkH28资讯网——每日最新资讯28at.com

localStorage
QkH28资讯网——每日最新资讯28at.com

sessionStorage
QkH28资讯网——每日最新资讯28at.com

indexDB
QkH28资讯网——每日最新资讯28at.com

数据生命周期
QkH28资讯网——每日最新资讯28at.com

服务器或者客户端都可以设置、有过期时间
QkH28资讯网——每日最新资讯28at.com

一直存在
QkH28资讯网——每日最新资讯28at.com

关闭页面就清空
QkH28资讯网——每日最新资讯28at.com

一直存在
QkH28资讯网——每日最新资讯28at.com

数据储存大小
QkH28资讯网——每日最新资讯28at.com

4KB
QkH28资讯网——每日最新资讯28at.com

5MB
QkH28资讯网——每日最新资讯28at.com

5MB
QkH28资讯网——每日最新资讯28at.com

动态,很大
QkH28资讯网——每日最新资讯28at.com

大于250MB
QkH28资讯网——每日最新资讯28at.com

与服务器通信
QkH28资讯网——每日最新资讯28at.com

每次都带在header中
QkH28资讯网——每日最新资讯28at.com

不带
QkH28资讯网——每日最新资讯28at.com

不带
QkH28资讯网——每日最新资讯28at.com

不带
QkH28资讯网——每日最新资讯28at.com

兼容性
QkH28资讯网——每日最新资讯28at.com

都支持
QkH28资讯网——每日最新资讯28at.com

都支持
QkH28资讯网——每日最新资讯28at.com

都支持
QkH28资讯网——每日最新资讯28at.com

IE不支持,其他主流都支持
QkH28资讯网——每日最新资讯28at.com

考虑到需要存储的数据量,5MB 一定不够的,所以选择了 IndexDB。QkH28资讯网——每日最新资讯28at.com

考虑新用户或者长时间未访问老用户,会取不到缓存数据与陈旧的数据。QkH28资讯网——每日最新资讯28at.com

因此准备上云,用阿里云存储,用 CDN 来保障。QkH28资讯网——每日最新资讯28at.com

总结下:线上 CDN、线下 IndexDB。QkH28资讯网——每日最新资讯28at.com

整体方案

整体流程图

图片图片QkH28资讯网——每日最新资讯28at.com

CDN

先讲讲线上 CDN。QkH28资讯网——每日最新资讯28at.com

通常情况下可以让后端支撑,本质就是更新策略问题,这里不细说。QkH28资讯网——每日最新资讯28at.com

我们讲讲另外一种方案,单独启个 Node 服务更新 CDN 数据。QkH28资讯网——每日最新资讯28at.com

流程图

图片图片QkH28资讯网——每日最新资讯28at.com

劫持逻辑

劫持所有接口,判断接口状态与缓存标识。从而进行更新数据、获取数据、缓存策略三种操作QkH28资讯网——每日最新资讯28at.com

通过配置白名单来控制接口存与取QkH28资讯网——每日最新资讯28at.com

axios.interceptors.response.use(      async (resp) => {        const { config } = resp        const { url } = config        // 是否有缓存tag,用于更新CDN数据。目前是定时服务在跑,访问页面带上tag        if (this.hasCdnTag() && this.isWhiteApi(url)) {          this.updateCDN(config, resp)        }        return resp;      },      async (err) => {        const { config } = err        const { url } = config        // 是否命中缓存策略        if (this.isWhiteApi(url) && this.useCache()) {          return this.fetchCDN(config).then(res => {            pushLog(`cdn缓存数据已命中,请处理`, SentryTypeEnum.error)            return res          }).catch(()=>{           pushLog(`cdn缓存数据未同步,请处理`, SentryTypeEnum.error)          })        }      }    );

缓存策略

累计接口异常发生 maxCount 次,打开缓存开关,expiresSeconds 秒后关闭。QkH28资讯网——每日最新资讯28at.com

缓存开关用避免网络波动导致命中缓存,设置了阀值。QkH28资讯网——每日最新资讯28at.com

/** 缓存策略*/useCache = () => {  if (this.expiresStamp > +new Date()) {    const d = new Date(this.expiresStamp)    console.warn(`    ---------------------------------------    ---------------------------------------    启用缓存中    关闭时间:${d.getHours()}:${d.getMinutes()}:${d.getSeconds()}    ---------------------------------------    ---------------------------------------    `)    return true  }  this.errorCount += 1  localStorage.setItem(CACHE_ERROR_COUNT_KEY, `${this.errorCount}`)  if (this.errorCount > this.maxCount) {    this.expiresStamp = +new Date() + this.expiresSeconds * 1000    this.errorCount = 0    localStorage.setItem(CACHE_EXPIRES_KEY, `${this.expiresStamp}`)    localStorage.removeItem(CACHE_ERROR_COUNT_KEY)    return true  }  return false}

唯一标识

根据 method、url、data 三者来标识接口,保证接口的唯一性QkH28资讯网——每日最新资讯28at.com

带动态标识,譬如时间戳等可以手动过滤QkH28资讯网——每日最新资讯28at.com

/** * 生成接口唯一键值*/generateCacheKey = (config) => {  // 请求方式,参数,请求地址,  const { method, url, data, params } = config;  let rawData = ''  if (method === 'get') {    rawData = params  }  if (method === 'post') {    rawData = JSON.parse(data)  }  // 返回拼接key  return `${encodeURIComponent([method, url, stringify(rawData)].join('_'))}.json`;};

更新数据

/** * 更新cdn缓存数据*/updateCDN = (config, data) => {  const fileName = this.generateCacheKey(config)  const cdnUrl = `${this.prefix}/${fileName}`  axios.post(`${this.nodeDomain}/cdn/update`, {    cdnUrl,    data  })}

Node定时任务

构建定时任务,用 puppeteer 去访问、带上缓存标识,去更新 CDN 数据QkH28资讯网——每日最新资讯28at.com

import schedule from 'node-schedule';const scheduleJob = {};export const xxxJob = (ctx) => {  const { xxx } = ctx.config;  ctx.logger.info(xxx, 'xxx');  const { key, url, rule } = xxx;  if (scheduleJob[key]) {    scheduleJob[key].cancel();  }  scheduleJob[key] = schedule.scheduleJob(rule, async () => {    ctx.logger.info(url, new Date());    await browserIndex(ctx, url);  });};export const browserIndex = async (ctx, domain) => {  ctx.logger.info('browser --start', domain);  if (!domain) {    ctx.logger.error('domain为空');    return false;  }  const browser = await puppeteer.launch({    args: [      '--use-gl=egl',      '--disable-gpu',      '--no-sandbox',      '--disable-setuid-sandbox',    ],    executablePath: process.env.CHROMIUM_PATH,    headless: true,    timeout: 0,  });  const page = await browser.newPage();  await page.goto(`${domain}?${URL_CACHE_KEY}`);  await sleep(10000);  // 访问首页所有查询接口  const list = await page.$$('.po-tabs__item');  if (list?.length) {    for (let i = 0; i < list.length; i++) {      await list[i].click();    }  }  await browser.close();  ctx.logger.info('browser --finish', domain);  return true;};

效果

手动 block 整个 domain,整个页面正常展示QkH28资讯网——每日最新资讯28at.com

图片图片QkH28资讯网——每日最新资讯28at.com

IndexDB

线上有 CDN 保证了,线下就轮到 IndexDB 了,基于业务简单的增删改查,选用 localForage 三方库足矣。QkH28资讯网——每日最新资讯28at.com

axios.interceptors.response.use(      async (resp) => {        const { config } = resp        const { url } = config        // 是否有缓存tag,用于更新CDN数据。目前是定时服务在跑,访问页面带上tag        if (this.hasCdnTag() && this.isWhiteApi(url)) {          this.updateCDN(config, resp)        }        if(this.isIndexDBWhiteApi(url)){          this.updateIndexDB(config, resp)        }        return resp;      },      async (err) => {        const { config } = err        const { url } = config        // 是否命中缓存策略        if (this.isWhiteApi(url) && this.useCache()) {          return this.fetchCDN(config).then(res => {            pushLog(`cdn缓存数据已命中,请处理`, SentryTypeEnum.error)            return res          }).catch(()=>{           pushLog(`cdn缓存数据未同步,请处理`, SentryTypeEnum.error)           if(this.isIndexDBWhiteApi(url)){             return this.fetchIndexDB(config).then(res => {              pushLog(`IndexDB缓存数据已命中,请处理`, SentryTypeEnum.error)              return res            }).catch(()=>{             pushLog(`IndexDB缓存数据未同步,请处理`, SentryTypeEnum.error)            })           }          })        }      }    );

总结

总结下,优点包括不入侵业务代码,不影响现有业务,随上随用,尽可能避免前端纯白屏的场景,成本低。劣势包括使用局限,不适合对数据实效性比较高的业务场景,不支持 IE 浏览器。QkH28资讯网——每日最新资讯28at.com

接口容灾我们也是刚弄不久,有许多细节与不足,欢迎沟通交流。QkH28资讯网——每日最新资讯28at.com

接口容灾本意是预防发生接口服务挂了的场景,我们不会很被动。原来是P0的故障,能被它降低为 P2、P3,甚至在某些场景下都不会有用户反馈。QkH28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-35314-0.html我们一起聊聊前端接口容灾

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Vue 3的Teleport特性详解,你了解几分?

下一篇: 2024 年 Vue 发展预测

标签:
  • 热门焦点
  • 直屏旗舰来了 iQOO 12和K70 Pro同台竞技

    旗舰机基本上使用的都是双曲面屏幕,这就让很多喜欢直屏的爱好者在苦等一款直屏旗舰,这次,你们等到了。据博主数码闲聊站带来的最新爆料称,Redmi下代旗舰K70 Pro和iQOO 12两款手
  • Redmi Pad评测:红米充满野心的一次尝试

    从Note系列到K系列,从蓝牙耳机到笔记本电脑,红米不知不觉之间也已经形成了自己颇有竞争力的产品体系,在中端和次旗舰市场上甚至要比小米新机的表现来得更好,正所谓“大丈夫生居
  • 帅气纯真少年!日本最帅初中生选美冠军出炉

    日本第一帅哥初一生选美大赛冠军现已正式出炉,冠军是来自千叶县的宗田悠良。日本一直热衷于各种选美大赛,从&ldquo;最美JK&rdquo;起到&ldquo;最美女星&r
  • 摸鱼心法第一章——和配置文件说拜拜

    为了能摸鱼我们团队做了容器化,但是带来的问题是服务配置文件很麻烦,然后大家在群里进行了“亲切友好”的沟通图片图片图片图片对比就对比,简单对比下独立配置中心和k8s作为配
  • 2023 年的 Node.js 生态系统

    随着技术的不断演进和创新,Node.js 在 2023 年达到了一个新的高度。Node.js 拥有一个庞大的生态系统,可以帮助开发人员更快地实现复杂的应用。本文就来看看 Node.js 最新的生
  • 多线程开发带来的问题与解决方法

    使用多线程主要会带来以下几个问题:(一)线程安全问题  线程安全问题指的是在某一线程从开始访问到结束访问某一数据期间,该数据被其他的线程所修改,那么对于当前线程而言,该线程
  • Temu起诉SHEIN,跨境电商战事升级

    来源 | 伯虎财经(bohuFN)作者 | 陈平安日前据外媒报道,拼多多旗下跨境电商平台Temu正对竞争对手SHEIN提起新诉讼,诉状称Shein&ldquo;利用市场支配力量强迫服装厂商与之签订独家
  • 支持aptX Lossless无损传输 iQOO TWS 1赛道版发布限时优惠价369元

    2023年7月4日,“无损音质,声动人心”iQOO TWS 1正式发布,支持aptX Lossless无损传输,限时优惠价369元。iQOO TWS 1耳机率先支持端到端aptX Lossless无
  • 外交部:美方应停止在网络安全问题上不负责任地指责他国

      中国外交部今天(16日)举行例行记者会。会上,有记者问,美国情报官员称,他们正在阻拦来自中国以及其他国家的黑客获取相关科研成果。 中方对此有何评论?对此
Top