| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | /* | 
					
						
							| 
									
										
										
										
											2020-06-16 00:05:35 +08:00
										 |  |  |  * MinIO Cloud Storage, (C) 2019, 2020 MinIO, Inc. | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  * You may obtain a copy of the License at | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *     http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  * limitations under the License. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package cmd | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-16 00:05:35 +08:00
										 |  |  | import ( | 
					
						
							|  |  |  | 	"sync/atomic" | 
					
						
							|  |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // CacheDiskStats represents cache disk statistics
 | 
					
						
							|  |  |  | // such as current disk usage and available.
 | 
					
						
							|  |  |  | type CacheDiskStats struct { | 
					
						
							| 
									
										
										
										
											2020-12-08 08:35:11 +08:00
										 |  |  | 	// used cache size
 | 
					
						
							|  |  |  | 	UsageSize uint64 | 
					
						
							|  |  |  | 	// total cache disk capacity
 | 
					
						
							|  |  |  | 	TotalCapacity uint64 | 
					
						
							| 
									
										
										
										
											2020-06-16 00:05:35 +08:00
										 |  |  | 	// indicates if usage is high or low, if high value is '1', if low its '0'
 | 
					
						
							|  |  |  | 	UsageState int32 | 
					
						
							|  |  |  | 	// indicates the current usage percentage of this cache disk
 | 
					
						
							|  |  |  | 	UsagePercent uint64 | 
					
						
							|  |  |  | 	Dir          string | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // CacheStats - represents bytes served from cache,
 | 
					
						
							|  |  |  | // cache hits and cache misses.
 | 
					
						
							|  |  |  | type CacheStats struct { | 
					
						
							| 
									
										
										
										
											2020-06-16 00:05:35 +08:00
										 |  |  | 	BytesServed  uint64 | 
					
						
							|  |  |  | 	Hits         uint64 | 
					
						
							|  |  |  | 	Misses       uint64 | 
					
						
							|  |  |  | 	GetDiskStats func() []CacheDiskStats | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Increase total bytes served from cache
 | 
					
						
							|  |  |  | func (s *CacheStats) incBytesServed(n int64) { | 
					
						
							| 
									
										
										
										
											2020-05-04 13:35:40 +08:00
										 |  |  | 	atomic.AddUint64(&s.BytesServed, uint64(n)) | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Increase cache hit by 1
 | 
					
						
							|  |  |  | func (s *CacheStats) incHit() { | 
					
						
							| 
									
										
										
										
											2020-05-04 13:35:40 +08:00
										 |  |  | 	atomic.AddUint64(&s.Hits, 1) | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Increase cache miss by 1
 | 
					
						
							|  |  |  | func (s *CacheStats) incMiss() { | 
					
						
							| 
									
										
										
										
											2020-05-04 13:35:40 +08:00
										 |  |  | 	atomic.AddUint64(&s.Misses, 1) | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Get total bytes served
 | 
					
						
							|  |  |  | func (s *CacheStats) getBytesServed() uint64 { | 
					
						
							| 
									
										
										
										
											2020-05-04 13:35:40 +08:00
										 |  |  | 	return atomic.LoadUint64(&s.BytesServed) | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Get total cache hits
 | 
					
						
							|  |  |  | func (s *CacheStats) getHits() uint64 { | 
					
						
							| 
									
										
										
										
											2020-05-04 13:35:40 +08:00
										 |  |  | 	return atomic.LoadUint64(&s.Hits) | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Get total cache misses
 | 
					
						
							|  |  |  | func (s *CacheStats) getMisses() uint64 { | 
					
						
							| 
									
										
										
										
											2020-05-04 13:35:40 +08:00
										 |  |  | 	return atomic.LoadUint64(&s.Misses) | 
					
						
							| 
									
										
										
										
											2019-12-06 15:16:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Prepare new CacheStats structure
 | 
					
						
							|  |  |  | func newCacheStats() *CacheStats { | 
					
						
							|  |  |  | 	return &CacheStats{} | 
					
						
							|  |  |  | } |