2015-03-27 23:29:13 +00:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"flag"
|
2018-11-04 05:32:04 +00:00
|
|
|
"fmt"
|
2020-05-29 02:00:07 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/util"
|
2015-03-27 23:29:13 +00:00
|
|
|
"os"
|
|
|
|
"path"
|
|
|
|
"strconv"
|
|
|
|
|
2016-06-03 01:09:14 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
2019-05-22 05:41:20 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/storage/idx"
|
2018-07-10 05:48:30 +00:00
|
|
|
"github.com/chrislusf/seaweedfs/weed/storage/types"
|
2015-03-27 23:29:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
fixVolumePath = flag.String("dir", "/tmp", "data directory to store files")
|
|
|
|
fixVolumeCollection = flag.String("collection", "", "the volume collection name")
|
|
|
|
fixVolumeId = flag.Int("volumeId", -1, "a volume id. The volume should already exist in the dir. The volume index file should not exist.")
|
|
|
|
)
|
|
|
|
|
|
|
|
/*
|
|
|
|
This is to see content in .idx files.
|
|
|
|
|
|
|
|
see_idx -v=4 -volumeId=9 -dir=/Users/chrislu/Downloads
|
|
|
|
*/
|
|
|
|
func main() {
|
|
|
|
flag.Parse()
|
|
|
|
fileName := strconv.Itoa(*fixVolumeId)
|
|
|
|
if *fixVolumeCollection != "" {
|
|
|
|
fileName = *fixVolumeCollection + "_" + fileName
|
|
|
|
}
|
|
|
|
indexFile, err := os.OpenFile(path.Join(*fixVolumePath, fileName+".idx"), os.O_RDONLY, 0644)
|
|
|
|
if err != nil {
|
|
|
|
glog.Fatalf("Create Volume Index [ERROR] %s\n", err)
|
|
|
|
}
|
|
|
|
defer indexFile.Close()
|
|
|
|
|
2019-05-22 05:41:20 +00:00
|
|
|
idx.WalkIndexFile(indexFile, func(key types.NeedleId, offset types.Offset, size uint32) error {
|
2020-05-29 02:00:07 +00:00
|
|
|
// key:1 offset:1 size:17214(16.81 KiB)
|
|
|
|
fmt.Printf("key:%v offset:%v size:%v(%v)\n", key, offset, size, util.BytesToHumanReadable(uint64(size)))
|
2018-07-10 05:48:30 +00:00
|
|
|
return nil
|
|
|
|
})
|
2015-03-27 23:29:13 +00:00
|
|
|
|
|
|
|
}
|