@eggjs/schedule 5.0.2 → 6.0.0-beta.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -12
- package/dist/agent.d.ts +13 -0
- package/dist/agent.js +32 -0
- package/dist/app/extend/agent.d.ts +22 -0
- package/dist/app/extend/agent.js +32 -0
- package/dist/app/extend/application.d.ts +16 -0
- package/dist/app/extend/application.js +18 -0
- package/dist/app/extend/application.unittest.d.ts +13 -0
- package/dist/app/extend/application.unittest.js +46 -0
- package/dist/app.d.ts +11 -0
- package/dist/app.js +69 -0
- package/dist/config/config.default.d.ts +6 -0
- package/dist/config/config.default.js +13 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +7 -0
- package/dist/lib/load_schedule.d.ts +7 -0
- package/dist/lib/load_schedule.js +61 -0
- package/dist/lib/schedule.d.ts +35 -0
- package/dist/lib/schedule.js +77 -0
- package/dist/lib/schedule_worker.d.ts +14 -0
- package/dist/lib/schedule_worker.js +22 -0
- package/dist/lib/strategy/all.d.ts +8 -0
- package/dist/lib/strategy/all.js +11 -0
- package/dist/lib/strategy/base.d.ts +35 -0
- package/dist/lib/strategy/base.js +73 -0
- package/dist/lib/strategy/timer.d.ts +24 -0
- package/dist/lib/strategy/timer.js +71 -0
- package/dist/lib/strategy/worker.d.ts +8 -0
- package/dist/lib/strategy/worker.js +11 -0
- package/dist/lib/types.d.ts +44 -0
- package/dist/lib/types.js +1 -0
- package/package.json +51 -55
- package/dist/commonjs/agent.d.ts +0 -7
- package/dist/commonjs/agent.js +0 -32
- package/dist/commonjs/app/extend/agent.d.ts +0 -2
- package/dist/commonjs/app/extend/agent.js +0 -29
- package/dist/commonjs/app/extend/application.d.ts +0 -2
- package/dist/commonjs/app/extend/application.js +0 -16
- package/dist/commonjs/app/extend/application.unittest.d.ts +0 -2
- package/dist/commonjs/app/extend/application.unittest.js +0 -58
- package/dist/commonjs/app.d.ts +0 -6
- package/dist/commonjs/app.js +0 -80
- package/dist/commonjs/config/config.default.d.ts +0 -2
- package/dist/commonjs/config/config.default.js +0 -17
- package/dist/commonjs/index.d.ts +0 -1
- package/dist/commonjs/index.js +0 -18
- package/dist/commonjs/lib/load_schedule.d.ts +0 -3
- package/dist/commonjs/lib/load_schedule.js +0 -71
- package/dist/commonjs/lib/schedule.d.ts +0 -31
- package/dist/commonjs/lib/schedule.js +0 -89
- package/dist/commonjs/lib/schedule_worker.d.ts +0 -10
- package/dist/commonjs/lib/schedule_worker.js +0 -22
- package/dist/commonjs/lib/strategy/all.d.ts +0 -4
- package/dist/commonjs/lib/strategy/all.js +0 -11
- package/dist/commonjs/lib/strategy/base.d.ts +0 -30
- package/dist/commonjs/lib/strategy/base.js +0 -79
- package/dist/commonjs/lib/strategy/timer.d.ts +0 -20
- package/dist/commonjs/lib/strategy/timer.js +0 -99
- package/dist/commonjs/lib/strategy/worker.d.ts +0 -4
- package/dist/commonjs/lib/strategy/worker.js +0 -11
- package/dist/commonjs/lib/types.d.ts +0 -53
- package/dist/commonjs/lib/types.js +0 -3
- package/dist/commonjs/package.json +0 -3
- package/dist/esm/agent.d.ts +0 -7
- package/dist/esm/agent.js +0 -29
- package/dist/esm/app/extend/agent.d.ts +0 -2
- package/dist/esm/app/extend/agent.js +0 -27
- package/dist/esm/app/extend/application.d.ts +0 -2
- package/dist/esm/app/extend/application.js +0 -14
- package/dist/esm/app/extend/application.unittest.d.ts +0 -2
- package/dist/esm/app/extend/application.unittest.js +0 -53
- package/dist/esm/app.d.ts +0 -6
- package/dist/esm/app.js +0 -77
- package/dist/esm/config/config.default.d.ts +0 -2
- package/dist/esm/config/config.default.js +0 -15
- package/dist/esm/index.d.ts +0 -1
- package/dist/esm/index.js +0 -2
- package/dist/esm/lib/load_schedule.d.ts +0 -3
- package/dist/esm/lib/load_schedule.js +0 -65
- package/dist/esm/lib/schedule.d.ts +0 -31
- package/dist/esm/lib/schedule.js +0 -85
- package/dist/esm/lib/schedule_worker.d.ts +0 -10
- package/dist/esm/lib/schedule_worker.js +0 -18
- package/dist/esm/lib/strategy/all.d.ts +0 -4
- package/dist/esm/lib/strategy/all.js +0 -7
- package/dist/esm/lib/strategy/base.d.ts +0 -30
- package/dist/esm/lib/strategy/base.js +0 -75
- package/dist/esm/lib/strategy/timer.d.ts +0 -20
- package/dist/esm/lib/strategy/timer.js +0 -92
- package/dist/esm/lib/strategy/worker.d.ts +0 -4
- package/dist/esm/lib/strategy/worker.js +0 -7
- package/dist/esm/lib/types.d.ts +0 -53
- package/dist/esm/lib/types.js +0 -2
- package/dist/esm/package.json +0 -3
- package/dist/package.json +0 -4
- package/src/agent.ts +0 -36
- package/src/app/extend/agent.ts +0 -30
- package/src/app/extend/application.ts +0 -16
- package/src/app/extend/application.unittest.ts +0 -57
- package/src/app.ts +0 -92
- package/src/config/config.default.ts +0 -17
- package/src/index.ts +0 -1
- package/src/lib/load_schedule.ts +0 -74
- package/src/lib/schedule.ts +0 -100
- package/src/lib/schedule_worker.ts +0 -24
- package/src/lib/strategy/all.ts +0 -7
- package/src/lib/strategy/base.ts +0 -91
- package/src/lib/strategy/timer.ts +0 -107
- package/src/lib/strategy/worker.ts +0 -7
- package/src/lib/types.ts +0 -58
package/src/lib/strategy/base.ts
DELETED
|
@@ -1,91 +0,0 @@
|
|
|
1
|
-
import type { Agent, EggLogger } from 'egg';
|
|
2
|
-
import type { EggScheduleConfig, EggScheduleJobInfo } from '../types.js';
|
|
3
|
-
|
|
4
|
-
export class BaseStrategy {
|
|
5
|
-
protected agent: Agent;
|
|
6
|
-
protected scheduleConfig: EggScheduleConfig;
|
|
7
|
-
protected key: string;
|
|
8
|
-
protected logger: EggLogger;
|
|
9
|
-
protected closed = false;
|
|
10
|
-
count = 0;
|
|
11
|
-
|
|
12
|
-
constructor(scheduleConfig: EggScheduleConfig, agent: Agent, key: string) {
|
|
13
|
-
this.agent = agent;
|
|
14
|
-
this.key = key;
|
|
15
|
-
this.scheduleConfig = scheduleConfig;
|
|
16
|
-
this.logger = this.agent.getLogger('scheduleLogger');
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
/** keep compatibility */
|
|
20
|
-
get schedule(): EggScheduleConfig {
|
|
21
|
-
return this.scheduleConfig;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
start() {
|
|
25
|
-
// empty loop by default
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
close() {
|
|
29
|
-
this.closed = true;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
33
|
-
onJobStart(_info: EggScheduleJobInfo) {}
|
|
34
|
-
|
|
35
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
36
|
-
onJobFinish(_info: EggScheduleJobInfo) {}
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* trigger one worker
|
|
40
|
-
*
|
|
41
|
-
* @param {...any} args - pass to job task
|
|
42
|
-
*/
|
|
43
|
-
sendOne(...args: any[]) {
|
|
44
|
-
/* istanbul ignore next */
|
|
45
|
-
if (this.agent.schedule.closed) {
|
|
46
|
-
this.logger.warn(`${this.key} skip due to schedule closed`);
|
|
47
|
-
return;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
this.count++;
|
|
51
|
-
|
|
52
|
-
const info = {
|
|
53
|
-
key: this.key,
|
|
54
|
-
id: this.getSeqId(),
|
|
55
|
-
args,
|
|
56
|
-
} as EggScheduleJobInfo;
|
|
57
|
-
|
|
58
|
-
this.logger.info(`[Job#${info.id}] ${info.key} triggered, send random by agent`);
|
|
59
|
-
this.agent.messenger.sendRandom('egg-schedule', info);
|
|
60
|
-
this.onJobStart(info);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* trigger all worker
|
|
65
|
-
*
|
|
66
|
-
* @param {...any} args - pass to job task
|
|
67
|
-
*/
|
|
68
|
-
sendAll(...args: any[]) {
|
|
69
|
-
/* istanbul ignore next */
|
|
70
|
-
if (this.agent.schedule.closed) {
|
|
71
|
-
this.logger.warn(`${this.key} skip due to schedule closed`);
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
this.count++;
|
|
76
|
-
|
|
77
|
-
const info = {
|
|
78
|
-
key: this.key,
|
|
79
|
-
id: this.getSeqId(),
|
|
80
|
-
args,
|
|
81
|
-
} as EggScheduleJobInfo;
|
|
82
|
-
this.logger.info(`[Job#${info.id}] ${info.key} triggered, send all by agent`);
|
|
83
|
-
// send to all workers
|
|
84
|
-
this.agent.messenger.send('egg-schedule', info);
|
|
85
|
-
this.onJobStart(info);
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
getSeqId() {
|
|
89
|
-
return `${Date.now()}${process.hrtime().join('')}${this.count}`;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import assert from 'node:assert';
|
|
2
|
-
import type { CronExpression } from 'cron-parser';
|
|
3
|
-
import cronParser from 'cron-parser';
|
|
4
|
-
import { ms } from 'humanize-ms';
|
|
5
|
-
import safeTimers from 'safe-timers';
|
|
6
|
-
import { logDate } from 'utility';
|
|
7
|
-
import type { Agent } from 'egg';
|
|
8
|
-
import type { EggScheduleConfig } from '../types.js';
|
|
9
|
-
import { BaseStrategy } from './base.js';
|
|
10
|
-
|
|
11
|
-
export abstract class TimerStrategy extends BaseStrategy {
|
|
12
|
-
protected cronInstance?: CronExpression;
|
|
13
|
-
|
|
14
|
-
constructor(scheduleConfig: EggScheduleConfig, agent: Agent, key: string) {
|
|
15
|
-
super(scheduleConfig, agent, key);
|
|
16
|
-
|
|
17
|
-
const { interval, cron, cronOptions, immediate } = this.scheduleConfig;
|
|
18
|
-
assert(interval || cron || immediate,
|
|
19
|
-
`[@eggjs/schedule] ${this.key} \`schedule.interval\` or \`schedule.cron\` or \`schedule.immediate\` must be present`);
|
|
20
|
-
|
|
21
|
-
// init cron parser
|
|
22
|
-
if (cron) {
|
|
23
|
-
try {
|
|
24
|
-
this.cronInstance = cronParser.parseExpression(cron, cronOptions);
|
|
25
|
-
} catch (err: any) {
|
|
26
|
-
throw new TypeError(
|
|
27
|
-
`[@eggjs/schedule] ${this.key} parse cron instruction(${cron}) error: ${err.message}`,
|
|
28
|
-
{ cause: err });
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
protected handler() {
|
|
34
|
-
throw new TypeError(`[@eggjs/schedule] ${this.key} strategy should override \`handler()\` method`);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
start() {
|
|
39
|
-
/* istanbul ignore next */
|
|
40
|
-
if (this.agent.schedule.closed) return;
|
|
41
|
-
|
|
42
|
-
if (this.scheduleConfig.immediate) {
|
|
43
|
-
this.logger.info(`[Timer] ${this.key} next time will execute immediate`);
|
|
44
|
-
setImmediate(() => this.handler());
|
|
45
|
-
} else {
|
|
46
|
-
this.#scheduleNext();
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
#scheduleNext() {
|
|
51
|
-
/* istanbul ignore next */
|
|
52
|
-
if (this.agent.schedule.closed) return;
|
|
53
|
-
|
|
54
|
-
// get next tick
|
|
55
|
-
const nextTick = this.getNextTick();
|
|
56
|
-
if (nextTick) {
|
|
57
|
-
this.logger.info(
|
|
58
|
-
`[Timer] ${this.key} next time will execute after ${nextTick}ms at ${logDate(new Date(Date.now() + nextTick))}`);
|
|
59
|
-
this.safeTimeout(() => this.handler(), nextTick);
|
|
60
|
-
} else {
|
|
61
|
-
this.logger.info(`[Timer] ${this.key} reach endDate, will stop`);
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
onJobStart() {
|
|
66
|
-
// Next execution will trigger task at a fix rate, regardless of its execution time.
|
|
67
|
-
this.#scheduleNext();
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
/**
|
|
71
|
-
* calculate next tick
|
|
72
|
-
*
|
|
73
|
-
* @return {Number|undefined} time interval, if out of range then return `undefined`
|
|
74
|
-
*/
|
|
75
|
-
protected getNextTick(): number | undefined {
|
|
76
|
-
// interval-style
|
|
77
|
-
if (this.scheduleConfig.interval) {
|
|
78
|
-
return ms(this.scheduleConfig.interval);
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
// cron-style
|
|
82
|
-
if (this.cronInstance) {
|
|
83
|
-
// calculate next cron tick
|
|
84
|
-
const now = Date.now();
|
|
85
|
-
let nextTick: number;
|
|
86
|
-
|
|
87
|
-
// loop to find next feature time
|
|
88
|
-
do {
|
|
89
|
-
try {
|
|
90
|
-
const nextInterval = this.cronInstance.next();
|
|
91
|
-
nextTick = nextInterval.getTime();
|
|
92
|
-
} catch (err) {
|
|
93
|
-
// Error: Out of the timespan range
|
|
94
|
-
this.logger.info(`[Timer] ${this.key} cron out of the timespan range, error: %s`, err);
|
|
95
|
-
return;
|
|
96
|
-
}
|
|
97
|
-
} while (now >= nextTick);
|
|
98
|
-
return nextTick - now;
|
|
99
|
-
}
|
|
100
|
-
// won\'t run here
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
protected safeTimeout(handler: () => void, delay: number, ...args: any[]) {
|
|
104
|
-
const fn = delay < safeTimers.maxInterval ? setTimeout : safeTimers.setTimeout;
|
|
105
|
-
return fn(handler, delay, ...args);
|
|
106
|
-
}
|
|
107
|
-
}
|
package/src/lib/types.ts
DELETED
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
import type { ParserOptions as CronOptions } from 'cron-parser';
|
|
2
|
-
import type { Schedule } from './schedule.js';
|
|
3
|
-
import type { ScheduleWorker } from './schedule_worker.js';
|
|
4
|
-
|
|
5
|
-
/**
|
|
6
|
-
* Schedule Config
|
|
7
|
-
* @see https://www.eggjs.org/zh-CN/basics/schedule
|
|
8
|
-
*/
|
|
9
|
-
export interface EggScheduleConfig {
|
|
10
|
-
type?: 'worker' | 'all';
|
|
11
|
-
interval?: string | number;
|
|
12
|
-
cron?: string;
|
|
13
|
-
cronOptions?: CronOptions;
|
|
14
|
-
immediate?: boolean;
|
|
15
|
-
disable?: boolean;
|
|
16
|
-
env?: string[];
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export type EggScheduleTask = (ctx: any, ...args: any[]) => Promise<void>;
|
|
20
|
-
|
|
21
|
-
export interface EggScheduleItem {
|
|
22
|
-
schedule: EggScheduleConfig;
|
|
23
|
-
scheduleQueryString: string;
|
|
24
|
-
task: EggScheduleTask;
|
|
25
|
-
key: string;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
export interface EggScheduleJobInfo {
|
|
29
|
-
id: string;
|
|
30
|
-
key: string;
|
|
31
|
-
workerId: number;
|
|
32
|
-
args: any[];
|
|
33
|
-
success?: boolean;
|
|
34
|
-
message?: string;
|
|
35
|
-
rt?: number;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
declare module 'egg' {
|
|
39
|
-
export interface EggScheduleAgent {
|
|
40
|
-
schedule: Schedule;
|
|
41
|
-
}
|
|
42
|
-
export interface Agent extends EggScheduleAgent {}
|
|
43
|
-
|
|
44
|
-
export interface EggScheduleApplication {
|
|
45
|
-
scheduleWorker: ScheduleWorker;
|
|
46
|
-
/** runSchedule in unittest */
|
|
47
|
-
runSchedule: (schedulePath: string, ...args: any[]) => Promise<void>;
|
|
48
|
-
}
|
|
49
|
-
export interface Application extends EggScheduleApplication {}
|
|
50
|
-
|
|
51
|
-
export interface EggScheduleAppConfig {
|
|
52
|
-
schedule: {
|
|
53
|
-
directory: string[];
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export interface EggAppConfig extends EggScheduleAppConfig {}
|
|
58
|
-
}
|