@eggjs/schedule 5.0.0
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/LICENSE +21 -0
- package/README.md +313 -0
- package/dist/commonjs/agent.d.ts +7 -0
- package/dist/commonjs/agent.js +32 -0
- package/dist/commonjs/app/extend/agent.d.ts +2 -0
- package/dist/commonjs/app/extend/agent.js +29 -0
- package/dist/commonjs/app/extend/application.d.ts +2 -0
- package/dist/commonjs/app/extend/application.js +16 -0
- package/dist/commonjs/app.d.ts +6 -0
- package/dist/commonjs/app.js +131 -0
- package/dist/commonjs/config/config.default.d.ts +2 -0
- package/dist/commonjs/config/config.default.js +17 -0
- package/dist/commonjs/index.d.ts +1 -0
- package/dist/commonjs/index.js +18 -0
- package/dist/commonjs/lib/load_schedule.d.ts +3 -0
- package/dist/commonjs/lib/load_schedule.js +71 -0
- package/dist/commonjs/lib/schedule.d.ts +31 -0
- package/dist/commonjs/lib/schedule.js +89 -0
- package/dist/commonjs/lib/schedule_worker.d.ts +10 -0
- package/dist/commonjs/lib/schedule_worker.js +22 -0
- package/dist/commonjs/lib/strategy/all.d.ts +4 -0
- package/dist/commonjs/lib/strategy/all.js +11 -0
- package/dist/commonjs/lib/strategy/base.d.ts +30 -0
- package/dist/commonjs/lib/strategy/base.js +79 -0
- package/dist/commonjs/lib/strategy/timer.d.ts +20 -0
- package/dist/commonjs/lib/strategy/timer.js +99 -0
- package/dist/commonjs/lib/strategy/worker.d.ts +4 -0
- package/dist/commonjs/lib/strategy/worker.js +11 -0
- package/dist/commonjs/lib/types.d.ts +53 -0
- package/dist/commonjs/lib/types.js +3 -0
- package/dist/commonjs/package.json +3 -0
- package/dist/esm/agent.d.ts +7 -0
- package/dist/esm/agent.js +29 -0
- package/dist/esm/app/extend/agent.d.ts +2 -0
- package/dist/esm/app/extend/agent.js +27 -0
- package/dist/esm/app/extend/application.d.ts +2 -0
- package/dist/esm/app/extend/application.js +14 -0
- package/dist/esm/app.d.ts +6 -0
- package/dist/esm/app.js +125 -0
- package/dist/esm/config/config.default.d.ts +2 -0
- package/dist/esm/config/config.default.js +15 -0
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/lib/load_schedule.d.ts +3 -0
- package/dist/esm/lib/load_schedule.js +65 -0
- package/dist/esm/lib/schedule.d.ts +31 -0
- package/dist/esm/lib/schedule.js +85 -0
- package/dist/esm/lib/schedule_worker.d.ts +10 -0
- package/dist/esm/lib/schedule_worker.js +18 -0
- package/dist/esm/lib/strategy/all.d.ts +4 -0
- package/dist/esm/lib/strategy/all.js +7 -0
- package/dist/esm/lib/strategy/base.d.ts +30 -0
- package/dist/esm/lib/strategy/base.js +75 -0
- package/dist/esm/lib/strategy/timer.d.ts +20 -0
- package/dist/esm/lib/strategy/timer.js +92 -0
- package/dist/esm/lib/strategy/worker.d.ts +4 -0
- package/dist/esm/lib/strategy/worker.js +7 -0
- package/dist/esm/lib/types.d.ts +53 -0
- package/dist/esm/lib/types.js +2 -0
- package/dist/esm/package.json +3 -0
- package/dist/package.json +4 -0
- package/package.json +91 -0
- package/src/agent.ts +36 -0
- package/src/app/extend/agent.ts +30 -0
- package/src/app/extend/application.ts +16 -0
- package/src/app.ts +142 -0
- package/src/config/config.default.ts +17 -0
- package/src/index.ts +1 -0
- package/src/lib/load_schedule.ts +74 -0
- package/src/lib/schedule.ts +100 -0
- package/src/lib/schedule_worker.ts +24 -0
- package/src/lib/strategy/all.ts +7 -0
- package/src/lib/strategy/base.ts +91 -0
- package/src/lib/strategy/timer.ts +106 -0
- package/src/lib/strategy/worker.ts +7 -0
- package/src/lib/types.ts +58 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2017-present Alibaba Group Holding Limited and other contributors.
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
package/README.md
ADDED
|
@@ -0,0 +1,313 @@
|
|
|
1
|
+
# @eggjs/schedule
|
|
2
|
+
|
|
3
|
+
[![NPM version][npm-image]][npm-url]
|
|
4
|
+
[](https://github.com/eggjs/egg-schedule/actions/workflows/nodejs.yml)
|
|
5
|
+
[![Test coverage][codecov-image]][codecov-url]
|
|
6
|
+
[![Known Vulnerabilities][snyk-image]][snyk-url]
|
|
7
|
+
[![npm download][download-image]][download-url]
|
|
8
|
+
[](https://nodejs.org/en/download/)
|
|
9
|
+
|
|
10
|
+
[npm-image]: https://img.shields.io/npm/v/@eggjs/schedule.svg?style=flat-square
|
|
11
|
+
[npm-url]: https://npmjs.org/package/@eggjs/schedule
|
|
12
|
+
[codecov-image]: https://codecov.io/github/eggjs/egg-schedule/coverage.svg?branch=master
|
|
13
|
+
[codecov-url]: https://codecov.io/github/eggjs/egg-schedule?branch=master
|
|
14
|
+
[snyk-image]: https://snyk.io/test/npm/@eggjs/schedule/badge.svg?style=flat-square
|
|
15
|
+
[snyk-url]: https://snyk.io/test/npm/@eggjs/schedule
|
|
16
|
+
[download-image]: https://img.shields.io/npm/dm/@eggjs/schedule.svg?style=flat-square
|
|
17
|
+
[download-url]: https://npmjs.org/package/@eggjs/schedule
|
|
18
|
+
|
|
19
|
+
A schedule plugin for egg, has been built-in plugin for egg enabled by default.
|
|
20
|
+
|
|
21
|
+
It's fully extendable for a developer and provides a simple built-in TimerStrategy.
|
|
22
|
+
|
|
23
|
+
## Usage
|
|
24
|
+
|
|
25
|
+
Just add your job file to `{baseDir}/app/schedule`.
|
|
26
|
+
|
|
27
|
+
```ts
|
|
28
|
+
// {baseDir}/app/schedule/cleandb.ts
|
|
29
|
+
import { Subscription } from 'egg';
|
|
30
|
+
|
|
31
|
+
export default class CleanDB extends Subscription {
|
|
32
|
+
/**
|
|
33
|
+
* @property {Object} schedule
|
|
34
|
+
* - {String} type - schedule type, `worker` or `all` or your custom types.
|
|
35
|
+
* - {String} [cron] - cron expression, see [below](#cron-style-scheduling)
|
|
36
|
+
* - {Object} [cronOptions] - cron options, see [cron-parser#options](https://github.com/harrisiirak/cron-parser#options)
|
|
37
|
+
* - {String | Number} [interval] - interval expression in millisecond or express explicitly like '1h'. see [below](#interval-style-scheduling)
|
|
38
|
+
* - {Boolean} [immediate] - To run a scheduler at startup
|
|
39
|
+
* - {Boolean} [disable] - whether to disable a scheduler, usually use in dynamic schedule
|
|
40
|
+
* - {Array} [env] - only enable scheduler when match env list
|
|
41
|
+
*/
|
|
42
|
+
static get schedule() {
|
|
43
|
+
return {
|
|
44
|
+
type: 'worker',
|
|
45
|
+
cron: '0 0 3 * * *',
|
|
46
|
+
// interval: '1h',
|
|
47
|
+
// immediate: true,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
async subscribe() {
|
|
52
|
+
await this.ctx.service.db.cleandb();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
You can also use function simply like:
|
|
58
|
+
|
|
59
|
+
```ts
|
|
60
|
+
import { EggContext } from 'egg';
|
|
61
|
+
|
|
62
|
+
export const schedule = {
|
|
63
|
+
type: 'worker',
|
|
64
|
+
cron: '0 0 3 * * *',
|
|
65
|
+
// interval: '1h',
|
|
66
|
+
// immediate: true,
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export async function task(ctx: EggContext) {
|
|
70
|
+
await ctx.service.db.cleandb();
|
|
71
|
+
}
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
## Overview
|
|
75
|
+
|
|
76
|
+
`@eggjs/schedule` supports both cron-based scheduling and interval-based scheduling.
|
|
77
|
+
|
|
78
|
+
Schedule decision is being made by `agent` process. `agent` triggers a task and sends a message to `worker` process. Then, one or all `worker` process(es) execute the task based on schedule type.
|
|
79
|
+
|
|
80
|
+
To setup a schedule task, simply create a job file in `{app_root}/app/schedule`. A file contains one job and exports `schedule` and `task` properties.
|
|
81
|
+
|
|
82
|
+
The rule of thumbs is one job per file.
|
|
83
|
+
|
|
84
|
+
## Task
|
|
85
|
+
|
|
86
|
+
Task is a class which will be instantiated with every schedule, and a `subscribe` method will be invoked.
|
|
87
|
+
|
|
88
|
+
You can get anonymous context with `this.ctx`.
|
|
89
|
+
|
|
90
|
+
- ctx.method: `SCHEDULE`
|
|
91
|
+
- ctx.path: `/__schedule?path=${schedulePath}&${schedule}`.
|
|
92
|
+
|
|
93
|
+
To create a task, `subscribe` can be a generator function or async function. For example:
|
|
94
|
+
|
|
95
|
+
```ts
|
|
96
|
+
// A simple logger example
|
|
97
|
+
import { Subscription } from 'egg';
|
|
98
|
+
|
|
99
|
+
export default class LoggerExample extends Subscription {
|
|
100
|
+
async subscribe() {
|
|
101
|
+
this.ctx.logger.info('Info about your task');
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
```ts
|
|
107
|
+
// A real world example: wipe out your database.
|
|
108
|
+
// Use it with caution. :)
|
|
109
|
+
import { Subscription } from 'egg';
|
|
110
|
+
|
|
111
|
+
export default class CleanDB extends Subscription {
|
|
112
|
+
async subscribe() {
|
|
113
|
+
await this.ctx.service.db.cleandb();
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
## Scheduling
|
|
119
|
+
|
|
120
|
+
`schedule` is an object that contains one required property, `type`, and optional properties, `{ cron, cronOptions, interval, immediate, disable, env }`.
|
|
121
|
+
|
|
122
|
+
### Cron-style Scheduling
|
|
123
|
+
|
|
124
|
+
Use [cron-parser](https://github.com/harrisiirak/cron-parser).
|
|
125
|
+
|
|
126
|
+
> Note: `cron-parser` support `second` as optional that is not supported by linux crontab.
|
|
127
|
+
>
|
|
128
|
+
> `@hourly / @daily / @weekly / @monthly / @yearly` is also supported.
|
|
129
|
+
|
|
130
|
+
```bash
|
|
131
|
+
* * * * * *
|
|
132
|
+
┬ ┬ ┬ ┬ ┬ ┬
|
|
133
|
+
│ │ │ │ │ |
|
|
134
|
+
│ │ │ │ │ └ day of week (0 - 7) (0 or 7 is Sun)
|
|
135
|
+
│ │ │ │ └───── month (1 - 12)
|
|
136
|
+
│ │ │ └────────── day of month (1 - 31)
|
|
137
|
+
│ │ └─────────────── hour (0 - 23)
|
|
138
|
+
│ └──────────────────── minute (0 - 59)
|
|
139
|
+
└───────────────────────── second (0 - 59, optional)
|
|
140
|
+
```
|
|
141
|
+
|
|
142
|
+
Example:
|
|
143
|
+
|
|
144
|
+
```ts
|
|
145
|
+
// To execute task every 3 hours
|
|
146
|
+
export const schedule = {
|
|
147
|
+
type: 'worker',
|
|
148
|
+
cron: '0 0 */3 * * *',
|
|
149
|
+
cronOptions: {
|
|
150
|
+
// tz: 'Europe/Athens',
|
|
151
|
+
},
|
|
152
|
+
};
|
|
153
|
+
```
|
|
154
|
+
|
|
155
|
+
### Interval-style Scheduling
|
|
156
|
+
|
|
157
|
+
To use `setInterval`, and support [ms](https://www.npmjs.com/package/ms) conversion style
|
|
158
|
+
|
|
159
|
+
Example:
|
|
160
|
+
|
|
161
|
+
```ts
|
|
162
|
+
// To execute task every 3 hours
|
|
163
|
+
export const schedule = {
|
|
164
|
+
type: 'worker',
|
|
165
|
+
interval: '3h',
|
|
166
|
+
};
|
|
167
|
+
```
|
|
168
|
+
|
|
169
|
+
**Notice: Egg built-in TimerStrategy will schedule each execution at a fix rate, regardless of its execution time. So you have to make sure that your actual execution time of your `task/subscribe` must be smaller than your delay time.**
|
|
170
|
+
|
|
171
|
+
### Schedule Type
|
|
172
|
+
|
|
173
|
+
**Build-in support is:**
|
|
174
|
+
|
|
175
|
+
- `worker`: will be executed in one random worker when a schedule runs.
|
|
176
|
+
- `all`: will be executed in all workers when a schedule runs.
|
|
177
|
+
|
|
178
|
+
**Custom schedule:**
|
|
179
|
+
|
|
180
|
+
To create a custom schedule, simply extend `agent.ScheduleStrategy` and register it by `agent.schedule.use(type, clz)`.
|
|
181
|
+
You can schedule the task to be executed by one random worker or all workers with
|
|
182
|
+
the built-in method `this.sendOne(...args)` or `this.sendAll(...args)` which support params,
|
|
183
|
+
it will pass to `subscribe(...args)` or `task(ctx, ...args)`.
|
|
184
|
+
|
|
185
|
+
```ts
|
|
186
|
+
// {baseDir}/agent.ts
|
|
187
|
+
import { Agent } from 'egg';
|
|
188
|
+
|
|
189
|
+
export default (agent: Agent) => {
|
|
190
|
+
class CustomStrategy extends agent.ScheduleStrategy {
|
|
191
|
+
start() {
|
|
192
|
+
// such as mq / redis subscribe
|
|
193
|
+
agent.notify.subscribe('remote_task', data => {
|
|
194
|
+
this.sendOne(data);
|
|
195
|
+
});
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
agent.schedule.use('custom', CustomStrategy);
|
|
200
|
+
}
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
Then you could use it to defined your job:
|
|
204
|
+
|
|
205
|
+
```ts
|
|
206
|
+
// {baseDir}/app/schedule/other.ts
|
|
207
|
+
import { Subscription } from 'egg';
|
|
208
|
+
|
|
209
|
+
export default class ClusterTask extends Subscription {
|
|
210
|
+
static get schedule() {
|
|
211
|
+
return {
|
|
212
|
+
type: 'custom',
|
|
213
|
+
};
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
async subscribe(data) {
|
|
217
|
+
console.log('got custom data:', data);
|
|
218
|
+
await this.ctx.service.someTask.run();
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
```
|
|
222
|
+
|
|
223
|
+
## Dynamic schedule
|
|
224
|
+
|
|
225
|
+
```ts
|
|
226
|
+
// {baseDir}/app/schedule/sync.ts
|
|
227
|
+
import { Application } from 'egg';
|
|
228
|
+
|
|
229
|
+
export default (app: Application) => {
|
|
230
|
+
class SyncTask extends app.Subscription {
|
|
231
|
+
static get schedule() {
|
|
232
|
+
return {
|
|
233
|
+
interval: 10000,
|
|
234
|
+
type: 'worker',
|
|
235
|
+
// only start task when hostname match
|
|
236
|
+
disable: require('os').hostname() !== app.config.sync.hostname,
|
|
237
|
+
// only start task at prod mode
|
|
238
|
+
env: [ 'prod' ],
|
|
239
|
+
};
|
|
240
|
+
}
|
|
241
|
+
|
|
242
|
+
async subscribe() {
|
|
243
|
+
await this.ctx.sync();
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
return SyncTask;
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
## Configuration
|
|
252
|
+
|
|
253
|
+
### Logging
|
|
254
|
+
|
|
255
|
+
See `${appInfo.root}/logs/{app_name}/egg-schedule.log` which provided by [config.customLogger.scheduleLogger](https://github.com/eggjs/egg-schedule/blob/master/config/config.default.ts).
|
|
256
|
+
|
|
257
|
+
```ts
|
|
258
|
+
// config/config.default.ts
|
|
259
|
+
import { EggAppConfig } from 'egg';
|
|
260
|
+
|
|
261
|
+
export default {
|
|
262
|
+
customLogger: {
|
|
263
|
+
scheduleLogger: {
|
|
264
|
+
// consoleLevel: 'NONE',
|
|
265
|
+
// file: path.join(appInfo.root, 'logs', appInfo.name, 'egg-schedule.log'),
|
|
266
|
+
},
|
|
267
|
+
},
|
|
268
|
+
} as Partial<EggAppConfig>;
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
### Customize directory
|
|
272
|
+
|
|
273
|
+
If you want to add additional schedule directories, you can use this config.
|
|
274
|
+
|
|
275
|
+
```ts
|
|
276
|
+
// config/config.default.ts
|
|
277
|
+
import { EggAppConfig } from 'egg';
|
|
278
|
+
|
|
279
|
+
export default {
|
|
280
|
+
schedule: {
|
|
281
|
+
directory: [
|
|
282
|
+
'path/to/otherSchedule',
|
|
283
|
+
],
|
|
284
|
+
},
|
|
285
|
+
} as Partial<EggAppConfig>;
|
|
286
|
+
```
|
|
287
|
+
|
|
288
|
+
## Testing
|
|
289
|
+
|
|
290
|
+
`app.runSchedule(scheduleName)` is provided by `@eggjs/schedule` plugin only for test purpose.
|
|
291
|
+
|
|
292
|
+
Example:
|
|
293
|
+
|
|
294
|
+
```ts
|
|
295
|
+
it('test a schedule task', async () => {
|
|
296
|
+
// get app instance
|
|
297
|
+
await app.runSchedule('clean_cache');
|
|
298
|
+
});
|
|
299
|
+
```
|
|
300
|
+
|
|
301
|
+
## Questions & Suggestions
|
|
302
|
+
|
|
303
|
+
Please open an issue [here](https://github.com/eggjs/egg/issues).
|
|
304
|
+
|
|
305
|
+
## License
|
|
306
|
+
|
|
307
|
+
[MIT](https://github.com/eggjs/egg-schedule/blob/master/LICENSE)
|
|
308
|
+
|
|
309
|
+
## Contributors
|
|
310
|
+
|
|
311
|
+
[](https://github.com/eggjs/egg-schedule/graphs/contributors)
|
|
312
|
+
|
|
313
|
+
Made with [contributors-img](https://contrib.rocks).
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const node_util_1 = require("node:util");
|
|
4
|
+
const worker_js_1 = require("./lib/strategy/worker.js");
|
|
5
|
+
const all_js_1 = require("./lib/strategy/all.js");
|
|
6
|
+
const debug = (0, node_util_1.debuglog)('@eggjs/schedule/agent');
|
|
7
|
+
class Boot {
|
|
8
|
+
#agent;
|
|
9
|
+
constructor(agent) {
|
|
10
|
+
this.#agent = agent;
|
|
11
|
+
}
|
|
12
|
+
async didLoad() {
|
|
13
|
+
// register built-in strategy
|
|
14
|
+
this.#agent.schedule.use('worker', worker_js_1.WorkerStrategy);
|
|
15
|
+
this.#agent.schedule.use('all', all_js_1.AllStrategy);
|
|
16
|
+
// wait for other plugin to register custom strategy
|
|
17
|
+
await this.#agent.schedule.init();
|
|
18
|
+
// dispatch job finish event to strategy
|
|
19
|
+
this.#agent.messenger.on('egg-schedule', (info) => {
|
|
20
|
+
// get job info from worker
|
|
21
|
+
this.#agent.schedule.onJobFinish(info);
|
|
22
|
+
});
|
|
23
|
+
debug('didLoad');
|
|
24
|
+
}
|
|
25
|
+
async serverDidReady() {
|
|
26
|
+
// start schedule after worker ready
|
|
27
|
+
this.#agent.schedule.start();
|
|
28
|
+
debug('serverDidReady, schedule start');
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
exports.default = Boot;
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWdlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSx5Q0FBcUM7QUFFckMsd0RBQTBEO0FBQzFELGtEQUFvRDtBQUdwRCxNQUFNLEtBQUssR0FBRyxJQUFBLG9CQUFRLEVBQUMsdUJBQXVCLENBQUMsQ0FBQztBQUVoRCxNQUFxQixJQUFJO0lBQ3ZCLE1BQU0sQ0FBUTtJQUNkLFlBQVksS0FBWTtRQUN0QixJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztJQUN0QixDQUFDO0lBRUQsS0FBSyxDQUFDLE9BQU87UUFDWCw2QkFBNkI7UUFDN0IsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSwwQkFBYyxDQUFDLENBQUM7UUFDbkQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxvQkFBVyxDQUFDLENBQUM7UUFFN0Msb0RBQW9EO1FBQ3BELE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFFbEMsd0NBQXdDO1FBQ3hDLElBQUksQ0FBQyxNQUFNLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxJQUF3QixFQUFFLEVBQUU7WUFDcEUsMkJBQTJCO1lBQzNCLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6QyxDQUFDLENBQUMsQ0FBQztRQUNILEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUNuQixDQUFDO0lBRUQsS0FBSyxDQUFDLGNBQWM7UUFDbEIsb0NBQW9DO1FBQ3BDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzdCLEtBQUssQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO0lBQzFDLENBQUM7Q0FDRjtBQTNCRCx1QkEyQkMifQ==
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const base_js_1 = require("../../lib/strategy/base.js");
|
|
4
|
+
const timer_js_1 = require("../../lib/strategy/timer.js");
|
|
5
|
+
const schedule_js_1 = require("../../lib/schedule.js");
|
|
6
|
+
const SCHEDULE = Symbol('agent#schedule');
|
|
7
|
+
exports.default = {
|
|
8
|
+
/**
|
|
9
|
+
* @member agent#ScheduleStrategy
|
|
10
|
+
*/
|
|
11
|
+
ScheduleStrategy: base_js_1.BaseStrategy,
|
|
12
|
+
/**
|
|
13
|
+
* @member agent#TimerScheduleStrategy
|
|
14
|
+
*/
|
|
15
|
+
TimerScheduleStrategy: timer_js_1.TimerStrategy,
|
|
16
|
+
/**
|
|
17
|
+
* @member agent#schedule
|
|
18
|
+
*/
|
|
19
|
+
get schedule() {
|
|
20
|
+
if (!this[SCHEDULE]) {
|
|
21
|
+
this[SCHEDULE] = new schedule_js_1.Schedule(this);
|
|
22
|
+
this.lifecycle.registerBeforeClose(() => {
|
|
23
|
+
return this[SCHEDULE].close();
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
return this[SCHEDULE];
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWdlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hZ2VudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHdEQUEwRDtBQUMxRCwwREFBNEQ7QUFDNUQsdURBQWlEO0FBRWpELE1BQU0sUUFBUSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBRTFDLGtCQUFlO0lBQ2I7O09BRUc7SUFDSCxnQkFBZ0IsRUFBRSxzQkFBWTtJQUU5Qjs7T0FFRztJQUNILHFCQUFxQixFQUFFLHdCQUFhO0lBRXBDOztPQUVHO0lBQ0gsSUFBSSxRQUFRO1FBQ1YsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxJQUFJLHNCQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDcEMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLEVBQUU7Z0JBQ3RDLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1lBQ2hDLENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3hCLENBQUM7Q0FDSyxDQUFDIn0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const schedule_worker_js_1 = require("../../lib/schedule_worker.js");
|
|
4
|
+
const SCHEDULE_WORKER = Symbol('application#scheduleWorker');
|
|
5
|
+
exports.default = {
|
|
6
|
+
/**
|
|
7
|
+
* @member app#schedule
|
|
8
|
+
*/
|
|
9
|
+
get scheduleWorker() {
|
|
10
|
+
if (!this[SCHEDULE_WORKER]) {
|
|
11
|
+
this[SCHEDULE_WORKER] = new schedule_worker_js_1.ScheduleWorker(this);
|
|
12
|
+
}
|
|
13
|
+
return this[SCHEDULE_WORKER];
|
|
14
|
+
},
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwbGljYXRpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2V4dGVuZC9hcHBsaWNhdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLHFFQUE4RDtBQUU5RCxNQUFNLGVBQWUsR0FBRyxNQUFNLENBQUMsNEJBQTRCLENBQUMsQ0FBQztBQUU3RCxrQkFBZTtJQUNiOztPQUVHO0lBQ0gsSUFBSSxjQUFjO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEVBQUUsQ0FBQztZQUMzQixJQUFJLENBQUMsZUFBZSxDQUFDLEdBQUcsSUFBSSxtQ0FBYyxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ25ELENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztJQUMvQixDQUFDO0NBQ0ssQ0FBQyJ9
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const node_util_1 = require("node:util");
|
|
7
|
+
const node_path_1 = __importDefault(require("node:path"));
|
|
8
|
+
const utils_1 = require("@eggjs/utils");
|
|
9
|
+
const debug = (0, node_util_1.debuglog)('@eggjs/schedule/app');
|
|
10
|
+
class Boot {
|
|
11
|
+
#app;
|
|
12
|
+
#logger;
|
|
13
|
+
constructor(app) {
|
|
14
|
+
this.#app = app;
|
|
15
|
+
this.#logger = app.getLogger('scheduleLogger');
|
|
16
|
+
}
|
|
17
|
+
async didLoad() {
|
|
18
|
+
const scheduleWorker = this.#app.scheduleWorker;
|
|
19
|
+
await scheduleWorker.init();
|
|
20
|
+
// log schedule list
|
|
21
|
+
for (const s in scheduleWorker.scheduleItems) {
|
|
22
|
+
const schedule = scheduleWorker.scheduleItems[s];
|
|
23
|
+
if (!schedule.schedule.disable) {
|
|
24
|
+
this.#logger.info('[@eggjs/schedule]: register schedule %s', schedule.key);
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
// register schedule event
|
|
28
|
+
this.#app.messenger.on('egg-schedule', async (info) => {
|
|
29
|
+
debug('app got "egg-schedule" message: %o', info);
|
|
30
|
+
const { id, key } = info;
|
|
31
|
+
this.#logger.debug(`[Job#${id}] ${key} await app ready`);
|
|
32
|
+
await this.#app.ready();
|
|
33
|
+
const schedule = scheduleWorker.scheduleItems[key];
|
|
34
|
+
this.#logger.debug(`[Job#${id}] ${key} task received by app`);
|
|
35
|
+
if (!schedule) {
|
|
36
|
+
this.#logger.warn(`[Job#${id}] ${key} unknown task`);
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
/* istanbul ignore next */
|
|
40
|
+
if (schedule.schedule.disable) {
|
|
41
|
+
this.#logger.warn(`[Job#${id}] ${key} disable`);
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
this.#logger.info(`[Job#${id}] ${key} executing by app`);
|
|
45
|
+
// run with anonymous context
|
|
46
|
+
const ctx = this.#app.createAnonymousContext({
|
|
47
|
+
method: 'SCHEDULE',
|
|
48
|
+
url: `/__schedule?path=${key}&${schedule.scheduleQueryString}`,
|
|
49
|
+
});
|
|
50
|
+
const start = Date.now();
|
|
51
|
+
let success;
|
|
52
|
+
let e;
|
|
53
|
+
try {
|
|
54
|
+
// execute
|
|
55
|
+
await this.#app.ctxStorage.run(ctx, async () => {
|
|
56
|
+
return await schedule.task(ctx, ...info.args);
|
|
57
|
+
});
|
|
58
|
+
success = true;
|
|
59
|
+
}
|
|
60
|
+
catch (err) {
|
|
61
|
+
success = false;
|
|
62
|
+
e = err;
|
|
63
|
+
}
|
|
64
|
+
const rt = Date.now() - start;
|
|
65
|
+
const msg = `[Job#${id}] ${key} execute ${success ? 'succeed' : 'failed'}, used ${rt}ms.`;
|
|
66
|
+
if (success) {
|
|
67
|
+
this.#logger.info(msg);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.#logger.error(msg, e);
|
|
71
|
+
}
|
|
72
|
+
// notify agent job finish
|
|
73
|
+
this.#app.messenger.sendToAgent('egg-schedule', {
|
|
74
|
+
...info,
|
|
75
|
+
success,
|
|
76
|
+
workerId: process.pid,
|
|
77
|
+
rt,
|
|
78
|
+
message: e?.message,
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
// for test purpose
|
|
82
|
+
const config = this.#app.config;
|
|
83
|
+
const directory = [
|
|
84
|
+
node_path_1.default.join(config.baseDir, 'app/schedule'),
|
|
85
|
+
...config.schedule.directory,
|
|
86
|
+
];
|
|
87
|
+
const runSchedule = async (schedulePath, ...args) => {
|
|
88
|
+
debug('[runSchedule] start schedulePath: %o, args: %o', schedulePath, args);
|
|
89
|
+
// resolve real path
|
|
90
|
+
if (node_path_1.default.isAbsolute(schedulePath)) {
|
|
91
|
+
schedulePath = (0, utils_1.importResolve)(schedulePath);
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
for (const dir of directory) {
|
|
95
|
+
const trySchedulePath = node_path_1.default.join(dir, schedulePath);
|
|
96
|
+
try {
|
|
97
|
+
schedulePath = (0, utils_1.importResolve)(trySchedulePath);
|
|
98
|
+
break;
|
|
99
|
+
}
|
|
100
|
+
catch (err) {
|
|
101
|
+
debug('[runSchedule] importResolve %o error: %s', trySchedulePath, err);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
debug('[runSchedule] resolve schedulePath: %o', schedulePath);
|
|
106
|
+
let schedule;
|
|
107
|
+
try {
|
|
108
|
+
schedule = scheduleWorker.scheduleItems[schedulePath];
|
|
109
|
+
if (!schedule) {
|
|
110
|
+
throw new Error(`Cannot find schedule ${schedulePath}`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
catch (err) {
|
|
114
|
+
err.message = `[@eggjs/schedule] ${err.message}`;
|
|
115
|
+
throw err;
|
|
116
|
+
}
|
|
117
|
+
// run with anonymous context
|
|
118
|
+
const ctx = this.#app.createAnonymousContext({
|
|
119
|
+
method: 'SCHEDULE',
|
|
120
|
+
url: `/__schedule?path=${schedulePath}&${schedule.scheduleQueryString}`,
|
|
121
|
+
});
|
|
122
|
+
return await this.#app.ctxStorage.run(ctx, async () => {
|
|
123
|
+
return await schedule.task(ctx, ...args);
|
|
124
|
+
});
|
|
125
|
+
};
|
|
126
|
+
Reflect.set(this.#app, 'runSchedule', runSchedule);
|
|
127
|
+
debug('didLoad');
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
exports.default = Boot;
|
|
131
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwcC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLHlDQUFxQztBQUNyQywwREFBNkI7QUFJN0Isd0NBQTZDO0FBRzdDLE1BQU0sS0FBSyxHQUFHLElBQUEsb0JBQVEsRUFBQyxxQkFBcUIsQ0FBQyxDQUFDO0FBRTlDLE1BQXFCLElBQUk7SUFDdkIsSUFBSSxDQUFjO0lBQ2xCLE9BQU8sQ0FBWTtJQUNuQixZQUFZLEdBQWdCO1FBQzFCLElBQUksQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDO1FBQ2hCLElBQUksQ0FBQyxPQUFPLEdBQUcsR0FBRyxDQUFDLFNBQVMsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0lBQ2pELENBQUM7SUFFRCxLQUFLLENBQUMsT0FBTztRQUNYLE1BQU0sY0FBYyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDO1FBQ2hELE1BQU0sY0FBYyxDQUFDLElBQUksRUFBRSxDQUFDO1FBRTVCLG9CQUFvQjtRQUNwQixLQUFLLE1BQU0sQ0FBQyxJQUFJLGNBQWMsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUM3QyxNQUFNLFFBQVEsR0FBRyxjQUFjLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2pELElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLE9BQU8sRUFBRSxDQUFDO2dCQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyx5Q0FBeUMsRUFBRSxRQUFRLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDN0UsQ0FBQztRQUNILENBQUM7UUFFRCwwQkFBMEI7UUFDMUIsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLGNBQWMsRUFBRSxLQUFLLEVBQUMsSUFBSSxFQUFDLEVBQUU7WUFDbEQsS0FBSyxDQUFDLG9DQUFvQyxFQUFFLElBQUksQ0FBQyxDQUFDO1lBQ2xELE1BQU0sRUFBRSxFQUFF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
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.default = () => {
|
|
4
|
+
const config = {};
|
|
5
|
+
config.customLogger = {
|
|
6
|
+
scheduleLogger: {
|
|
7
|
+
consoleLevel: 'NONE',
|
|
8
|
+
file: 'egg-schedule.log',
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
config.schedule = {
|
|
12
|
+
// custom additional directory, full path
|
|
13
|
+
directory: [],
|
|
14
|
+
};
|
|
15
|
+
return config;
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmRlZmF1bHQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29uZmlnL2NvbmZpZy5kZWZhdWx0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsa0JBQWUsR0FBRyxFQUFFO0lBQ2xCLE1BQU0sTUFBTSxHQUFHLEVBQXlCLENBQUM7SUFFekMsTUFBTSxDQUFDLFlBQVksR0FBRztRQUNwQixjQUFjLEVBQUU7WUFDZCxZQUFZLEVBQUUsTUFBTTtZQUNwQixJQUFJLEVBQUUsa0JBQWtCO1NBQ3pCO0tBQ0YsQ0FBQztJQUVGLE1BQU0sQ0FBQyxRQUFRLEdBQUc7UUFDaEIseUNBQXlDO1FBQ3pDLFNBQVMsRUFBRSxFQUFFO0tBQ2QsQ0FBQztJQUVGLE9BQU8sTUFBTSxDQUFDO0FBQ2hCLENBQUMsQ0FBQyJ9
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './lib/types.js';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./lib/types.js"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGlEQUErQiJ9
|