前端处理API接口故障:多接口自动切换的实现方案

因为在开发APP,一个接口如果不通(被挂了)又不能改了重新打包让用户再下载软件更新,所以避免这种情况,跟后端讨论多备用接口地址自动切换的方案,自动切换到备用的接口地址,并保证后续所有的请求都使用当前可用的接口地址,以供参考(非必要可以不使用)

其实这种会出现很多问题,当不同的用户访问的服务器地址不一样,而每个服务器的数据又不完全同步。所以后端方案是数据库统一,负载均衡。

解决方案思路:
  1. 接口地址列表:维护一个接口地址列表,当请求失败时,依次尝试备用地址。
  2. 全局可用接口地址:一旦找到一个可用的接口地址,所有后续请求都会使用该地址,直到它不可用时再进行切换。
  3. 持久化存储:使用本地存储将当前可用的接口地址存储起来,避免页面刷新后重新从第一个接口地址开始尝试
javascript 复制代码
// 维护当前可用的接口地址,使用本地存储持久化
let currentInterfaceUrl = uni.getStorageSync('currentInterfaceUrl') || 'http://192.168.0.165:8889/platform-api/app/';
const interfaceUrls = [
    'http://192.168.0.165:8889/platform-api/app/', 
    'http://192.168.0.166:8889/platform-api/app/', 
    'http://192.168.0.167:8889/platform-api/app/'
];

// 通用的请求方法
function request(url, postData = {}, method = "GET", contentType = "application/json") {
    return new Promise((resolve, reject) => {
        function tryRequest(attempt) {
            if (attempt >= interfaceUrls.length) {
                reject('所有接口地址均不可用');
                return;
            }

            let currentUrl = interfaceUrls[attempt];
            uni.request({
                url: currentUrl + url,
                data: postData,
                header: {
                    'content-type': contentType,
                    'token': uni.getStorageSync('token') // 获取token
                },
                method: method,
                success: (res) => {
                    if (res.statusCode === 200) {
                        // 更新全局接口地址
                        if (currentInterfaceUrl !== currentUrl) {
                            currentInterfaceUrl = currentUrl;
                            uni.setStorageSync('currentInterfaceUrl', currentInterfaceUrl);
                        }
                        resolve(res.data);
                    } else {
                        reject(res.data.msg);
                    }
                },
                fail: () => {
                    console.log('当前接口地址不可用,尝试下一个地址...');
                    tryRequest(attempt + 1);  // 尝试下一个接口地址
                }
            });
        }

        // 从当前可用的接口地址开始请求
        let attempt = interfaceUrls.indexOf(currentInterfaceUrl);
        tryRequest(attempt);
    });
}
相关推荐
啥都不懂的小小白9 小时前
Vue第四篇:组件通信 + DOM 更新 + 过渡动画
vue.js·全局事件通信
向下的大树9 小时前
VUE父子组件传参中的触发时机问题:异步场景下的解决方案
前端·javascript·vue.js
英俊潇洒美少年9 小时前
vue2中使用节流防抖函数时,使用的vue状态始终是初始化的数据
前端·javascript·vue.js
棒棒的唐9 小时前
适合小程序使用的将对象数组转换为参数字符串方法
前端·javascript·小程序
刘一说10 小时前
Vue3响应式原理重构:从Object.defineProperty到Proxy的革命性升级
javascript·vue.js·重构
博客zhu虎康10 小时前
音频视频处理:前端直播流播放 flv
前端
一位搞嵌入式的 genius10 小时前
深入理解 JavaScript 原型与继承:从基础到进阶
开发语言·前端·javascript
董世昌4110 小时前
深度解析var、let、const的区别与最佳使用场景
开发语言·前端·javascript
C_心欲无痕10 小时前
Next.js 平行路由:构建模块化动态布局
开发语言·前端·javascript
warrah10 小时前
前端项目容器化部署问题
前端·docker