ProcessManager.js 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. const { fork } = require('child_process');
  2. const path = require('path');
  3. class ProcessManager {
  4. constructor() {
  5. // 存储所有worker进程
  6. this.workers = new Map();
  7. // 定义不同worker的配置
  8. this.workerConfigs = [
  9. {
  10. name: '0_RECEIVE_FACTORY', //筛选数据
  11. script: './0_RECEIVE_FACTORY/RECEIVE_FACTORY.js',
  12. args: ['--type=data'],
  13. restart: false // 是否在崩溃时重启
  14. },
  15. {
  16. name: '1_FILTER_FACTORY', //筛选数据
  17. script: './1_FILTER_FACTORY/FILTER_FACTORY.js',
  18. args: ['--type=data'],
  19. restart: false // 是否在崩溃时重启
  20. },
  21. {
  22. name: '2_PRODUCT_FACTORY',//书库筛选
  23. script: './2_PRODUCT_FACTORY/PRODUCT_FACTORY.js',
  24. args: ['--type=data'],
  25. restart: false
  26. },
  27. {
  28. name: '5_CREATE_LINK_FACTORY', //创建推广连接
  29. script: './5_CREATE_LINK_FACTORY/CREATE_LINK_FACTORY.js',
  30. args: ['--type=data'],
  31. restart: false
  32. },
  33. {
  34. name: '7_CHECK_AND_CREATE_URL_FACTORY',//创建检测连接
  35. script: './7_CHECK_AND_CREATE_URL_FACTORY/CHECK_AND_CREATE_URL_FACTORY.js',
  36. args: ['--type=data'],
  37. restart: false
  38. },
  39. {
  40. name: 'MESSAGE_DISPATCH', //消息中心
  41. script: './MESSAGE_DISPATCH/MESSAGE_DISPATCH.js',
  42. args: ['--type=data'],
  43. restart: false
  44. },
  45. ];
  46. }
  47. start() {
  48. // 启动所有worker
  49. this.workerConfigs.forEach(config => {
  50. this.createWorker(config);
  51. });
  52. // 处理主进程的退出
  53. process.on('SIGTERM', () => this.shutdown());
  54. process.on('SIGINT', () => this.shutdown());
  55. }
  56. createWorker(config) {
  57. const worker = fork(
  58. path.join(__dirname, '', config.script),
  59. config.args,
  60. {
  61. env: { ...process.env } // 可以添加额外的环境变量
  62. }
  63. );
  64. this.workers.set(config.name, {
  65. process: worker,
  66. config: config,
  67. startTime: Date.now()
  68. });
  69. // 监听工作进程消息
  70. worker.on('message', (message) => {
  71. this.handleWorkerMessage(config.name, message);
  72. });
  73. // 监听错误
  74. worker.on('error', (error) => {
  75. console.error(`[${config.name}] 错误:`, error);
  76. });
  77. // 监听退出
  78. worker.on('exit', (code, signal) => {
  79. console.log(`[${config.name}] 退出,代码: ${code}, 信号: ${signal}`);
  80. // 从workers中移除
  81. this.workers.delete(config.name);
  82. // 如果配置了重启且不是正常关闭,则重新启动
  83. if (config.restart && !this.isShuttingDown) {
  84. console.log(`[${config.name}] 正在重启...`);
  85. setTimeout(() => this.createWorker(config), 1000);
  86. }
  87. });
  88. console.log(`[${config.name}] 已启动,PID: ${worker.pid}`);
  89. return worker;
  90. }
  91. handleWorkerMessage(workerName, message) {
  92. console.log(`[${workerName}] 消息:`, message);
  93. // 处理来自worker的不同类型消息
  94. switch(message.type) {
  95. case 'status':
  96. this.updateWorkerStatus(workerName, message.data);
  97. break;
  98. case 'error':
  99. this.handleWorkerError(workerName, message.data);
  100. break;
  101. // ... 其他消息类型
  102. }
  103. }
  104. updateWorkerStatus(workerName, status) {
  105. const worker = this.workers.get(workerName);
  106. if (worker) {
  107. worker.status = status;
  108. }
  109. }
  110. handleWorkerError(workerName, error) {
  111. console.error(`[${workerName}] 报告错误:`, error);
  112. // 实现错误处理逻辑
  113. }
  114. getWorkerStatus(workerName) {
  115. return this.workers.get(workerName);
  116. }
  117. async shutdown() {
  118. this.isShuttingDown = true;
  119. console.log('开始关闭所有工作进程...');
  120. // 向所有worker发送关闭信号
  121. const shutdownPromises = Array.from(this.workers.entries()).map(
  122. async ([name, {process}]) => {
  123. console.log(`正在关闭 ${name}...`);
  124. process.send({ type: 'shutdown' });
  125. return new Promise((resolve) => {
  126. process.once('exit', resolve);
  127. // 设置超时强制结束
  128. setTimeout(() => {
  129. if (!process.killed) {
  130. console.log(`${name} 强制终止`);
  131. process.kill('SIGKILL');
  132. }
  133. }, 5000);
  134. });
  135. }
  136. );
  137. await Promise.all(shutdownPromises);
  138. console.log('所有工作进程已关闭');
  139. process.exit(0);
  140. }
  141. }
  142. // 启动进程管理器
  143. module.exports = ProcessManager;