Watcher.js 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. /**
  2. * Copyright 2013-2022 the PM2 project authors. All rights reserved.
  3. * Use of this source code is governed by a license that
  4. * can be found in the LICENSE file.
  5. */
  6. var chokidar = require('chokidar');
  7. var util = require('util');
  8. var log = require('debug')('pm2:watch');
  9. module.exports = function ClusterMode(God) {
  10. /**
  11. * Watch folder for changes and restart
  12. * @method watch
  13. * @param {Object} pm2_env pm2 app environnement
  14. * @return MemberExpression
  15. */
  16. God.watch = {};
  17. God.watch._watchers = {};
  18. God.watch.enable = function(pm2_env) {
  19. if (God.watch._watchers[pm2_env.pm_id]) {
  20. God.watch._watchers[pm2_env.pm_id].close();
  21. God.watch._watchers[pm2_env.pm_id] = null;
  22. delete God.watch._watchers[pm2_env.pm_id];
  23. }
  24. log('Initial watch ', pm2_env.watch)
  25. var watch = pm2_env.watch
  26. if(typeof watch == 'boolean' || util.isArray(watch) && watch.length === 0)
  27. watch = pm2_env.pm_cwd;
  28. log('Watching %s', watch);
  29. var watch_options = {
  30. ignored : pm2_env.ignore_watch || /[\/\\]\.|node_modules/,
  31. persistent : true,
  32. ignoreInitial : true,
  33. cwd: pm2_env.pm_cwd
  34. };
  35. if (pm2_env.watch_options) {
  36. watch_options = Object.assign(watch_options, pm2_env.watch_options);
  37. }
  38. log('Watch opts', watch_options);
  39. var watcher = chokidar.watch(watch, watch_options);
  40. console.log('[Watch] Start watching', pm2_env.name);
  41. watcher.on('all', function(event, path) {
  42. var self = this;
  43. if (self.restarting === true) {
  44. log('Already restarting, skipping');
  45. return false;
  46. }
  47. self.restarting = true;
  48. console.log('Change detected on path %s for app %s - restarting', path, pm2_env.name);
  49. setTimeout(function() {
  50. God.restartProcessName(pm2_env.name, function(err, list) {
  51. self.restarting = false;
  52. if (err) {
  53. log('Error while restarting', err);
  54. return false;
  55. }
  56. return log('Process restarted');
  57. });
  58. }, (pm2_env.watch_delay || 0));
  59. return false;
  60. });
  61. watcher.on('error', function(e) {
  62. console.error(e.stack || e);
  63. });
  64. God.watch._watchers[pm2_env.pm_id] = watcher;
  65. //return God.watch._watchers[pm2_env.name];
  66. },
  67. /**
  68. * Description
  69. * @method close
  70. * @param {} id
  71. * @return
  72. */
  73. God.watch.disableAll = function() {
  74. var watchers = God.watch._watchers;
  75. console.log('[Watch] PM2 is being killed. Watch is disabled to avoid conflicts');
  76. for (var i in watchers) {
  77. watchers[i].close && watchers[i].close();
  78. watchers.splice(i, 1);
  79. }
  80. },
  81. God.watch.disable = function(pm2_env) {
  82. var watcher = God.watch._watchers[pm2_env.pm_id]
  83. if (watcher) {
  84. console.log('[Watch] Stop watching', pm2_env.name);
  85. watcher.close();
  86. delete God.watch._watchers[pm2_env.pm_id];
  87. return true;
  88. } else {
  89. return false;
  90. }
  91. }
  92. };