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.
		
		
		
		
		
			
		
			
				
					
					
						
							124 lines
						
					
					
						
							3.3 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							124 lines
						
					
					
						
							3.3 KiB
						
					
					
				| package topology | |
| 
 | |
| import ( | |
| 	"github.com/seaweedfs/seaweedfs/weed/pb/master_pb" | |
| 	"slices" | |
| 	"strings" | |
| ) | |
| 
 | |
| type TopologyInfo struct { | |
| 	Max         int64              `json:"Max"` | |
| 	Free        int64              `json:"Free"` | |
| 	DataCenters []DataCenterInfo   `json:"DataCenters"` | |
| 	Layouts     []VolumeLayoutInfo `json:"Layouts"` | |
| } | |
| 
 | |
| type VolumeLayoutCollection struct { | |
| 	Collection   string | |
| 	VolumeLayout *VolumeLayout | |
| } | |
| 
 | |
| func (t *Topology) ToInfo() (info TopologyInfo) { | |
| 	info.Max = t.diskUsages.GetMaxVolumeCount() | |
| 	info.Free = t.diskUsages.FreeSpace() | |
| 	var dcs []DataCenterInfo | |
| 	for _, c := range t.Children() { | |
| 		dc := c.(*DataCenter) | |
| 		dcs = append(dcs, dc.ToInfo()) | |
| 	} | |
| 
 | |
| 	slices.SortFunc(dcs, func(a, b DataCenterInfo) int { | |
| 		return strings.Compare(string(a.Id), string(b.Id)) | |
| 	}) | |
| 
 | |
| 	info.DataCenters = dcs | |
| 	var layouts []VolumeLayoutInfo | |
| 	for _, col := range t.collectionMap.Items() { | |
| 		c := col.(*Collection) | |
| 		for _, layout := range c.storageType2VolumeLayout.Items() { | |
| 			if layout != nil { | |
| 				tmp := layout.(*VolumeLayout).ToInfo() | |
| 				tmp.Collection = c.Name | |
| 				layouts = append(layouts, tmp) | |
| 			} | |
| 		} | |
| 	} | |
| 	info.Layouts = layouts | |
| 	return | |
| } | |
| 
 | |
| func (t *Topology) ListVolumeLayoutCollections() (volumeLayouts []*VolumeLayoutCollection) { | |
| 	for _, col := range t.collectionMap.Items() { | |
| 		for _, volumeLayout := range col.(*Collection).storageType2VolumeLayout.Items() { | |
| 			volumeLayouts = append(volumeLayouts, | |
| 				&VolumeLayoutCollection{col.(*Collection).Name, volumeLayout.(*VolumeLayout)}, | |
| 			) | |
| 		} | |
| 	} | |
| 	return volumeLayouts | |
| } | |
| 
 | |
| func (t *Topology) ToVolumeMap() interface{} { | |
| 	m := make(map[string]interface{}) | |
| 	m["Max"] = t.diskUsages.GetMaxVolumeCount() | |
| 	m["Free"] = t.diskUsages.FreeSpace() | |
| 	dcs := make(map[NodeId]interface{}) | |
| 	for _, c := range t.Children() { | |
| 		dc := c.(*DataCenter) | |
| 		racks := make(map[NodeId]interface{}) | |
| 		for _, r := range dc.Children() { | |
| 			rack := r.(*Rack) | |
| 			dataNodes := make(map[NodeId]interface{}) | |
| 			for _, d := range rack.Children() { | |
| 				dn := d.(*DataNode) | |
| 				var volumes []interface{} | |
| 				for _, v := range dn.GetVolumes() { | |
| 					volumes = append(volumes, v) | |
| 				} | |
| 				dataNodes[d.Id()] = volumes | |
| 			} | |
| 			racks[r.Id()] = dataNodes | |
| 		} | |
| 		dcs[dc.Id()] = racks | |
| 	} | |
| 	m["DataCenters"] = dcs | |
| 	return m | |
| } | |
| 
 | |
| func (t *Topology) ToVolumeLocations() (volumeLocations []*master_pb.VolumeLocation) { | |
| 	for _, c := range t.Children() { | |
| 		dc := c.(*DataCenter) | |
| 		for _, r := range dc.Children() { | |
| 			rack := r.(*Rack) | |
| 			for _, d := range rack.Children() { | |
| 				dn := d.(*DataNode) | |
| 				volumeLocation := &master_pb.VolumeLocation{ | |
| 					Url:        dn.Url(), | |
| 					PublicUrl:  dn.PublicUrl, | |
| 					DataCenter: dn.GetDataCenterId(), | |
| 					GrpcPort:   uint32(dn.GrpcPort), | |
| 				} | |
| 				for _, v := range dn.GetVolumes() { | |
| 					volumeLocation.NewVids = append(volumeLocation.NewVids, uint32(v.Id)) | |
| 				} | |
| 				for _, s := range dn.GetEcShards() { | |
| 					volumeLocation.NewVids = append(volumeLocation.NewVids, uint32(s.VolumeId)) | |
| 				} | |
| 				volumeLocations = append(volumeLocations, volumeLocation) | |
| 			} | |
| 		} | |
| 	} | |
| 	return | |
| } | |
| 
 | |
| func (t *Topology) ToTopologyInfo() *master_pb.TopologyInfo { | |
| 	m := &master_pb.TopologyInfo{ | |
| 		Id:        string(t.Id()), | |
| 		DiskInfos: t.diskUsages.ToDiskInfo(), | |
| 	} | |
| 	for _, c := range t.Children() { | |
| 		dc := c.(*DataCenter) | |
| 		m.DataCenterInfos = append(m.DataCenterInfos, dc.ToDataCenterInfo()) | |
| 	} | |
| 	return m | |
| }
 |