aboutsummaryrefslogtreecommitdiff
path: root/weed/topology/topology.go
diff options
context:
space:
mode:
Diffstat (limited to 'weed/topology/topology.go')
-rw-r--r--weed/topology/topology.go11
1 files changed, 10 insertions, 1 deletions
diff --git a/weed/topology/topology.go b/weed/topology/topology.go
index 6bfd912cb..ba3be97c4 100644
--- a/weed/topology/topology.go
+++ b/weed/topology/topology.go
@@ -329,7 +329,7 @@ func (t *Topology) UnRegisterVolumeLayout(v storage.VolumeInfo, dn *DataNode) {
}
func (t *Topology) DataCenterExists(dcName string) bool {
- return dcName == "" || t.GetOrCreateDataCenter(dcName) != nil
+ return dcName == "" || t.GetDataCenter(dcName) != nil
}
func (t *Topology) GetDataCenter(dcName string) (dc *DataCenter) {
@@ -358,6 +358,15 @@ func (t *Topology) GetOrCreateDataCenter(dcName string) *DataCenter {
return dc
}
+func (t *Topology) ListDataCenters() (dcs []string) {
+ t.RLock()
+ defer t.RUnlock()
+ for _, c := range t.children {
+ dcs = append(dcs, string(c.(*DataCenter).Id()))
+ }
+ return dcs
+}
+
func (t *Topology) SyncDataNodeRegistration(volumes []*master_pb.VolumeInformationMessage, dn *DataNode) (newVolumes, deletedVolumes []storage.VolumeInfo) {
// convert into in memory struct storage.VolumeInfo
var volumeInfos []storage.VolumeInfo