并发串行调用接口

简介: 这里思考比较少,不过因为事情本身比较简单,就简单处理了。毕竟我这种菜鸟,高大上的东西是从未停止过仰望的。备注下是因为如果有机会再用到类似的逻辑,可以拿来重新思考一下,另外,我还觉得有点儿TCP里”滑动窗口“的感觉喔,哈哈哈,毕竟场景类似,控制流量嘛/** * 代码块说明: 小并发串行调用接口处理大批量数据 * 依赖变量: data (原始数据) */va

这里思考比较少,不过因为事情本身比较简单,就简单处理了。毕竟我这种菜鸟,高大上的东西是从未停止过仰望的。备注下是因为如果有机会再用到类似的逻辑,可以拿来重新思考一下,另外,我还觉得有点儿TCP里”滑动窗口“的感觉喔,哈哈哈,毕竟场景类似,控制流量嘛

/** 
 * 代码块说明: 小并发串行调用接口处理大批量数据
 * 依赖变量: data (原始数据)
 */
var chunks = [],       // 数据切割存储
    size = 50,         // 数据分片大小
    concurrence = 4;   // 并发量

    /* 按数据分片大小切割原始数据 */
    while (data.length > 0){
        chunks.push(data.splice(0, size));
    }

    var batchLength = chunks.length; // 切割后数据块数量
    var steps = 0; // 游标,用于滑动读取切割后的数据块
    /**
     * 核心函数
     * 变量说明: _i (游标, 用于定位分片数据)
     *         cData (切割后的数据块数组) 
     *         len (切割后数据块数量)
     *         c (发送请求的并发量)
     */
    var batchPush = function(_i, cData, len, c){
        if (_i < len) {
            var _pulling = true; // 标识位
            var _j = 0; // 临时变量,定位并发数据块位置

            //分批请求
            while (_pulling){
                if (cData[_j + _i]){
                    $.ajax({
                        method: 'POST',
                        url: 'xxx',
                        data: JSON.stringify(cData[_j + _i]),
                        dataType: 'json',
                        success: function(rData){
                            // 接口返回码校验(此略)
                            ++steps;
                            // 并发都处理完后, 触发下一次并发(串行)
                            if (steps % c === 0) {
                                // 缓冲一秒
                                setTimeout(function(){
                                    batchPush(steps, cData, len, c);
                                }, 1000);
                            }
                            // 数据处理(此略)
                        },
                        error: function(){
                            // 异常处理(此略)
                        }
                    });
                }
                _j++;
                if (_j >= c){
                    _pulling = false;
                }
            }
        } else {
            // 全部发送完毕
            steps = 0;
        }
    };
    // 触发调用
    batchPush(steps, chunks, batchLength, concurrence);

Anyway, it works. 有机会读一读”滑动窗口”的处理逻辑, 哈哈.

目录
相关文章
|
7月前
|
JSON 程序员 数据格式
程序员必知:同步接口和异步接口
程序员必知:同步接口和异步接口
502 0
使用队列解决高并发下使用Client对象调用webService接口
使用队列解决高并发下使用Client对象调用webService接口
|
数据挖掘 API PHP
Playfab开发(一)如何调用PlayFab接口
Playfab开发(一)如何调用PlayFab接口
调用DescribeRouteTables接口
调用DescribeRouteTables接口
79 1
|
Web App开发 移动开发 JavaScript
h5调用底层接口的一些知识
h5调用底层接口的一些知识
138 0
同步调用和异步调用
同步调用和异步调用
|
Java
CheerpJ调用的两种方式
CheerpJ调用的两种方式
257 0
|
Java 测试技术
Java 线程池模拟用户并发请求接口代码示例
Java 线程池模拟用户并发请求接口代码示例
|
小程序
小程序调用接口不生效?
小程序调用接口不生效?
368 0
|
监控 Java 数据挖掘
使用 SpringAOP 获取一次请求流经方法的调用次数和调用耗时
  引语   作为工程师,不能仅仅满足于实现了现有的功能逻辑,还必须深入认识系统。一次请求,流经了哪些方法,执行了多少次DB操作,访问了多少次文件操作,调用多少次API操作,总共有多少次IO操作,多少CPU操作,各耗时多少 ? 开发者应当知道这些运行时数据,才能对系统的运行有更深入的理解,更好滴提升系统的性能和稳定性。   完成一次订单导出任务,实际上是一个比较复杂的过程:需要访问ES 来查询订单,调用批量API接口 及访问 Hbase 获取订单详情数据,格式化报表字段数据,写入和上传报表文件,更新数据库,上报日志数据等;在大流量导出的情形下,采用批量并发策略,多线程来获取订单详情数据,整
268 0