mirror of
https://github.com/minio/minio.git
synced 2025-01-24 13:13:16 -05:00
Merge pull request #754 from harshavardhana/pr_out_live_multiple_disk_removal_works_properly
Live multiple disk removal works properly
This commit is contained in:
commit
6a64019659
@ -33,6 +33,7 @@ import (
|
|||||||
|
|
||||||
"github.com/minio/minio/pkg/crypto/sha256"
|
"github.com/minio/minio/pkg/crypto/sha256"
|
||||||
"github.com/minio/minio/pkg/crypto/sha512"
|
"github.com/minio/minio/pkg/crypto/sha512"
|
||||||
|
"github.com/minio/minio/pkg/donut/disk"
|
||||||
"github.com/minio/minio/pkg/donut/split"
|
"github.com/minio/minio/pkg/donut/split"
|
||||||
"github.com/minio/minio/pkg/iodine"
|
"github.com/minio/minio/pkg/iodine"
|
||||||
)
|
)
|
||||||
@ -88,23 +89,30 @@ func (b bucket) getBucketName() string {
|
|||||||
}
|
}
|
||||||
func (b bucket) getBucketMetadataReaders() (map[int]io.ReadCloser, error) {
|
func (b bucket) getBucketMetadataReaders() (map[int]io.ReadCloser, error) {
|
||||||
readers := make(map[int]io.ReadCloser)
|
readers := make(map[int]io.ReadCloser)
|
||||||
|
var disks map[int]disk.Disk
|
||||||
|
var err error
|
||||||
for _, node := range b.nodes {
|
for _, node := range b.nodes {
|
||||||
disks, err := node.ListDisks()
|
disks, err = node.ListDisks()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, iodine.New(err, nil)
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
var bucketMetaDataReader io.ReadCloser
|
||||||
for order, disk := range disks {
|
for order, disk := range disks {
|
||||||
bucketMetaDataReader, err := disk.OpenFile(filepath.Join(b.donutName, bucketMetadataConfig))
|
bucketMetaDataReader, err = disk.OpenFile(filepath.Join(b.donutName, bucketMetadataConfig))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, iodine.New(err, nil)
|
continue
|
||||||
}
|
}
|
||||||
readers[order] = bucketMetaDataReader
|
readers[order] = bucketMetaDataReader
|
||||||
}
|
}
|
||||||
|
if err != nil {
|
||||||
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
return readers, nil
|
return readers, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b bucket) getBucketMetadata() (*AllBuckets, error) {
|
func (b bucket) getBucketMetadata() (*AllBuckets, error) {
|
||||||
|
var err error
|
||||||
metadata := new(AllBuckets)
|
metadata := new(AllBuckets)
|
||||||
readers, err := b.getBucketMetadataReaders()
|
readers, err := b.getBucketMetadataReaders()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -115,12 +123,11 @@ func (b bucket) getBucketMetadata() (*AllBuckets, error) {
|
|||||||
}
|
}
|
||||||
for _, reader := range readers {
|
for _, reader := range readers {
|
||||||
jenc := json.NewDecoder(reader)
|
jenc := json.NewDecoder(reader)
|
||||||
if err := jenc.Decode(metadata); err != nil {
|
if err = jenc.Decode(metadata); err == nil {
|
||||||
return nil, iodine.New(err, nil)
|
|
||||||
}
|
|
||||||
return metadata, nil
|
return metadata, nil
|
||||||
}
|
}
|
||||||
return nil, iodine.New(InvalidArgument{}, nil)
|
}
|
||||||
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
// GetObjectMetadata - get metadata for an object
|
// GetObjectMetadata - get metadata for an object
|
||||||
@ -357,6 +364,7 @@ func (b bucket) readObjectMetadata(objectName string) (ObjectMetadata, error) {
|
|||||||
if objectName == "" {
|
if objectName == "" {
|
||||||
return ObjectMetadata{}, iodine.New(InvalidArgument{}, nil)
|
return ObjectMetadata{}, iodine.New(InvalidArgument{}, nil)
|
||||||
}
|
}
|
||||||
|
var err error
|
||||||
objMetadataReaders, err := b.getObjectReaders(objectName, objectMetadataConfig)
|
objMetadataReaders, err := b.getObjectReaders(objectName, objectMetadataConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ObjectMetadata{}, iodine.New(err, nil)
|
return ObjectMetadata{}, iodine.New(err, nil)
|
||||||
@ -366,13 +374,12 @@ func (b bucket) readObjectMetadata(objectName string) (ObjectMetadata, error) {
|
|||||||
}
|
}
|
||||||
for _, objMetadataReader := range objMetadataReaders {
|
for _, objMetadataReader := range objMetadataReaders {
|
||||||
jdec := json.NewDecoder(objMetadataReader)
|
jdec := json.NewDecoder(objMetadataReader)
|
||||||
if err := jdec.Decode(&objMetadata); err != nil {
|
if err = jdec.Decode(&objMetadata); err == nil {
|
||||||
return ObjectMetadata{}, iodine.New(err, nil)
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
return objMetadata, nil
|
return objMetadata, nil
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
return ObjectMetadata{}, iodine.New(err, nil)
|
||||||
|
}
|
||||||
|
|
||||||
// TODO - This a temporary normalization of objectNames, need to find a better way
|
// TODO - This a temporary normalization of objectNames, need to find a better way
|
||||||
//
|
//
|
||||||
@ -539,23 +546,28 @@ func (b bucket) decodeEncodedData(totalLeft, blockSize int64, readers map[int]io
|
|||||||
// getObjectReaders -
|
// getObjectReaders -
|
||||||
func (b bucket) getObjectReaders(objectName, objectMeta string) (map[int]io.ReadCloser, error) {
|
func (b bucket) getObjectReaders(objectName, objectMeta string) (map[int]io.ReadCloser, error) {
|
||||||
readers := make(map[int]io.ReadCloser)
|
readers := make(map[int]io.ReadCloser)
|
||||||
|
var disks map[int]disk.Disk
|
||||||
|
var err error
|
||||||
nodeSlice := 0
|
nodeSlice := 0
|
||||||
for _, node := range b.nodes {
|
for _, node := range b.nodes {
|
||||||
disks, err := node.ListDisks()
|
disks, err = node.ListDisks()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, iodine.New(err, nil)
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
for order, disk := range disks {
|
for order, disk := range disks {
|
||||||
|
var objectSlice io.ReadCloser
|
||||||
bucketSlice := fmt.Sprintf("%s$%d$%d", b.name, nodeSlice, order)
|
bucketSlice := fmt.Sprintf("%s$%d$%d", b.name, nodeSlice, order)
|
||||||
objectPath := filepath.Join(b.donutName, bucketSlice, objectName, objectMeta)
|
objectPath := filepath.Join(b.donutName, bucketSlice, objectName, objectMeta)
|
||||||
objectSlice, err := disk.OpenFile(objectPath)
|
objectSlice, err = disk.OpenFile(objectPath)
|
||||||
if err != nil {
|
if err == nil {
|
||||||
return nil, iodine.New(err, nil)
|
|
||||||
}
|
|
||||||
readers[order] = objectSlice
|
readers[order] = objectSlice
|
||||||
}
|
}
|
||||||
|
}
|
||||||
nodeSlice = nodeSlice + 1
|
nodeSlice = nodeSlice + 1
|
||||||
}
|
}
|
||||||
|
if err != nil {
|
||||||
|
return nil, iodine.New(err, nil)
|
||||||
|
}
|
||||||
return readers, nil
|
return readers, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -99,6 +99,9 @@ func (donut API) listBuckets() (map[string]BucketMetadata, error) {
|
|||||||
// to figure out between acceptable and unacceptable errors
|
// to figure out between acceptable and unacceptable errors
|
||||||
return make(map[string]BucketMetadata), nil
|
return make(map[string]BucketMetadata), nil
|
||||||
}
|
}
|
||||||
|
if metadata == nil {
|
||||||
|
return make(map[string]BucketMetadata), nil
|
||||||
|
}
|
||||||
return metadata.Buckets, nil
|
return metadata.Buckets, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -232,18 +235,24 @@ func (donut API) getBucketMetadataWriters() ([]io.WriteCloser, error) {
|
|||||||
// getBucketMetadataReaders - readers are returned in map rather than slice
|
// getBucketMetadataReaders - readers are returned in map rather than slice
|
||||||
func (donut API) getBucketMetadataReaders() (map[int]io.ReadCloser, error) {
|
func (donut API) getBucketMetadataReaders() (map[int]io.ReadCloser, error) {
|
||||||
readers := make(map[int]io.ReadCloser)
|
readers := make(map[int]io.ReadCloser)
|
||||||
|
var disks map[int]disk.Disk
|
||||||
|
var err error
|
||||||
for _, node := range donut.nodes {
|
for _, node := range donut.nodes {
|
||||||
disks, err := node.ListDisks()
|
disks, err = node.ListDisks()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, iodine.New(err, nil)
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
for order, d := range disks {
|
}
|
||||||
bucketMetaDataReader, err := d.OpenFile(filepath.Join(donut.config.DonutName, bucketMetadataConfig))
|
var bucketMetaDataReader io.ReadCloser
|
||||||
|
for order, dsk := range disks {
|
||||||
|
bucketMetaDataReader, err = dsk.OpenFile(filepath.Join(donut.config.DonutName, bucketMetadataConfig))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, iodine.New(err, nil)
|
continue
|
||||||
}
|
}
|
||||||
readers[order] = bucketMetaDataReader
|
readers[order] = bucketMetaDataReader
|
||||||
}
|
}
|
||||||
|
if err != nil {
|
||||||
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
return readers, nil
|
return readers, nil
|
||||||
}
|
}
|
||||||
@ -269,7 +278,8 @@ func (donut API) setDonutBucketMetadata(metadata *AllBuckets) error {
|
|||||||
|
|
||||||
// getDonutBucketMetadata -
|
// getDonutBucketMetadata -
|
||||||
func (donut API) getDonutBucketMetadata() (*AllBuckets, error) {
|
func (donut API) getDonutBucketMetadata() (*AllBuckets, error) {
|
||||||
metadata := new(AllBuckets)
|
metadata := &AllBuckets{}
|
||||||
|
var err error
|
||||||
readers, err := donut.getBucketMetadataReaders()
|
readers, err := donut.getBucketMetadataReaders()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, iodine.New(err, nil)
|
return nil, iodine.New(err, nil)
|
||||||
@ -279,12 +289,11 @@ func (donut API) getDonutBucketMetadata() (*AllBuckets, error) {
|
|||||||
}
|
}
|
||||||
for _, reader := range readers {
|
for _, reader := range readers {
|
||||||
jenc := json.NewDecoder(reader)
|
jenc := json.NewDecoder(reader)
|
||||||
if err := jenc.Decode(metadata); err != nil {
|
if err = jenc.Decode(metadata); err == nil {
|
||||||
return nil, iodine.New(err, nil)
|
|
||||||
}
|
|
||||||
return metadata, nil
|
return metadata, nil
|
||||||
}
|
}
|
||||||
return nil, iodine.New(InvalidArgument{}, nil)
|
}
|
||||||
|
return nil, iodine.New(err, nil)
|
||||||
}
|
}
|
||||||
|
|
||||||
// makeDonutBucket -
|
// makeDonutBucket -
|
||||||
|
Loading…
x
Reference in New Issue
Block a user