You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							117 lines
						
					
					
						
							3.1 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							117 lines
						
					
					
						
							3.1 KiB
						
					
					
				| package shell | |
| 
 | |
| import ( | |
| 	"context" | |
| 	"fmt" | |
| 	"github.com/seaweedfs/seaweedfs/weed/pb/master_pb" | |
| 	"github.com/seaweedfs/seaweedfs/weed/storage/super_block" | |
| 	"io" | |
| ) | |
| 
 | |
| func init() { | |
| 	Commands = append(Commands, &commandCollectionList{}) | |
| } | |
| 
 | |
| type commandCollectionList struct { | |
| } | |
| 
 | |
| func (c *commandCollectionList) Name() string { | |
| 	return "collection.list" | |
| } | |
| 
 | |
| func (c *commandCollectionList) Help() string { | |
| 	return `list all collections` | |
| } | |
| 
 | |
| func (c *commandCollectionList) HasTag(CommandTag) bool { | |
| 	return false | |
| } | |
| 
 | |
| type CollectionInfo struct { | |
| 	FileCount        float64 | |
| 	DeleteCount      float64 | |
| 	DeletedByteCount float64 | |
| 	Size             float64 | |
| 	VolumeCount      int | |
| } | |
| 
 | |
| func (c *commandCollectionList) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) { | |
| 
 | |
| 	collections, err := ListCollectionNames(commandEnv, true, true) | |
| 
 | |
| 	if err != nil { | |
| 		return err | |
| 	} | |
| 
 | |
| 	topologyInfo, _, err := collectTopologyInfo(commandEnv, 0) | |
| 	if err != nil { | |
| 		return err | |
| 	} | |
| 
 | |
| 	collectionInfos := make(map[string]*CollectionInfo) | |
| 
 | |
| 	collectCollectionInfo(topologyInfo, collectionInfos) | |
| 
 | |
| 	for _, c := range collections { | |
| 		cif, found := collectionInfos[c] | |
| 		if !found { | |
| 			continue | |
| 		} | |
| 		fmt.Fprintf(writer, "collection:\"%s\"\tvolumeCount:%d\tsize:%.0f\tfileCount:%.0f\tdeletedBytes:%.0f\tdeletion:%.0f\n", c, cif.VolumeCount, cif.Size, cif.FileCount, cif.DeletedByteCount, cif.DeleteCount) | |
| 	} | |
| 
 | |
| 	fmt.Fprintf(writer, "Total %d collections.\n", len(collections)) | |
| 
 | |
| 	return nil | |
| } | |
| 
 | |
| func ListCollectionNames(commandEnv *CommandEnv, includeNormalVolumes, includeEcVolumes bool) (collections []string, err error) { | |
| 	var resp *master_pb.CollectionListResponse | |
| 	err = commandEnv.MasterClient.WithClient(false, func(client master_pb.SeaweedClient) error { | |
| 		resp, err = client.CollectionList(context.Background(), &master_pb.CollectionListRequest{ | |
| 			IncludeNormalVolumes: includeNormalVolumes, | |
| 			IncludeEcVolumes:     includeEcVolumes, | |
| 		}) | |
| 		return err | |
| 	}) | |
| 	if err != nil { | |
| 		return | |
| 	} | |
| 	for _, c := range resp.Collections { | |
| 		collections = append(collections, c.Name) | |
| 	} | |
| 	return | |
| } | |
| 
 | |
| func addToCollection(collectionInfos map[string]*CollectionInfo, vif *master_pb.VolumeInformationMessage) { | |
| 	c := vif.Collection | |
| 	cif, found := collectionInfos[c] | |
| 	if !found { | |
| 		cif = &CollectionInfo{} | |
| 		collectionInfos[c] = cif | |
| 	} | |
| 	replicaPlacement, _ := super_block.NewReplicaPlacementFromByte(byte(vif.ReplicaPlacement)) | |
| 	copyCount := float64(replicaPlacement.GetCopyCount()) | |
| 	cif.Size += float64(vif.Size) / copyCount | |
| 	cif.DeleteCount += float64(vif.DeleteCount) / copyCount | |
| 	cif.FileCount += float64(vif.FileCount) / copyCount | |
| 	cif.DeletedByteCount += float64(vif.DeletedByteCount) / copyCount | |
| 	cif.VolumeCount++ | |
| } | |
| 
 | |
| func collectCollectionInfo(t *master_pb.TopologyInfo, collectionInfos map[string]*CollectionInfo) { | |
| 	for _, dc := range t.DataCenterInfos { | |
| 		for _, r := range dc.RackInfos { | |
| 			for _, dn := range r.DataNodeInfos { | |
| 				for _, diskInfo := range dn.DiskInfos { | |
| 					for _, vi := range diskInfo.VolumeInfos { | |
| 						addToCollection(collectionInfos, vi) | |
| 					} | |
| 					//for _, ecShardInfo := range diskInfo.EcShardInfos { | |
| 					// | |
| 					//} | |
| 				} | |
| 			} | |
| 		} | |
| 	} | |
| }
 |