mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-16 08:01:18 +00:00

* refactor: remove ModelProviderIdType and update related types (#5549) * perf: model provider * fix eval create split (#5570) * git rebase --continuedoc * add more variable types (#5540) * variable types * password * time picker * internal var * file * fix-test * time select default value & range * password & type render * fix * fix build * fix * move method * split date select * icon * perf: variable code * prompt editor add markdown plugin (#5556) * editor markdown * fix build * pnpm lock * add props * update code * fix list * editor ui * fix variable reset (#5586) * perf: variables type code * customize lexical indent (#5588) * perf: multiple selector * perf: tab plugin * doc * refactor: update workflow constants to use ToolTypeEnum (#5491) * refactor: replace FlowNodeTemplateTypeEnum with string literals in workflow templates * perf: tool type --------- Co-authored-by: archer <545436317@qq.com> * update doc * fix: make table's row more natural while dragging it (#5596) * feat: add APIGetTemplate function and refactor template fetching logic (#5498) * feat: add APIGetTemplate function and refactor template fetching logic * chore: adjust the code * chore: update sdk --------- Co-authored-by: FinleyGe <m13203533462@163.com> * perf init system * doc * remove log * remove i18n * perf: variables render --------- Co-authored-by: Ctrlz <143257420+ctrlz526@users.noreply.github.com> Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: 伍闲犬 <whoeverimf5@gmail.com> Co-authored-by: FinleyGe <m13203533462@163.com>
42 lines
1.2 KiB
TypeScript
42 lines
1.2 KiB
TypeScript
import { getWorkerController, WorkerNameEnum } from './utils';
|
|
|
|
export const preLoadWorker = async () => {
|
|
const start = Date.now();
|
|
const max = Math.min(Number(global.systemEnv?.tokenWorkers || 30), 500);
|
|
const workerController = getWorkerController({
|
|
name: WorkerNameEnum.countGptMessagesTokens,
|
|
maxReservedThreads: max
|
|
});
|
|
|
|
// Batch size for concurrent loading
|
|
const batchSize = 5;
|
|
|
|
for (let i = 0; i < max; i += batchSize) {
|
|
const currentBatchSize = Math.min(batchSize, max - i);
|
|
const promises = [];
|
|
|
|
// Create batch of promises for concurrent loading
|
|
for (let j = 0; j < currentBatchSize; j++) {
|
|
const promise = (async () => {
|
|
const worker = workerController.createWorker();
|
|
await workerController.run({
|
|
workerId: worker.id,
|
|
messages: [
|
|
{
|
|
role: 'user',
|
|
content: '1'
|
|
}
|
|
]
|
|
});
|
|
})();
|
|
promises.push(promise);
|
|
}
|
|
|
|
// Wait for current batch to complete
|
|
await Promise.all(promises);
|
|
console.log('Preload worker', workerController.workerQueue.length);
|
|
}
|
|
|
|
console.log('Preload worker success', workerController.workerQueue.length, Date.now() - start);
|
|
};
|