|
@ -22,6 +22,7 @@ type VolumeLayout struct { |
|
|
readonlyVolumes map[needle.VolumeId]bool // transient set of readonly volumes
|
|
|
readonlyVolumes map[needle.VolumeId]bool // transient set of readonly volumes
|
|
|
oversizedVolumes map[needle.VolumeId]bool // set of oversized volumes
|
|
|
oversizedVolumes map[needle.VolumeId]bool // set of oversized volumes
|
|
|
volumeSizeLimit uint64 |
|
|
volumeSizeLimit uint64 |
|
|
|
|
|
replicationAsMin bool |
|
|
accessLock sync.RWMutex |
|
|
accessLock sync.RWMutex |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -31,7 +32,7 @@ type VolumeLayoutStats struct { |
|
|
FileCount uint64 |
|
|
FileCount uint64 |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func NewVolumeLayout(rp *super_block.ReplicaPlacement, ttl *needle.TTL, volumeSizeLimit uint64) *VolumeLayout { |
|
|
|
|
|
|
|
|
func NewVolumeLayout(rp *super_block.ReplicaPlacement, ttl *needle.TTL, volumeSizeLimit uint64, replicationAsMin bool) *VolumeLayout { |
|
|
return &VolumeLayout{ |
|
|
return &VolumeLayout{ |
|
|
rp: rp, |
|
|
rp: rp, |
|
|
ttl: ttl, |
|
|
ttl: ttl, |
|
@ -40,6 +41,7 @@ func NewVolumeLayout(rp *super_block.ReplicaPlacement, ttl *needle.TTL, volumeSi |
|
|
readonlyVolumes: make(map[needle.VolumeId]bool), |
|
|
readonlyVolumes: make(map[needle.VolumeId]bool), |
|
|
oversizedVolumes: make(map[needle.VolumeId]bool), |
|
|
oversizedVolumes: make(map[needle.VolumeId]bool), |
|
|
volumeSizeLimit: volumeSizeLimit, |
|
|
volumeSizeLimit: volumeSizeLimit, |
|
|
|
|
|
replicationAsMin: replicationAsMin, |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -107,7 +109,7 @@ func (vl *VolumeLayout) UnRegisterVolume(v *storage.VolumeInfo, dn *DataNode) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
func (vl *VolumeLayout) ensureCorrectWritables(v *storage.VolumeInfo) { |
|
|
func (vl *VolumeLayout) ensureCorrectWritables(v *storage.VolumeInfo) { |
|
|
if vl.vid2location[v.Id].Length() == vl.rp.GetCopyCount() && vl.isWritable(v) { |
|
|
|
|
|
|
|
|
if vl.enoughCopies(v.Id) && vl.isWritable(v) { |
|
|
if _, ok := vl.oversizedVolumes[v.Id]; !ok { |
|
|
if _, ok := vl.oversizedVolumes[v.Id]; !ok { |
|
|
vl.setVolumeWritable(v.Id) |
|
|
vl.setVolumeWritable(v.Id) |
|
|
} |
|
|
} |
|
@ -272,12 +274,18 @@ func (vl *VolumeLayout) SetVolumeAvailable(dn *DataNode, vid needle.VolumeId, is |
|
|
return false |
|
|
return false |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if vl.vid2location[vid].Length() == vl.rp.GetCopyCount() { |
|
|
|
|
|
|
|
|
if vl.enoughCopies(vid) { |
|
|
return vl.setVolumeWritable(vid) |
|
|
return vl.setVolumeWritable(vid) |
|
|
} |
|
|
} |
|
|
return false |
|
|
return false |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
func (vl *VolumeLayout) enoughCopies(vid needle.VolumeId) bool { |
|
|
|
|
|
locations := vl.vid2location[vid].Length() |
|
|
|
|
|
desired := vl.rp.GetCopyCount() |
|
|
|
|
|
return locations == desired || (vl.replicationAsMin && locations > desired) |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
func (vl *VolumeLayout) SetVolumeCapacityFull(vid needle.VolumeId) bool { |
|
|
func (vl *VolumeLayout) SetVolumeCapacityFull(vid needle.VolumeId) bool { |
|
|
vl.accessLock.Lock() |
|
|
vl.accessLock.Lock() |
|
|
defer vl.accessLock.Unlock() |
|
|
defer vl.accessLock.Unlock() |
|
|