|
@ -18,8 +18,8 @@ type Volume struct { |
|
|
dataFile *os.File |
|
|
dataFile *os.File |
|
|
nm *NeedleMap |
|
|
nm *NeedleMap |
|
|
|
|
|
|
|
|
replicaType ReplicationType |
|
|
|
|
|
version Version |
|
|
version Version |
|
|
|
|
|
replicaType ReplicationType |
|
|
|
|
|
|
|
|
accessLock sync.Mutex |
|
|
accessLock sync.Mutex |
|
|
} |
|
|
} |
|
@ -85,12 +85,17 @@ func (v *Volume) readSuperBlock() error { |
|
|
if _, e := v.dataFile.Read(header); e != nil { |
|
|
if _, e := v.dataFile.Read(header); e != nil { |
|
|
return fmt.Errorf("cannot read superblock: %s", e) |
|
|
return fmt.Errorf("cannot read superblock: %s", e) |
|
|
} |
|
|
} |
|
|
v.version = Version(header[0]) |
|
|
|
|
|
var err error |
|
|
var err error |
|
|
if v.replicaType, err = NewReplicationTypeFromByte(header[1]); err != nil { |
|
|
|
|
|
return fmt.Errorf("cannot read replica type: %s", err) |
|
|
|
|
|
|
|
|
v.version, v.replicaType, err = ParseSuperBlock(header) |
|
|
|
|
|
return err |
|
|
} |
|
|
} |
|
|
return nil |
|
|
|
|
|
|
|
|
func ParseSuperBlock(header []byte) (version Version, replicaType ReplicationType, e error) { |
|
|
|
|
|
version = Version(header[0]) |
|
|
|
|
|
var err error |
|
|
|
|
|
if replicaType, err = NewReplicationTypeFromByte(header[1]); err != nil { |
|
|
|
|
|
e = fmt.Errorf("cannot read replica type: %s", err) |
|
|
|
|
|
} |
|
|
|
|
|
return |
|
|
} |
|
|
} |
|
|
func (v *Volume) NeedToReplicate() bool { |
|
|
func (v *Volume) NeedToReplicate() bool { |
|
|
return v.replicaType.GetCopyCount() > 1 |
|
|
return v.replicaType.GetCopyCount() > 1 |
|
@ -143,7 +148,7 @@ func (v *Volume) compact() error { |
|
|
filePath := path.Join(v.dir, v.Id.String()) |
|
|
filePath := path.Join(v.dir, v.Id.String()) |
|
|
return v.copyDataAndGenerateIndexFile(filePath+".dat", filePath+".cpd", filePath+".cpx") |
|
|
return v.copyDataAndGenerateIndexFile(filePath+".dat", filePath+".cpd", filePath+".cpx") |
|
|
} |
|
|
} |
|
|
func (v *Volume) commitCompact() (error) { |
|
|
|
|
|
|
|
|
func (v *Volume) commitCompact() error { |
|
|
v.accessLock.Lock() |
|
|
v.accessLock.Lock() |
|
|
defer v.accessLock.Unlock() |
|
|
defer v.accessLock.Unlock() |
|
|
v.dataFile.Close() |
|
|
v.dataFile.Close() |
|
@ -185,7 +190,9 @@ func (v *Volume) copyDataAndGenerateIndexFile(srcName, dstName, idxName string) |
|
|
dst.Write(header) |
|
|
dst.Write(header) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
n, rest := ReadNeedle(src) |
|
|
|
|
|
|
|
|
version, _, _ := ParseSuperBlock(header) |
|
|
|
|
|
|
|
|
|
|
|
n, rest := ReadNeedle(src, version) |
|
|
nm := NewNeedleMap(idx) |
|
|
nm := NewNeedleMap(idx) |
|
|
old_offset := uint32(SuperBlockSize) |
|
|
old_offset := uint32(SuperBlockSize) |
|
|
new_offset := uint32(SuperBlockSize) |
|
|
new_offset := uint32(SuperBlockSize) |
|
@ -208,7 +215,7 @@ func (v *Volume) copyDataAndGenerateIndexFile(srcName, dstName, idxName string) |
|
|
src.Seek(int64(rest-n.Size-4), 1) |
|
|
src.Seek(int64(rest-n.Size-4), 1) |
|
|
} |
|
|
} |
|
|
old_offset += rest + 16 |
|
|
old_offset += rest + 16 |
|
|
n, rest = ReadNeedle(src) |
|
|
|
|
|
|
|
|
n, rest = ReadNeedle(src, version) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return nil |
|
|
return nil |
|
|