aboutsummaryrefslogtreecommitdiff
path: root/go/operation
diff options
context:
space:
mode:
authorchrislusf <chris.lu@gmail.com>2015-05-26 00:58:41 -0700
committerchrislusf <chris.lu@gmail.com>2015-05-26 00:58:41 -0700
commit86cd40fba87f7e69c10d1e66e967f6e5e40605b6 (patch)
tree0bec704ff7aa8c0dd89c2f4852844a230e46c821 /go/operation
parent7272af8ec45426151593fcd7d1a4d5a8092d5de6 (diff)
downloadseaweedfs-86cd40fba87f7e69c10d1e66e967f6e5e40605b6.tar.xz
seaweedfs-86cd40fba87f7e69c10d1e66e967f6e5e40605b6.zip
Add "weed backup" command.
This is a pre-cursor for asynchronous replication.
Diffstat (limited to 'go/operation')
-rw-r--r--go/operation/sync_volume.go54
1 files changed, 54 insertions, 0 deletions
diff --git a/go/operation/sync_volume.go b/go/operation/sync_volume.go
new file mode 100644
index 000000000..54944a64e
--- /dev/null
+++ b/go/operation/sync_volume.go
@@ -0,0 +1,54 @@
+package operation
+
+import (
+ "encoding/json"
+ "fmt"
+ "net/url"
+
+ "github.com/chrislusf/seaweedfs/go/glog"
+ "github.com/chrislusf/seaweedfs/go/util"
+)
+
+type SyncVolumeResponse struct {
+ Replication string `json:"Replication,omitempty"`
+ Ttl string `json:"Ttl,omitempty"`
+ TailOffset uint64 `json:"TailOffset,omitempty"`
+ CompactRevision uint16 `json:"CompactRevision,omitempty"`
+ IdxFileSize uint64 `json:"IdxFileSize,omitempty"`
+ Error string `json:"error,omitempty"`
+}
+
+func GetVolumeSyncStatus(server string, vid string) (*SyncVolumeResponse, error) {
+ values := make(url.Values)
+ values.Add("volume", vid)
+ jsonBlob, err := util.Post("http://"+server+"/admin/sync/status", values)
+ glog.V(2).Info("sync volume result :", string(jsonBlob))
+ if err != nil {
+ return nil, err
+ }
+ var ret SyncVolumeResponse
+ err = json.Unmarshal(jsonBlob, &ret)
+ if err != nil {
+ return nil, err
+ }
+ if ret.Error != "" {
+ return nil, fmt.Errorf("Volume %s get sync status error: %s", vid, ret.Error)
+ }
+ return &ret, nil
+}
+
+func GetVolumeIdxEntries(server string, vid string, eachEntryFn func(key uint64, offset, size uint32)) error {
+ values := make(url.Values)
+ values.Add("volume", vid)
+ line := make([]byte, 16)
+ err := util.GetBufferStream("http://"+server+"/admin/sync/index", values, line, func(bytes []byte) {
+ key := util.BytesToUint64(bytes[:8])
+ offset := util.BytesToUint32(bytes[8:12])
+ size := util.BytesToUint32(bytes[12:16])
+ eachEntryFn(key, offset, size)
+ })
+ if err != nil {
+ return err
+ }
+ return nil
+}