| 
									
										
										
										
											2021-04-19 03:41:13 +08:00
										 |  |  | // Copyright (c) 2015-2021 MinIO, Inc.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This file is part of MinIO Object Storage stack
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This program is free software: you can redistribute it and/or modify
 | 
					
						
							|  |  |  | // it under the terms of the GNU Affero General Public License as published by
 | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or
 | 
					
						
							|  |  |  | // (at your option) any later version.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // This program is distributed in the hope that it will be useful
 | 
					
						
							|  |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					
						
							|  |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					
						
							|  |  |  | // GNU Affero General Public License for more details.
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | // You should have received a copy of the GNU Affero General Public License
 | 
					
						
							|  |  |  | // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
										
										
											2021-01-19 12:35:38 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | package cmd | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2021-05-06 23:52:02 +08:00
										 |  |  | 	"github.com/minio/madmin-go" | 
					
						
							| 
									
										
										
										
											2021-01-19 12:35:38 +08:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // GetTotalCapacity gets the total capacity in the cluster.
 | 
					
						
							| 
									
										
										
										
											2021-02-05 04:26:58 +08:00
										 |  |  | func GetTotalCapacity(diskInfo []madmin.Disk) (capacity uint64) { | 
					
						
							|  |  |  | 	for _, disk := range diskInfo { | 
					
						
							|  |  |  | 		capacity += disk.TotalSpace | 
					
						
							| 
									
										
										
										
											2021-01-19 12:35:38 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // GetTotalUsableCapacity gets the total usable capacity in the cluster.
 | 
					
						
							| 
									
										
										
										
											2021-01-23 04:09:24 +08:00
										 |  |  | // This value is not an accurate representation of total usable in a multi-tenant deployment.
 | 
					
						
							| 
									
										
										
										
											2021-02-05 04:26:58 +08:00
										 |  |  | func GetTotalUsableCapacity(diskInfo []madmin.Disk, s StorageInfo) (capacity float64) { | 
					
						
							|  |  |  | 	raw := GetTotalCapacity(diskInfo) | 
					
						
							| 
									
										
										
										
											2021-01-23 04:09:24 +08:00
										 |  |  | 	var approxDataBlocks float64 | 
					
						
							|  |  |  | 	var actualDisks float64 | 
					
						
							|  |  |  | 	for _, scData := range s.Backend.StandardSCData { | 
					
						
							|  |  |  | 		approxDataBlocks += float64(scData) | 
					
						
							|  |  |  | 		actualDisks += float64(scData + s.Backend.StandardSCParity) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	ratio := approxDataBlocks / actualDisks | 
					
						
							| 
									
										
										
										
											2021-01-19 12:35:38 +08:00
										 |  |  | 	return float64(raw) * ratio | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // GetTotalCapacityFree gets the total capacity free in the cluster.
 | 
					
						
							| 
									
										
										
										
											2021-02-05 04:26:58 +08:00
										 |  |  | func GetTotalCapacityFree(diskInfo []madmin.Disk) (capacity uint64) { | 
					
						
							|  |  |  | 	for _, d := range diskInfo { | 
					
						
							|  |  |  | 		capacity += d.AvailableSpace | 
					
						
							| 
									
										
										
										
											2021-01-19 12:35:38 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // GetTotalUsableCapacityFree gets the total usable capacity free in the cluster.
 | 
					
						
							| 
									
										
										
										
											2021-01-23 04:09:24 +08:00
										 |  |  | // This value is not an accurate representation of total free in a multi-tenant deployment.
 | 
					
						
							| 
									
										
										
										
											2021-02-05 04:26:58 +08:00
										 |  |  | func GetTotalUsableCapacityFree(diskInfo []madmin.Disk, s StorageInfo) (capacity float64) { | 
					
						
							|  |  |  | 	raw := GetTotalCapacityFree(diskInfo) | 
					
						
							| 
									
										
										
										
											2021-01-23 04:09:24 +08:00
										 |  |  | 	var approxDataBlocks float64 | 
					
						
							|  |  |  | 	var actualDisks float64 | 
					
						
							|  |  |  | 	for _, scData := range s.Backend.StandardSCData { | 
					
						
							|  |  |  | 		approxDataBlocks += float64(scData) | 
					
						
							|  |  |  | 		actualDisks += float64(scData + s.Backend.StandardSCParity) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	ratio := approxDataBlocks / actualDisks | 
					
						
							| 
									
										
										
										
											2021-01-19 12:35:38 +08:00
										 |  |  | 	return float64(raw) * ratio | 
					
						
							|  |  |  | } |