Browse Source

disk file avoid file.Stat()

pull/1833/head
Chris Lu 4 years ago
parent
commit
7635f6b9fa
  1. 2
      unmaintained/change_superblock/change_superblock.go
  2. 11
      weed/storage/backend/disk_file.go
  3. 2
      weed/storage/volume_vacuum.go

2
unmaintained/change_superblock/change_superblock.go

@ -92,7 +92,7 @@ func main() {
header := superBlock.Bytes() header := superBlock.Bytes()
if n, e := datFile.WriteAt(header, 0); n == 0 || e != nil {
if n, e := datBackend.WriteAt(header, 0); n == 0 || e != nil {
glog.Fatalf("cannot write super block: %v", e) glog.Fatalf("cannot write super block: %v", e)
} }

11
weed/storage/backend/disk_file.go

@ -2,6 +2,7 @@ package backend
import ( import (
"github.com/chrislusf/seaweedfs/weed/glog" "github.com/chrislusf/seaweedfs/weed/glog"
. "github.com/chrislusf/seaweedfs/weed/storage/types"
"os" "os"
"time" "time"
) )
@ -22,11 +23,15 @@ func NewDiskFile(f *os.File) *DiskFile {
if err != nil { if err != nil {
glog.Fatalf("stat file %s: %v", f.Name(), err) glog.Fatalf("stat file %s: %v", f.Name(), err)
} }
offset := stat.Size()
if offset%NeedlePaddingSize != 0 {
offset = offset + (NeedlePaddingSize - offset%NeedlePaddingSize)
}
return &DiskFile{ return &DiskFile{
fullFilePath: f.Name(), fullFilePath: f.Name(),
File: f, File: f,
fileSize: stat.Size(),
fileSize: offset,
modTime: stat.ModTime(), modTime: stat.ModTime(),
} }
} }
@ -47,6 +52,10 @@ func (df *DiskFile) WriteAt(p []byte, off int64) (n int, err error) {
return return
} }
func (df *DiskFile) Append(p []byte) (n int, err error) {
return df.WriteAt(p, df.fileSize)
}
func (df *DiskFile) Truncate(off int64) error { func (df *DiskFile) Truncate(off int64) error {
err := df.File.Truncate(off) err := df.File.Truncate(off)
if err == nil { if err == nil {

2
weed/storage/volume_vacuum.go

@ -286,7 +286,7 @@ func (v *Volume) makeupDiff(newDatFileName, newIdxFileName, oldDatFileName, oldI
if err != nil { if err != nil {
return fmt.Errorf("ReadNeedleBlob %s key %d offset %d size %d failed: %v", oldDatFile.Name(), key, increIdxEntry.offset.ToActualOffset(), increIdxEntry.size, err) return fmt.Errorf("ReadNeedleBlob %s key %d offset %d size %d failed: %v", oldDatFile.Name(), key, increIdxEntry.offset.ToActualOffset(), increIdxEntry.size, err)
} }
dst.Write(needleBytes)
dstDatBackend.Append(needleBytes)
util.Uint32toBytes(idxEntryBytes[8:12], uint32(offset/NeedlePaddingSize)) util.Uint32toBytes(idxEntryBytes[8:12], uint32(offset/NeedlePaddingSize))
} else { //deleted needle } else { //deleted needle
//fakeDelNeedle 's default Data field is nil //fakeDelNeedle 's default Data field is nil

Loading…
Cancel
Save