|
@ -303,7 +303,7 @@ func (vl *VolumeLayout) PickForWrite(count uint64, option *VolumeGrowOption) (vi |
|
|
// check whether picked file is close to full
|
|
|
// check whether picked file is close to full
|
|
|
dn := locationList.Head() |
|
|
dn := locationList.Head() |
|
|
info, _ := dn.GetVolumesById(vid) |
|
|
info, _ := dn.GetVolumesById(vid) |
|
|
if float64(info.Size) > float64(vl.volumeSizeLimit)*option.Threshold() { |
|
|
|
|
|
|
|
|
if float64(info.Size) > float64(vl.volumeSizeLimit)*VolumeGrowStrategy.Threshold { |
|
|
shouldGrow = true |
|
|
shouldGrow = true |
|
|
} |
|
|
} |
|
|
return vid, count, locationList.Copy(), shouldGrow, nil |
|
|
return vid, count, locationList.Copy(), shouldGrow, nil |
|
@ -334,7 +334,7 @@ func (vl *VolumeLayout) PickForWrite(count uint64, option *VolumeGrowOption) (vi |
|
|
vid, locationList = writableVolumeId, volumeLocationList.Copy() |
|
|
vid, locationList = writableVolumeId, volumeLocationList.Copy() |
|
|
// check whether picked file is close to full
|
|
|
// check whether picked file is close to full
|
|
|
info, _ := dn.GetVolumesById(writableVolumeId) |
|
|
info, _ := dn.GetVolumesById(writableVolumeId) |
|
|
if float64(info.Size) > float64(vl.volumeSizeLimit)*option.Threshold() { |
|
|
|
|
|
|
|
|
if float64(info.Size) > float64(vl.volumeSizeLimit)*VolumeGrowStrategy.Threshold { |
|
|
shouldGrow = true |
|
|
shouldGrow = true |
|
|
} |
|
|
} |
|
|
counter = count |
|
|
counter = count |
|
@ -370,7 +370,6 @@ func (vl *VolumeLayout) GetActiveVolumeCount(option *VolumeGrowOption) (total, a |
|
|
return len(vl.writables), len(vl.writables), len(vl.crowded) |
|
|
return len(vl.writables), len(vl.writables), len(vl.crowded) |
|
|
} |
|
|
} |
|
|
total = len(vl.writables) |
|
|
total = len(vl.writables) |
|
|
threshold := option.Threshold() |
|
|
|
|
|
for _, v := range vl.writables { |
|
|
for _, v := range vl.writables { |
|
|
for _, dn := range vl.vid2location[v].list { |
|
|
for _, dn := range vl.vid2location[v].list { |
|
|
if dn.GetDataCenter().Id() == NodeId(option.DataCenter) { |
|
|
if dn.GetDataCenter().Id() == NodeId(option.DataCenter) { |
|
@ -382,7 +381,7 @@ func (vl *VolumeLayout) GetActiveVolumeCount(option *VolumeGrowOption) (total, a |
|
|
} |
|
|
} |
|
|
active++ |
|
|
active++ |
|
|
info, _ := dn.GetVolumesById(v) |
|
|
info, _ := dn.GetVolumesById(v) |
|
|
if float64(info.Size) > float64(vl.volumeSizeLimit)*threshold { |
|
|
|
|
|
|
|
|
if float64(info.Size) > float64(vl.volumeSizeLimit)* VolumeGrowStrategy.Threshold{ |
|
|
crowded++ |
|
|
crowded++ |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|