Expire metrics on query in addition to on add (#6981)
Ensures that expired metrics are removed even when no new data is sent to the output.
This commit is contained in:
		
							parent
							
								
									8792a5fd5e
								
							
						
					
					
						commit
						e8d9add2d1
					
				|  | @ -65,6 +65,12 @@ func (c *Collector) Collect(ch chan<- prometheus.Metric) { | ||||||
| 	c.Lock() | 	c.Lock() | ||||||
| 	defer c.Unlock() | 	defer c.Unlock() | ||||||
| 
 | 
 | ||||||
|  | 	// Expire metrics, doing this on Collect ensure metrics are removed even if no
 | ||||||
|  | 	// new metrics are added to the output.
 | ||||||
|  | 	if c.expireDuration != 0 { | ||||||
|  | 		c.coll.Expire(time.Now(), c.expireDuration) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	for _, family := range c.coll.GetProto() { | 	for _, family := range c.coll.GetProto() { | ||||||
| 		for _, metric := range family.Metric { | 		for _, metric := range family.Metric { | ||||||
| 			ch <- &Metric{family: family, metric: metric} | 			ch <- &Metric{family: family, metric: metric} | ||||||
|  | @ -80,8 +86,11 @@ func (c *Collector) Add(metrics []telegraf.Metric) error { | ||||||
| 		c.coll.Add(metric) | 		c.coll.Add(metric) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	// Expire metrics, doing this on Add ensure metrics are removed even if no
 | ||||||
|  | 	// one is querying the data.
 | ||||||
| 	if c.expireDuration != 0 { | 	if c.expireDuration != 0 { | ||||||
| 		c.coll.Expire(time.Now(), c.expireDuration) | 		c.coll.Expire(time.Now(), c.expireDuration) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue