mirror of
https://github.com/seaweedfs/seaweedfs.git
synced 2024-01-19 02:48:24 +00:00
Merge pull request #354 from hxiaodon/master
if replicated volume has one copy in readonly mode at one node,it sho…
This commit is contained in:
commit
fa8198f44b
|
@ -79,6 +79,17 @@ func (dn *DataNode) GetVolumes() (ret []storage.VolumeInfo) {
|
||||||
return ret
|
return ret
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (dn *DataNode) GetVolumesById(id storage.VolumeId) (storage.VolumeInfo, error) {
|
||||||
|
dn.RLock()
|
||||||
|
defer dn.RUnlock()
|
||||||
|
v_info, ok := dn.volumes[id]
|
||||||
|
if ok {
|
||||||
|
return v_info, nil
|
||||||
|
} else {
|
||||||
|
return storage.VolumeInfo{}, fmt.Errorf("volumeInfo not found")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (dn *DataNode) GetDataCenter() *DataCenter {
|
func (dn *DataNode) GetDataCenter() *DataCenter {
|
||||||
return dn.Parent().Parent().(*NodeImpl).value.(*DataCenter)
|
return dn.Parent().Parent().(*NodeImpl).value.(*DataCenter)
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,19 @@ func (vl *VolumeLayout) RegisterVolume(v *storage.VolumeInfo, dn *DataNode) {
|
||||||
}
|
}
|
||||||
vl.vid2location[v.Id].Set(dn)
|
vl.vid2location[v.Id].Set(dn)
|
||||||
glog.V(4).Infoln("volume", v.Id, "added to dn", dn.Id(), "len", vl.vid2location[v.Id].Length(), "copy", v.ReplicaPlacement.GetCopyCount())
|
glog.V(4).Infoln("volume", v.Id, "added to dn", dn.Id(), "len", vl.vid2location[v.Id].Length(), "copy", v.ReplicaPlacement.GetCopyCount())
|
||||||
|
for _, dn := range vl.vid2location[v.Id].list {
|
||||||
|
if v_info, err := dn.GetVolumesById(v.Id); err == nil {
|
||||||
|
if v_info.ReadOnly {
|
||||||
|
glog.V(3).Infof("vid %d removed from writable", v.Id)
|
||||||
|
vl.removeFromWritable(v.Id)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
glog.V(3).Infof("vid %d removed from writable", v.Id)
|
||||||
|
vl.removeFromWritable(v.Id)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
if vl.vid2location[v.Id].Length() == vl.rp.GetCopyCount() && vl.isWritable(v) {
|
if vl.vid2location[v.Id].Length() == vl.rp.GetCopyCount() && vl.isWritable(v) {
|
||||||
if _, ok := vl.oversizedVolumes[v.Id]; !ok {
|
if _, ok := vl.oversizedVolumes[v.Id]; !ok {
|
||||||
vl.addToWritable(v.Id)
|
vl.addToWritable(v.Id)
|
||||||
|
|
Loading…
Reference in a new issue