UNPKG

hystrixjs

Version:

resilience module for NodeJS applications

229 lines (196 loc) 9.78 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })(); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var _RollingNumber = require("./RollingNumber"); var _RollingNumber2 = _interopRequireDefault(_RollingNumber); var _RollingPercentile = require("./RollingPercentile"); var _RollingPercentile2 = _interopRequireDefault(_RollingPercentile); var _RollingNumberEvent = require("./RollingNumberEvent"); var _RollingNumberEvent2 = _interopRequireDefault(_RollingNumberEvent); var _utilActualTime = require("../util/ActualTime"); var _utilActualTime2 = _interopRequireDefault(_utilActualTime); var _utilHystrixConfig = require("../util/HystrixConfig"); var _utilHystrixConfig2 = _interopRequireDefault(_utilHystrixConfig); var CommandMetrics = (function () { function CommandMetrics(commandKey) { var commandGroup = arguments.length <= 1 || arguments[1] === undefined ? "hystrix" : arguments[1]; var _ref = arguments.length <= 2 || arguments[2] === undefined ? {} : arguments[2]; var _ref$statisticalWindowTimeInMilliSeconds = _ref.statisticalWindowTimeInMilliSeconds; var statisticalWindowTimeInMilliSeconds = _ref$statisticalWindowTimeInMilliSeconds === undefined ? _utilHystrixConfig2["default"].metricsStatisticalWindowInMilliseconds : _ref$statisticalWindowTimeInMilliSeconds; var _ref$statisticalWindowNumberOfBuckets = _ref.statisticalWindowNumberOfBuckets; var statisticalWindowNumberOfBuckets = _ref$statisticalWindowNumberOfBuckets === undefined ? _utilHystrixConfig2["default"].metricsStatisticalWindowBuckets : _ref$statisticalWindowNumberOfBuckets; var _ref$percentileWindowTimeInMilliSeconds = _ref.percentileWindowTimeInMilliSeconds; var percentileWindowTimeInMilliSeconds = _ref$percentileWindowTimeInMilliSeconds === undefined ? _utilHystrixConfig2["default"].metricsPercentileWindowInMilliseconds : _ref$percentileWindowTimeInMilliSeconds; var _ref$percentileWindowNumberOfBuckets = _ref.percentileWindowNumberOfBuckets; var percentileWindowNumberOfBuckets = _ref$percentileWindowNumberOfBuckets === undefined ? _utilHystrixConfig2["default"].metricsPercentileWindowBuckets : _ref$percentileWindowNumberOfBuckets; _classCallCheck(this, CommandMetrics); if (!commandKey) { throw new Error("Please provide a unique command key for the metrics."); } this.currentExecutionCount = 0; this.metricsRollingStatisticalWindowInMilliseconds = statisticalWindowTimeInMilliSeconds; this.commandKey = commandKey; this.commandGroup = commandGroup; this.lastHealthCountsSnapshot = _utilActualTime2["default"].getCurrentTime(); this.rollingCount = new _RollingNumber2["default"]({ timeInMillisecond: statisticalWindowTimeInMilliSeconds, numberOfBuckets: statisticalWindowNumberOfBuckets }); this.percentileCount = new _RollingPercentile2["default"]({ timeInMillisecond: percentileWindowTimeInMilliSeconds, numberOfBuckets: percentileWindowNumberOfBuckets }); } _createClass(CommandMetrics, [{ key: "markSuccess", value: function markSuccess() { this.rollingCount.increment(_RollingNumberEvent2["default"].SUCCESS); } }, { key: "markRejected", value: function markRejected() { this.rollingCount.increment(_RollingNumberEvent2["default"].REJECTED); } }, { key: "markFailure", value: function markFailure() { this.rollingCount.increment(_RollingNumberEvent2["default"].FAILURE); } }, { key: "markTimeout", value: function markTimeout() { this.rollingCount.increment(_RollingNumberEvent2["default"].TIMEOUT); } }, { key: "markShortCircuited", value: function markShortCircuited() { this.rollingCount.increment(_RollingNumberEvent2["default"].SHORT_CIRCUITED); } }, { key: "markFallbackFailure", value: function markFallbackFailure() { this.rollingCount.increment(_RollingNumberEvent2["default"].FALLBACK_FAILURE); } }, { key: "markFallbackSuccess", value: function markFallbackSuccess() { this.rollingCount.increment(_RollingNumberEvent2["default"].FALLBACK_SUCCESS); } }, { key: "incrementExecutionCount", value: function incrementExecutionCount() { ++this.currentExecutionCount; } }, { key: "decrementExecutionCount", value: function decrementExecutionCount() { --this.currentExecutionCount; } }, { key: "getCurrentExecutionCount", value: function getCurrentExecutionCount() { return this.currentExecutionCount; } }, { key: "addExecutionTime", value: function addExecutionTime(time) { this.percentileCount.addValue(time); } }, { key: "getRollingCount", value: function getRollingCount(type) { return this.rollingCount.getRollingSum(type); } }, { key: "getCumulativeCount", value: function getCumulativeCount(type) { return this.rollingCount.getCumulativeSum(type); } }, { key: "getExecutionTime", value: function getExecutionTime(percentile) { return this.percentileCount.getPercentile(percentile); } }, { key: "getHealthCounts", value: function getHealthCounts() { //TODO restrict calculation by time to avoid too frequent calls var success = this.rollingCount.getRollingSum(_RollingNumberEvent2["default"].SUCCESS); var error = this.rollingCount.getRollingSum(_RollingNumberEvent2["default"].FAILURE); var timeout = this.rollingCount.getRollingSum(_RollingNumberEvent2["default"].TIMEOUT); var shortCircuited = this.rollingCount.getRollingSum(_RollingNumberEvent2["default"].SHORT_CIRCUITED); var totalCount = success + error + timeout + shortCircuited; var errorCount = error + timeout + shortCircuited; var errorPercentage = 0; if (totalCount > 0) { errorPercentage = errorCount / totalCount * 100; } return { totalCount: totalCount, errorCount: errorCount, errorPercentage: parseInt(errorPercentage) }; } }, { key: "update", value: function update() { this.rollingCount.getCurrentBucket(); this.percentileCount.getCurrentBucket(); } }, { key: "reset", value: function reset() { this.rollingCount.reset(); this.lastHealthCountsSnapshot = _utilActualTime2["default"].getCurrentTime(); } }]); return CommandMetrics; })(); exports.CommandMetrics = CommandMetrics; var metricsByCommand = new Map(); var Factory = (function () { function Factory() { _classCallCheck(this, Factory); } _createClass(Factory, null, [{ key: "getOrCreate", value: function getOrCreate() { var _ref2 = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; var commandKey = _ref2.commandKey; var _ref2$commandGroup = _ref2.commandGroup; var commandGroup = _ref2$commandGroup === undefined ? "hystrix" : _ref2$commandGroup; var statisticalWindowTimeInMilliSeconds = _ref2.statisticalWindowTimeInMilliSeconds; var statisticalWindowNumberOfBuckets = _ref2.statisticalWindowNumberOfBuckets; var percentileWindowTimeInMilliSeconds = _ref2.percentileWindowTimeInMilliSeconds; var percentileWindowNumberOfBuckets = _ref2.percentileWindowNumberOfBuckets; var previouslyCached = metricsByCommand.get(commandKey); if (previouslyCached) { return previouslyCached; } var metrics = new CommandMetrics(commandKey, commandGroup, { statisticalWindowTimeInMilliSeconds: statisticalWindowTimeInMilliSeconds, statisticalWindowNumberOfBuckets: statisticalWindowNumberOfBuckets, percentileWindowTimeInMilliSeconds: percentileWindowTimeInMilliSeconds, percentileWindowNumberOfBuckets: percentileWindowNumberOfBuckets }); metricsByCommand.set(commandKey, metrics); return metricsByCommand.get(commandKey); } }, { key: "resetCache", value: function resetCache() { metricsByCommand.clear(); } }, { key: "getAllMetrics", value: function getAllMetrics() { return metricsByCommand.values(); } }]); return Factory; })(); exports.Factory = Factory;