qdone 2.0.16-alpha → 2.0.18-alpha

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -43,6 +43,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
43
43
  };
44
44
  Object.defineProperty(exports, "__esModule", { value: true });
45
45
  exports.processMessages = exports.getMessages = exports.requestShutdown = void 0;
46
+ var os_1 = require("os");
46
47
  var client_sqs_1 = require("@aws-sdk/client-sqs");
47
48
  var chalk_1 = __importDefault(require("chalk"));
48
49
  var debug_1 = __importDefault(require("debug"));
@@ -117,7 +118,7 @@ exports.getMessages = getMessages;
117
118
  //
118
119
  function processMessages(queues, callback, options) {
119
120
  return __awaiter(this, void 0, void 0, function () {
120
- var opt, lastLatency, systemMonitor, jobExecutor, queueManager, delayTimeout, delay, activeQrls, maxReturnCount, listen, allowedJobs, maxLatency, latency, latencyFactor, targetJobs, jobsLeft, _i, _a, _b, qname, qrl, maxMessages;
121
+ var opt, lastLatency, systemMonitor, jobExecutor, queueManager, delayTimeout, delay, activeQrls, maxReturnCount, listen, allowedJobs, maxLatency, latency, latencyFactor, freememFactor, targetJobs, jobsLeft, _i, _a, _b, qname, qrl, maxMessages;
121
122
  var _this = this;
122
123
  return __generator(this, function (_c) {
123
124
  switch (_c.label) {
@@ -211,9 +212,10 @@ function processMessages(queues, callback, options) {
211
212
  latency = systemMonitor.getLatency() || 10;
212
213
  latencyFactor = 1 - Math.abs(Math.min(latency / maxLatency, 1)) // 0 if latency is at max, 1 if latency 0
213
214
  ;
214
- targetJobs = Math.round(allowedJobs * latencyFactor);
215
+ freememFactor = Math.min(1, Math.max(0, (0, os_1.freemem)() - (0, os_1.totalmem)() / 2) / (0, os_1.totalmem)());
216
+ targetJobs = Math.round(allowedJobs * latencyFactor * freememFactor);
215
217
  jobsLeft = targetJobs;
216
- debug({ jobCount: jobExecutor.activeJobCount(), maxReturnCount: maxReturnCount, allowedJobs: allowedJobs, maxLatency: maxLatency, latency: latency, latencyFactor: latencyFactor, targetJobs: targetJobs, activeQrls: activeQrls });
218
+ debug({ jobCount: jobExecutor.activeJobCount(), maxReturnCount: maxReturnCount, allowedJobs: allowedJobs, maxLatency: maxLatency, latency: latency, latencyFactor: latencyFactor, freememFactor: freememFactor, targetJobs: targetJobs, activeQrls: activeQrls });
217
219
  for (_i = 0, _a = queueManager.getPairs(); _i < _a.length; _i++) {
218
220
  _b = _a[_i], qname = _b.qname, qrl = _b.qrl;
219
221
  debug({ evaluating: { qname: qname, qrl: qrl, jobsLeft: jobsLeft, activeQrlsHasQrl: activeQrls.has(qrl) } });
@@ -85,21 +85,33 @@ var metricNames = [
85
85
  */
86
86
  function _cheapIdleCheck(qname, qrl, opt) {
87
87
  return __awaiter(this, void 0, void 0, function () {
88
- var client, cmd, data, result;
88
+ var client, cmd, data, result_1, e_1;
89
89
  return __generator(this, function (_a) {
90
90
  switch (_a.label) {
91
91
  case 0:
92
+ _a.trys.push([0, 2, , 3]);
92
93
  client = (0, sqs_js_1.getSQSClient)();
93
94
  cmd = new client_sqs_1.GetQueueAttributesCommand({ AttributeNames: exports.attributeNames, QueueUrl: qrl });
94
95
  return [4 /*yield*/, client.send(cmd)];
95
96
  case 1:
96
97
  data = _a.sent();
97
98
  debug('data', data);
98
- result = data.Attributes;
99
- result.queue = qname.slice(opt.prefix.length);
99
+ result_1 = data.Attributes;
100
+ result_1.queue = qname.slice(opt.prefix.length);
100
101
  // We are idle if all the messages attributes are zero
101
- result.idle = exports.attributeNames.filter(function (k) { return result[k] === '0'; }).length === exports.attributeNames.length;
102
- return [2 /*return*/, { result: result, SQS: 1 }];
102
+ result_1.idle = exports.attributeNames.filter(function (k) { return result_1[k] === '0'; }).length === exports.attributeNames.length;
103
+ return [2 /*return*/, { result: result_1, SQS: 1 }];
104
+ case 2:
105
+ e_1 = _a.sent();
106
+ if (e_1 instanceof client_sqs_1.QueueDoesNotExist) {
107
+ // Count deleted queues as idle
108
+ return [2 /*return*/, { idle: true, SQS: 1 }];
109
+ }
110
+ else {
111
+ throw e_1;
112
+ }
113
+ return [3 /*break*/, 3];
114
+ case 3: return [2 /*return*/];
103
115
  }
104
116
  });
105
117
  });
@@ -320,7 +332,7 @@ exports.processQueue = processQueue;
320
332
  */
321
333
  function processQueuePair(qname, qrl, opt) {
322
334
  return __awaiter(this, void 0, void 0, function () {
323
- var isFifo, normalizeOptions, fqname, fqrl, result, active, fresult, idleCheckResult, factive, _a, dresult, dfresult, e_1, deleteResult, resultIncludingDelete;
335
+ var isFifo, normalizeOptions, fqname, fqrl, result, active, fresult, idleCheckResult, factive, _a, dresult, dfresult, e_2, deleteResult, resultIncludingDelete;
324
336
  return __generator(this, function (_b) {
325
337
  switch (_b.label) {
326
338
  case 0:
@@ -385,11 +397,11 @@ function processQueuePair(qname, qrl, opt) {
385
397
  }
386
398
  })];
387
399
  case 5:
388
- e_1 = _b.sent();
400
+ e_2 = _b.sent();
389
401
  // Handle the case where the fail queue has been deleted or was never
390
402
  // created for some reason
391
- if (!(e_1 instanceof client_sqs_1.QueueDoesNotExist))
392
- throw e_1;
403
+ if (!(e_2 instanceof client_sqs_1.QueueDoesNotExist))
404
+ throw e_2;
393
405
  // Fail queue doesn't exist if we get here
394
406
  if (opt.verbose)
395
407
  console.error(chalk_1.default.blue('Queue ') + fqname.slice(opt.prefix.length) + chalk_1.default.blue(' does not exist.'));
@@ -269,7 +269,7 @@ var JobExecutor = /** @class */ (function () {
269
269
  };
270
270
  JobExecutor.prototype.executeJob = function (message, callback, qname, qrl) {
271
271
  return __awaiter(this, void 0, void 0, function () {
272
- var payload, visibilityTimeout, job, oldJob, e, queue_1, result, err_1;
272
+ var payload, visibilityTimeout, job, oldJob, e, queue, result, err_1;
273
273
  return __generator(this, function (_a) {
274
274
  switch (_a.label) {
275
275
  case 0:
@@ -316,8 +316,8 @@ var JobExecutor = /** @class */ (function () {
316
316
  _a.label = 1;
317
317
  case 1:
318
318
  _a.trys.push([1, 3, , 4]);
319
- queue_1 = qname.slice(this.opt.prefix.length);
320
- return [4 /*yield*/, (0, sentry_js_1.withSentry)(function () { return callback(queue_1, payload); }, this.opt, { job: job })];
319
+ queue = qname.slice(this.opt.prefix.length);
320
+ return [4 /*yield*/, callback(queue, payload)];
321
321
  case 2:
322
322
  result = _a.sent();
323
323
  debug('executeJob callback finished', { payload: payload, result: result });