schangxiang@126.com
2025-09-19 0821aa23eabe557c0d9ef5dbe6989c68be35d1fe
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
'use strict';
 
module.exports = class BaseStrategy {
  constructor(schedule, agent, key) {
    this.agent = agent;
    this.key = key;
    this.schedule = schedule;
    this.logger = this.agent.getLogger('scheduleLogger');
    this.count = 0;
  }
 
  start() {}
 
  onJobStart() {}
 
  onJobFinish() {}
 
  /**
   * trigger one worker
   *
   * @param {...any} args - pass to job task
   */
  sendOne(...args) {
    /* istanbul ignore next */
    if (this.agent.schedule.closed) {
      this.logger.warn(`${this.key} skip due to schedule closed`);
      return;
    }
 
    this.count++;
 
    const info = {
      key: this.key,
      id: this.getSeqId(),
      args,
    };
 
    this.logger.debug(`[Job#${info.id}] ${info.key} triggered, send random by agent`);
    this.agent.messenger.sendRandom('egg-schedule', info);
    this.onJobStart(info);
  }
 
  /**
   * trigger all worker
   *
   * @param {...any} args - pass to job task
   */
  sendAll(...args) {
    /* istanbul ignore next */
    if (this.agent.schedule.closed) {
      this.logger.warn(`${this.key} skip due to schedule closed`);
      return;
    }
 
    this.count++;
 
    const info = {
      key: this.key,
      id: this.getSeqId(),
      args,
    };
    this.logger.debug(`[Job#${info.id}] ${info.key} triggered, send all by agent`);
    this.agent.messenger.send('egg-schedule', info);
    this.onJobStart(info);
  }
 
  getSeqId() {
    return `${Date.now()}${process.hrtime().join('')}${this.count}`;
  }
};