mirror of
https://github.com/minio/minio.git
synced 2025-02-02 17:35:58 -05:00
Heal buckets upon init if needed, adding new disks and HUP works
This commit is contained in:
parent
00a701a155
commit
5507a39840
@ -119,6 +119,7 @@ func New() (Interface, error) {
|
||||
newBucket.partMetadata = make(map[string]map[int]PartMetadata)
|
||||
a.storedBuckets.Set(k, newBucket)
|
||||
}
|
||||
a.Heal()
|
||||
}
|
||||
return a, nil
|
||||
}
|
||||
|
@ -25,11 +25,15 @@ import (
|
||||
"github.com/minio/minio/pkg/iodine"
|
||||
)
|
||||
|
||||
// Heal heal an existing donut
|
||||
func (donut API) Heal() error {
|
||||
// healBuckets heal bucket slices
|
||||
func (donut API) healBuckets() error {
|
||||
if err := donut.listDonutBuckets(); err != nil {
|
||||
return iodine.New(err, nil)
|
||||
}
|
||||
bucketMetadata, err := donut.getDonutBucketMetadata()
|
||||
if err != nil {
|
||||
return iodine.New(err, nil)
|
||||
}
|
||||
disks := make(map[int]disk.Disk)
|
||||
for _, node := range donut.nodes {
|
||||
nDisks, err := node.ListDisks()
|
||||
@ -40,20 +44,8 @@ func (donut API) Heal() error {
|
||||
disks[k] = v
|
||||
}
|
||||
}
|
||||
|
||||
missingDisks := make(map[int]disk.Disk)
|
||||
for order, disk := range disks {
|
||||
if !disk.IsUsable() {
|
||||
missingDisks[order] = disk
|
||||
}
|
||||
}
|
||||
|
||||
bucketMetadata, err := donut.getDonutBucketMetadata()
|
||||
if err != nil {
|
||||
return iodine.New(err, nil)
|
||||
}
|
||||
|
||||
for _, disk := range missingDisks {
|
||||
if disk.IsUsable() {
|
||||
disk.MakeDir(donut.config.DonutName)
|
||||
bucketMetadataWriter, err := disk.CreateFile(filepath.Join(donut.config.DonutName, bucketMetadataConfig))
|
||||
if err != nil {
|
||||
@ -64,9 +56,6 @@ func (donut API) Heal() error {
|
||||
if err := jenc.Encode(bucketMetadata); err != nil {
|
||||
return iodine.New(err, nil)
|
||||
}
|
||||
}
|
||||
|
||||
for order, disk := range missingDisks {
|
||||
for bucket := range bucketMetadata.Buckets {
|
||||
bucketSlice := fmt.Sprintf("%s$0$%d", bucket, order) // TODO handle node slices
|
||||
err := disk.MakeDir(filepath.Join(donut.config.DonutName, bucketSlice))
|
||||
@ -75,7 +64,6 @@ func (donut API) Heal() error {
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
return nil
|
||||
// TODO heal data
|
||||
}
|
||||
|
@ -73,3 +73,9 @@ func (donut API) DetachNode(hostname string) error {
|
||||
func (donut API) Rebalance() error {
|
||||
return iodine.New(APINotImplemented{API: "management.Rebalance"}, nil)
|
||||
}
|
||||
|
||||
// Heal - heal your donuts
|
||||
func (donut API) Heal() error {
|
||||
// TODO handle data heal
|
||||
return donut.healBuckets()
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user