mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-17 08:37:59 +00:00

* feat: workflow catch error (#5220) * feat: error catch * feat: workflow catch error * perf: add catch error to node * feat: system tool error catch * catch error * fix: ts * update doc * perf: training queue code (#5232) * doc * perf: training queue code * Feat: 优化错误提示与重试逻辑 (#5192) * feat: 批量重试异常数据 & 报错信息国际化 - 新增“全部重试”按钮,支持批量重试所有训练异常数据 - 报错信息支持国际化,常见错误自动映射为 i18n key - 相关文档和 i18n 资源已同步更新 * feat: enhance error message and retry mechanism * feat: enhance error message and retry mechanism * feat: add retry_failed i18n key * feat: enhance error message and retry mechanism * feat: enhance error message and retry mechanism * feat: enhance error message and retry mechanism : 5 * feat: enhance error message and retry mechanism : 6 * feat: enhance error message and retry mechanism : 7 * feat: enhance error message and retry mechanism : 8 * perf: catch chat error * perf: copy hook (#5246) * perf: copy hook * doc * doc * add app evaluation (#5083) * add app evaluation * fix * usage * variables * editing condition * var ui * isplus filter * migrate code * remove utils * name * update type * build * fix * fix * fix * delete comment * fix * perf: eval code * eval code * eval code * feat: ttfb time in model log * Refactor chat page (#5253) * feat: update side bar layout; add login and logout logic at chat page * refactor: encapsulate login logic and reuse it in `LoginModal` and `Login` page * chore: improve some logics and comments * chore: improve some logics * chore: remove redundant side effect; add translations --------- Co-authored-by: Archer <545436317@qq.com> * perf: chat page code * doc * perf: provider redirect * chore: ui improvement (#5266) * Fix: SSE * Fix: SSE * eval pagination (#5264) * eval scroll pagination * change eval list to manual pagination * number * fix build * fix * version doc (#5267) * version doc * version doc * doc * feat: eval model select * config eval model * perf: eval detail modal ui * doc * doc * fix: chat store reload * doc --------- Co-authored-by: colnii <1286949794@qq.com> Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: 酒川户 <76519998+chuanhu9@users.noreply.github.com>
90 lines
2.3 KiB
TypeScript
90 lines
2.3 KiB
TypeScript
import {
|
|
type ConnectionOptions,
|
|
type Processor,
|
|
Queue,
|
|
type QueueOptions,
|
|
Worker,
|
|
type WorkerOptions
|
|
} from 'bullmq';
|
|
import { addLog } from '../system/log';
|
|
import { newQueueRedisConnection, newWorkerRedisConnection } from '../redis';
|
|
|
|
const defaultWorkerOpts: Omit<ConnectionOptions, 'connection'> = {
|
|
removeOnComplete: {
|
|
count: 0 // Delete jobs immediately on completion
|
|
},
|
|
removeOnFail: {
|
|
count: 0 // Delete jobs immediately on failure
|
|
}
|
|
};
|
|
|
|
export enum QueueNames {
|
|
datasetSync = 'datasetSync',
|
|
evaluation = 'evaluation',
|
|
// abondoned
|
|
websiteSync = 'websiteSync'
|
|
}
|
|
|
|
export const queues = (() => {
|
|
if (!global.queues) {
|
|
global.queues = new Map<QueueNames, Queue>();
|
|
}
|
|
return global.queues;
|
|
})();
|
|
export const workers = (() => {
|
|
if (!global.workers) {
|
|
global.workers = new Map<QueueNames, Worker>();
|
|
}
|
|
return global.workers;
|
|
})();
|
|
|
|
export function getQueue<DataType, ReturnType = void>(
|
|
name: QueueNames,
|
|
opts?: Omit<QueueOptions, 'connection'>
|
|
): Queue<DataType, ReturnType> {
|
|
// check if global.queues has the queue
|
|
const queue = queues.get(name);
|
|
if (queue) {
|
|
return queue as Queue<DataType, ReturnType>;
|
|
}
|
|
const newQueue = new Queue<DataType, ReturnType>(name.toString(), {
|
|
connection: newQueueRedisConnection(),
|
|
...opts
|
|
});
|
|
|
|
// default error handler, to avoid unhandled exceptions
|
|
newQueue.on('error', (error) => {
|
|
addLog.error(`MQ Queue [${name}]: ${error.message}`, error);
|
|
});
|
|
queues.set(name, newQueue);
|
|
return newQueue;
|
|
}
|
|
|
|
export function getWorker<DataType, ReturnType = void>(
|
|
name: QueueNames,
|
|
processor: Processor<DataType, ReturnType>,
|
|
opts?: Omit<WorkerOptions, 'connection'>
|
|
): Worker<DataType, ReturnType> {
|
|
const worker = workers.get(name);
|
|
if (worker) {
|
|
return worker as Worker<DataType, ReturnType>;
|
|
}
|
|
|
|
const newWorker = new Worker<DataType, ReturnType>(name.toString(), processor, {
|
|
connection: newWorkerRedisConnection(),
|
|
...defaultWorkerOpts,
|
|
...opts
|
|
});
|
|
// default error handler, to avoid unhandled exceptions
|
|
newWorker.on('error', (error) => {
|
|
addLog.error(`MQ Worker [${name}]: ${error.message}`, error);
|
|
});
|
|
newWorker.on('failed', (jobId, error) => {
|
|
addLog.error(`MQ Worker [${name}]: ${error.message}`, error);
|
|
});
|
|
workers.set(name, newWorker);
|
|
return newWorker;
|
|
}
|
|
|
|
export * from 'bullmq';
|