Fix: subtract time taken to run heartbeat (#3072)
This commit is contained in:
		
							parent
							
								
									8c24b02fce
								
							
						
					
					
						commit
						33cc96f918
					
				
					 1 changed files with 9 additions and 1 deletions
				
			
		|  | @ -948,7 +948,15 @@ class Monitor extends BeanModel { | ||||||
| 
 | 
 | ||||||
|             if (! this.isStop) { |             if (! this.isStop) { | ||||||
|                 log.debug("monitor", `[${this.name}] SetTimeout for next check.`); |                 log.debug("monitor", `[${this.name}] SetTimeout for next check.`); | ||||||
|                 this.heartbeatInterval = setTimeout(safeBeat, beatInterval * 1000); | 
 | ||||||
|  |                 let intervalRemainingMs = Math.max( | ||||||
|  |                     1, | ||||||
|  |                     beatInterval * 1000 - dayjs().diff(dayjs.utc(bean.time)) | ||||||
|  |                 ); | ||||||
|  | 
 | ||||||
|  |                 log.debug("monitor", `[${this.name}] Next heartbeat in: ${intervalRemainingMs}ms`); | ||||||
|  | 
 | ||||||
|  |                 this.heartbeatInterval = setTimeout(safeBeat, intervalRemainingMs); | ||||||
|             } else { |             } else { | ||||||
|                 log.info("monitor", `[${this.name}] isStop = true, no next check.`); |                 log.info("monitor", `[${this.name}] isStop = true, no next check.`); | ||||||
|             } |             } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue