Files
kiss-translator/src/libs/pool.js

78 lines
1.8 KiB
JavaScript
Raw Normal View History

2023-08-20 19:27:29 +08:00
/**
* 任务池
* @param {*} fn
* @param {*} preFn
* @param {*} _interval
* @param {*} _limit
* @returns
*/
2023-08-10 11:55:40 +08:00
export const taskPool = (fn, preFn, _interval = 100, _limit = 100) => {
2023-08-04 16:05:14 +08:00
const pool = [];
const maxRetry = 2; // 最大重试次数
let maxCount = _limit; // 最大数量
let curCount = 0; // 当前数量
let interval = _interval; // 间隔时间
2023-08-11 16:48:09 +08:00
let timer = null;
2023-08-04 16:05:14 +08:00
const handleTask = async (item, preArgs) => {
curCount++;
const { args, resolve, reject, retry } = item;
try {
2023-08-10 11:55:40 +08:00
const res = await fn({ ...args, ...preArgs });
2023-08-04 16:05:14 +08:00
resolve(res);
} catch (err) {
if (retry < maxRetry) {
pool.push({ args, resolve, reject, retry: retry + 1 });
} else {
reject(err);
}
} finally {
curCount--;
}
};
2023-08-11 16:48:09 +08:00
const run = async () => {
2023-08-04 16:05:14 +08:00
// console.log("timer", timer);
2023-08-11 16:48:09 +08:00
timer && clearTimeout(timer);
timer = setTimeout(run, interval);
2023-08-04 16:05:14 +08:00
if (curCount < maxCount) {
const item = pool.shift();
if (item) {
try {
const preArgs = await preFn(item.args);
handleTask(item, preArgs);
} catch (err) {
console.log("[preFn]", err);
pool.push(item);
}
}
}
2023-08-11 16:48:09 +08:00
};
2023-08-04 16:05:14 +08:00
return {
push: async (args) => {
2023-08-11 16:48:09 +08:00
if (!timer) {
run();
}
2023-08-04 16:05:14 +08:00
return new Promise((resolve, reject) => {
pool.push({ args, resolve, reject, retry: 0 });
});
},
2023-08-06 22:31:42 +08:00
update: (_interval = 100, _limit = 100) => {
2023-08-04 16:05:14 +08:00
if (_interval >= 0 && _interval <= 5000 && _interval !== interval) {
interval = _interval;
}
if (_limit >= 1 && _limit <= 100 && _limit !== maxCount) {
maxCount = _limit;
}
},
clear: () => {
pool.length = 0;
curCount = 0;
timer && clearTimeout(timer);
2023-08-11 16:48:09 +08:00
timer = null;
2023-08-04 16:05:14 +08:00
},
};
};