mirror of
				https://github.com/Unleash/unleash.git
				synced 2025-10-27 11:02:16 +01:00 
			
		
		
		
	Currently if the intial metrics-fetch fails unleash will not setup a metrics-poller. This fix ensures that the metrics poller will start regardless of whether the inital fetch fails or succeeds. closes #396
		
			
				
	
	
		
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| 
 | |
| const logger = require('../logger')('client-metrics-store.js');
 | |
| 
 | |
| const { EventEmitter } = require('events');
 | |
| 
 | |
| const TEN_SECONDS = 10 * 1000;
 | |
| 
 | |
| class ClientMetricsStore extends EventEmitter {
 | |
|     constructor(metricsDb, pollInterval = TEN_SECONDS) {
 | |
|         super();
 | |
|         this.metricsDb = metricsDb;
 | |
|         this.highestIdSeen = 0;
 | |
| 
 | |
|         this._init(pollInterval);
 | |
|     }
 | |
| 
 | |
|     async _init(pollInterval) {
 | |
|         try {
 | |
|             const metrics = await this.metricsDb.getMetricsLastHour();
 | |
|             this._emitMetrics(metrics);
 | |
|         } catch (err) {
 | |
|             logger.error('Error fetching metrics last hour', err);
 | |
|         }
 | |
|         this._startPoller(pollInterval);
 | |
|         this.emit('ready');
 | |
|     }
 | |
| 
 | |
|     _startPoller(pollInterval) {
 | |
|         this.timer = setInterval(() => this._fetchNewAndEmit(), pollInterval);
 | |
|         this.timer.unref();
 | |
|     }
 | |
| 
 | |
|     _fetchNewAndEmit() {
 | |
|         this.metricsDb
 | |
|             .getNewMetrics(this.highestIdSeen)
 | |
|             .then(metrics => this._emitMetrics(metrics));
 | |
|     }
 | |
| 
 | |
|     _emitMetrics(metrics) {
 | |
|         if (metrics && metrics.length > 0) {
 | |
|             this.highestIdSeen = metrics[metrics.length - 1].id;
 | |
|             metrics.forEach(m => this.emit('metrics', m.metrics));
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     // Insert new client metrics
 | |
|     insert(metrics) {
 | |
|         return this.metricsDb.insert(metrics);
 | |
|     }
 | |
| 
 | |
|     destroy() {
 | |
|         try {
 | |
|             clearInterval(this.timer);
 | |
|         } catch (e) {
 | |
|             // empty
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| module.exports = ClientMetricsStore;
 |