serverManager.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. const { exec } = require('child_process');
  2. const axios = require('axios');
  3. const fs = require('fs');
  4. const path = require('path');
  5. const constants = require('./constants');
  6. const utils = require('./utils');
  7. let serverProcess;
  8. // 启动 Web API 的函数
  9. const startServer = () => {
  10. return new Promise((resolve, reject) => {
  11. try {
  12. console.log('Starting server...Promise');
  13. const serverExePath = path.join(constants.serverPath, 'server', 'IES.ExamServer.exe');
  14. if (!fs.existsSync(serverExePath)) {
  15. throw new Error(`IES.ExamServer.exe not found at ${serverExePath}`);
  16. }
  17. // 使用双引号包裹路径
  18. const serverCommand = `"${serverExePath}"`;
  19. console.log(`Server command: ${serverCommand}`);
  20. serverProcess = exec(serverCommand, {
  21. cwd: `${constants.serverPath}/server`, // 设置工作目录为 server 目录
  22. stdio: 'inherit'
  23. });
  24. serverProcess.stdout.on('data', (data) => {
  25. console.log(`Server stdout: ${data}`);
  26. });
  27. serverProcess.stderr.on('data', (data) => {
  28. console.log(`Server stderr: ${data}`);
  29. });
  30. serverProcess.on('close', (data) => {
  31. console.log(`Server process exited with code ${data}`);
  32. reject(new Error(`Server process exited with code ${data}`));
  33. });
  34. // 等待 Web API 启动成功
  35. const checkHealth = async () => {
  36. try {
  37. const response = await axios.get(`${constants.baseUrl}/index/health`, {
  38. httpsAgent: constants.agent,
  39. timeout: 5000 // 设置超时时间为 5 秒
  40. });
  41. if (response.status === 200) {
  42. console.log('Server is up and running!');
  43. resolve();
  44. }
  45. } catch (error) {
  46. console.log('Waiting for server to start...', error);
  47. setTimeout(checkHealth, 10000); // 每隔 10 秒检查一次
  48. }
  49. };
  50. checkHealth();
  51. } catch (error)
  52. {
  53. console.error('Error starting server:', error);
  54. reject(error);
  55. }
  56. });
  57. };
  58. // 检查服务器健康状态的函数
  59. const checkServerHealth = async () => {
  60. try {
  61. const response = await axios.get(`${constants.baseUrl}/index/health`, {
  62. httpsAgent: constants.agent
  63. });
  64. if (response.status === 200) {
  65. console.log('Server is up and running!');
  66. return true;
  67. }
  68. } catch (error) {
  69. console.log('Server is not running yet.', error);
  70. return false;
  71. }
  72. };
  73. // 关闭服务器的函数
  74. const shutdownServer = async () => {
  75. try {
  76. console.log('index/shutdown api ...');
  77. const response = await axios.get(`${constants.baseUrl}/index/shutdown?delay=0`, {
  78. httpsAgent: constants.agent,
  79. validateStatus: (status) => status === 200 || status === 404, // 允许 404 状态码
  80. timeout: 5000 // 设置超时时间为 5 秒
  81. });
  82. if (response.status === 404) {
  83. console.error('API: index/shutdown not found.');
  84. }
  85. if (response.status === 200) {
  86. console.log('Server is shutdown!');
  87. }
  88. } catch (error) {
  89. console.error('关闭.NET Core Web API 时出错:', error);
  90. }
  91. if (serverProcess) {
  92. console.log('Killing server process...');
  93. serverProcess.kill();
  94. }
  95. };
  96. module.exports = {
  97. startServer,
  98. checkServerHealth,
  99. shutdownServer
  100. };