UNPKG

@sex-pomelo/sex-pomelo

Version:

[![NPM version][npm-image-pomelo]][npm-url-pomelo] [![NPM version][npm-image-down]][npm-url-pomelo]

135 lines (113 loc) 4.03 kB
"use strict"; const reFilename = __filename.substring(__filename.indexOf("node_modules")); const logger = require('@sex-pomelo/sex-pomelo-logger').getLogger('pomelo', reFilename); const utils = require('../util/utils'); const events = require('../util/events'); const Constants = require('../util/constants'); const util = require('util'); module.exports = function(opts, consoleService) { return new Module(opts, consoleService); }; module.exports.moduleId = Constants.KEYWORDS.MONITOR_WATCHER; let Module = function(opts, consoleService) { this.app = opts.app; this.service = consoleService; this.id = this.app.getServerId(); this.app.event.on(events.START_SERVER, finishStart.bind(null, this)); }; Module.prototype.start = function(cb) { subscribeRequest(this, this.service.agent, this.id, cb); }; Module.prototype.monitorHandler = function(agent, msg, cb) { if(!msg || !msg.action) { return; } let func = monitorMethods[msg.action]; if(!func) { logger.info('monitorwatcher unknown action: %j', msg.action); return; } func(this, agent, msg, cb); }; // ----------------- monitor start method ------------------------- let subscribeRequest = function(self, agent, id, cb) { let msg = {action: 'subscribe', id: id}; agent.request(Constants.KEYWORDS.MASTER_WATCHER, msg, function(err, servers) { if(err) { logger.error('subscribeRequest request to master with error: %j', err.stack); utils.invokeCallback(cb, err); } let res = []; for(let id in servers) { res.push(servers[id]); } addServers(self, res); utils.invokeCallback(cb); }); }; // ----------------- monitor request methods ------------------------- let addServer = function(self, agent, msg, cb) { logger.debug('[%s] receive addServer signal: %j', self.app.serverId, msg); if(!msg || !msg.server) { logger.warn('monitorwatcher addServer receive empty message: %j', msg); utils.invokeCallback(cb, Constants.SIGNAL.FAIL); return; } addServers(self, [msg.server]); utils.invokeCallback(cb, Constants.SIGNAL.OK); }; let removeServer = function(self, agent, msg, cb) { logger.debug('%s receive removeServer signal: %j', self.app.serverId, msg); if(!msg || !msg.id) { logger.warn('monitorwatcher removeServer receive empty message: %j', msg); utils.invokeCallback(cb, Constants.SIGNAL.FAIL); return; } removeServers(self, [msg.id]); utils.invokeCallback(cb, Constants.SIGNAL.OK); }; let replaceServer = function(self, agent, msg, cb) { logger.debug('%s receive replaceServer signal: %j', self.app.serverId, msg); if(!msg || !msg.servers) { logger.warn('monitorwatcher replaceServer receive empty message: %j', msg); utils.invokeCallback(cb, Constants.SIGNAL.FAIL); return; } replaceServers(self, msg.servers); utils.invokeCallback(cb, Constants.SIGNAL.OK); }; let startOver = function(self, agent, msg, cb) { let fun = self.app.lifecycleCbs[Constants.LIFECYCLE.AFTER_STARTALL]; if(!!fun) { fun.call(null, self.app); } self.app.event.emit(events.START_ALL); utils.invokeCallback(cb, Constants.SIGNAL.OK); }; // ----------------- common methods ------------------------- let addServers = function(self, servers) { if(!servers || !servers.length) { return; } self.app.addServers(servers); }; let removeServers = function(self, ids) { if(!ids || !ids.length) { return; } self.app.removeServers(ids); }; let replaceServers = function(self, servers) { self.app.replaceServers(servers); }; // ----------------- bind methods ------------------------- let finishStart = function(self, id) { let msg = {action: 'record', id: id}; self.service.agent.notify(Constants.KEYWORDS.MASTER_WATCHER, msg); }; let monitorMethods = { 'addServer': addServer, 'removeServer': removeServer, 'replaceServer': replaceServer, 'startOver': startOver };