From 3dd6c452163a85e61cf5c95035468d99733ff931 Mon Sep 17 00:00:00 2001
From: root <root@172.16.5.15>
Date: Thu, 2 Jul 2020 15:47:41 +0800
Subject: [PATCH] add compression type for br backup request

---
 pkg/backup/backup.pb.go | 263 +++++++++++++++++++++++++---------------
 proto/backup.proto      |  10 ++
 2 files changed, 177 insertions(+), 96 deletions(-)

diff --git a/pkg/backup/backup.pb.go b/pkg/backup/backup.pb.go
index 7148998ce..a1602f8d0 100644
--- a/pkg/backup/backup.pb.go
+++ b/pkg/backup/backup.pb.go
@@ -32,6 +32,36 @@ var _ = math.Inf
 // proto package needs to be updated.
 const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package
 
+// algorithm used for compress sst file
+type BackupRequest_CompressionType int32
+
+const (
+	BackupRequest_UNKNOWN BackupRequest_CompressionType = 0
+	BackupRequest_LZ4     BackupRequest_CompressionType = 1
+	BackupRequest_SNAPPY  BackupRequest_CompressionType = 2
+	BackupRequest_ZSTD    BackupRequest_CompressionType = 3
+)
+
+var BackupRequest_CompressionType_name = map[int32]string{
+	0: "UNKNOWN",
+	1: "LZ4",
+	2: "SNAPPY",
+	3: "ZSTD",
+}
+var BackupRequest_CompressionType_value = map[string]int32{
+	"UNKNOWN": 0,
+	"LZ4":     1,
+	"SNAPPY":  2,
+	"ZSTD":    3,
+}
+
+func (x BackupRequest_CompressionType) String() string {
+	return proto.EnumName(BackupRequest_CompressionType_name, int32(x))
+}
+func (BackupRequest_CompressionType) EnumDescriptor() ([]byte, []int) {
+	return fileDescriptor_backup_f13518ccfad72a94, []int{6, 0}
+}
+
 // The message save the metadata of a backup.
 type BackupMeta struct {
 	// ID and version of backuped cluster.
@@ -63,7 +93,7 @@ func (m *BackupMeta) Reset()         { *m = BackupMeta{} }
 func (m *BackupMeta) String() string { return proto.CompactTextString(m) }
 func (*BackupMeta) ProtoMessage()    {}
 func (*BackupMeta) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{0}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{0}
 }
 func (m *BackupMeta) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -176,7 +206,7 @@ func (m *File) Reset()         { *m = File{} }
 func (m *File) String() string { return proto.CompactTextString(m) }
 func (*File) ProtoMessage()    {}
 func (*File) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{1}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{1}
 }
 func (m *File) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -298,7 +328,7 @@ func (m *Schema) Reset()         { *m = Schema{} }
 func (m *Schema) String() string { return proto.CompactTextString(m) }
 func (*Schema) ProtoMessage()    {}
 func (*Schema) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{2}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{2}
 }
 func (m *Schema) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -382,7 +412,7 @@ func (m *RawRange) Reset()         { *m = RawRange{} }
 func (m *RawRange) String() string { return proto.CompactTextString(m) }
 func (*RawRange) ProtoMessage()    {}
 func (*RawRange) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{3}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{3}
 }
 func (m *RawRange) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -444,7 +474,7 @@ func (m *ClusterIDError) Reset()         { *m = ClusterIDError{} }
 func (m *ClusterIDError) String() string { return proto.CompactTextString(m) }
 func (*ClusterIDError) ProtoMessage()    {}
 func (*ClusterIDError) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{4}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{4}
 }
 func (m *ClusterIDError) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -503,7 +533,7 @@ func (m *Error) Reset()         { *m = Error{} }
 func (m *Error) String() string { return proto.CompactTextString(m) }
 func (*Error) ProtoMessage()    {}
 func (*Error) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{5}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{5}
 }
 func (m *Error) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -693,18 +723,19 @@ type BackupRequest struct {
 	StorageBackend *StorageBackend `protobuf:"bytes,9,opt,name=storage_backend,json=storageBackend" json:"storage_backend,omitempty"`
 	// If raw kv mode is enabled, `start_version` and `end_version` will be ignored, and `cf`
 	// specifies which cf to backup.
-	IsRawKv              bool     `protobuf:"varint,10,opt,name=is_raw_kv,json=isRawKv,proto3" json:"is_raw_kv,omitempty"`
-	Cf                   string   `protobuf:"bytes,11,opt,name=cf,proto3" json:"cf,omitempty"`
-	XXX_NoUnkeyedLiteral struct{} `json:"-"`
-	XXX_unrecognized     []byte   `json:"-"`
-	XXX_sizecache        int32    `json:"-"`
+	IsRawKv              bool                          `protobuf:"varint,10,opt,name=is_raw_kv,json=isRawKv,proto3" json:"is_raw_kv,omitempty"`
+	Cf                   string                        `protobuf:"bytes,11,opt,name=cf,proto3" json:"cf,omitempty"`
+	CompressionType      BackupRequest_CompressionType `protobuf:"varint,12,opt,name=compression_type,json=compressionType,proto3,enum=backup.BackupRequest_CompressionType" json:"compression_type,omitempty"`
+	XXX_NoUnkeyedLiteral struct{}                      `json:"-"`
+	XXX_unrecognized     []byte                        `json:"-"`
+	XXX_sizecache        int32                         `json:"-"`
 }
 
 func (m *BackupRequest) Reset()         { *m = BackupRequest{} }
 func (m *BackupRequest) String() string { return proto.CompactTextString(m) }
 func (*BackupRequest) ProtoMessage()    {}
 func (*BackupRequest) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{6}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{6}
 }
 func (m *BackupRequest) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -803,6 +834,13 @@ func (m *BackupRequest) GetCf() string {
 	return ""
 }
 
+func (m *BackupRequest) GetCompressionType() BackupRequest_CompressionType {
+	if m != nil {
+		return m.CompressionType
+	}
+	return BackupRequest_UNKNOWN
+}
+
 type StorageBackend struct {
 	// Types that are valid to be assigned to Backend:
 	//	*StorageBackend_Noop
@@ -819,7 +857,7 @@ func (m *StorageBackend) Reset()         { *m = StorageBackend{} }
 func (m *StorageBackend) String() string { return proto.CompactTextString(m) }
 func (*StorageBackend) ProtoMessage()    {}
 func (*StorageBackend) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{7}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{7}
 }
 func (m *StorageBackend) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -1030,7 +1068,7 @@ func (m *Noop) Reset()         { *m = Noop{} }
 func (m *Noop) String() string { return proto.CompactTextString(m) }
 func (*Noop) ProtoMessage()    {}
 func (*Noop) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{8}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{8}
 }
 func (m *Noop) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -1071,7 +1109,7 @@ func (m *Local) Reset()         { *m = Local{} }
 func (m *Local) String() string { return proto.CompactTextString(m) }
 func (*Local) ProtoMessage()    {}
 func (*Local) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{9}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{9}
 }
 func (m *Local) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -1131,7 +1169,7 @@ func (m *S3) Reset()         { *m = S3{} }
 func (m *S3) String() string { return proto.CompactTextString(m) }
 func (*S3) ProtoMessage()    {}
 func (*S3) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{10}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{10}
 }
 func (m *S3) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -1260,7 +1298,7 @@ func (m *GCS) Reset()         { *m = GCS{} }
 func (m *GCS) String() string { return proto.CompactTextString(m) }
 func (*GCS) ProtoMessage()    {}
 func (*GCS) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{11}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{11}
 }
 func (m *GCS) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -1345,7 +1383,7 @@ func (m *BackupResponse) Reset()         { *m = BackupResponse{} }
 func (m *BackupResponse) String() string { return proto.CompactTextString(m) }
 func (*BackupResponse) ProtoMessage()    {}
 func (*BackupResponse) Descriptor() ([]byte, []int) {
-	return fileDescriptor_backup_30cdb6cdf9418e89, []int{12}
+	return fileDescriptor_backup_f13518ccfad72a94, []int{12}
 }
 func (m *BackupResponse) XXX_Unmarshal(b []byte) error {
 	return m.Unmarshal(b)
@@ -1416,6 +1454,7 @@ func init() {
 	proto.RegisterType((*S3)(nil), "backup.S3")
 	proto.RegisterType((*GCS)(nil), "backup.GCS")
 	proto.RegisterType((*BackupResponse)(nil), "backup.BackupResponse")
+	proto.RegisterEnum("backup.BackupRequest_CompressionType", BackupRequest_CompressionType_name, BackupRequest_CompressionType_value)
 }
 
 // Reference imports to suppress errors if they are not otherwise used.
@@ -1969,6 +2008,11 @@ func (m *BackupRequest) MarshalTo(dAtA []byte) (int, error) {
 		i = encodeVarintBackup(dAtA, i, uint64(len(m.Cf)))
 		i += copy(dAtA[i:], m.Cf)
 	}
+	if m.CompressionType != 0 {
+		dAtA[i] = 0x60
+		i++
+		i = encodeVarintBackup(dAtA, i, uint64(m.CompressionType))
+	}
 	if m.XXX_unrecognized != nil {
 		i += copy(dAtA[i:], m.XXX_unrecognized)
 	}
@@ -2558,6 +2602,9 @@ func (m *BackupRequest) Size() (n int) {
 	if l > 0 {
 		n += 1 + l + sovBackup(uint64(l))
 	}
+	if m.CompressionType != 0 {
+		n += 1 + sovBackup(uint64(m.CompressionType))
+	}
 	if m.XXX_unrecognized != nil {
 		n += len(m.XXX_unrecognized)
 	}
@@ -4220,6 +4267,25 @@ func (m *BackupRequest) Unmarshal(dAtA []byte) error {
 			}
 			m.Cf = string(dAtA[iNdEx:postIndex])
 			iNdEx = postIndex
+		case 12:
+			if wireType != 0 {
+				return fmt.Errorf("proto: wrong wireType = %d for field CompressionType", wireType)
+			}
+			m.CompressionType = 0
+			for shift := uint(0); ; shift += 7 {
+				if shift >= 64 {
+					return ErrIntOverflowBackup
+				}
+				if iNdEx >= l {
+					return io.ErrUnexpectedEOF
+				}
+				b := dAtA[iNdEx]
+				iNdEx++
+				m.CompressionType |= (BackupRequest_CompressionType(b) & 0x7F) << shift
+				if b < 0x80 {
+					break
+				}
+			}
 		default:
 			iNdEx = preIndex
 			skippy, err := skipBackup(dAtA[iNdEx:])
@@ -5420,82 +5486,87 @@ var (
 	ErrIntOverflowBackup   = fmt.Errorf("proto: integer overflow")
 )
 
-func init() { proto.RegisterFile("backup.proto", fileDescriptor_backup_30cdb6cdf9418e89) }
-
-var fileDescriptor_backup_30cdb6cdf9418e89 = []byte{
-	// 1175 bytes of a gzipped FileDescriptorProto
-	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x56, 0x4f, 0x8f, 0xdb, 0x44,
-	0x14, 0x8f, 0x1d, 0x27, 0xb1, 0x5f, 0xfe, 0x76, 0x54, 0x4a, 0xb4, 0xa5, 0xdb, 0xc8, 0x55, 0x21,
-	0x70, 0x48, 0xd1, 0x06, 0x7a, 0xe1, 0x80, 0x9a, 0x6d, 0xe9, 0xb6, 0x5b, 0x50, 0x35, 0x91, 0xb8,
-	0x5a, 0x8e, 0x3d, 0xc9, 0x5a, 0x71, 0x6c, 0x33, 0x33, 0x49, 0x1b, 0xbe, 0x04, 0x57, 0xbe, 0x00,
-	0x12, 0x07, 0x6e, 0x7c, 0x89, 0x4a, 0x70, 0xe0, 0x82, 0xc4, 0x11, 0x15, 0x3e, 0x08, 0x9a, 0x37,
-	0xe3, 0x74, 0x43, 0xe9, 0x2e, 0x42, 0x9c, 0x76, 0xde, 0xef, 0xf7, 0xe6, 0x79, 0xe6, 0x37, 0xef,
-	0xfd, 0x36, 0xd0, 0x9a, 0x85, 0xd1, 0x72, 0x5d, 0x8c, 0x0a, 0x9e, 0xcb, 0x9c, 0xd4, 0x75, 0x74,
-	0xd0, 0x5e, 0x6e, 0x78, 0x11, 0x15, 0x33, 0x0d, 0x1f, 0xb4, 0x19, 0xe7, 0x39, 0xdf, 0x85, 0x57,
-	0x17, 0xf9, 0x22, 0xc7, 0xe5, 0x1d, 0xb5, 0x32, 0x68, 0x97, 0xaf, 0x85, 0xc4, 0xa5, 0x06, 0xfc,
-	0x5f, 0x6d, 0x80, 0x09, 0xd6, 0xfb, 0x9c, 0xc9, 0x90, 0xdc, 0x00, 0x88, 0xd2, 0xb5, 0x90, 0x8c,
-	0x07, 0x49, 0xdc, 0xb7, 0x06, 0xd6, 0xd0, 0xa1, 0x9e, 0x41, 0x1e, 0xc5, 0xe4, 0x3d, 0xe8, 0x96,
-	0xf4, 0x86, 0x71, 0x91, 0xe4, 0x59, 0xdf, 0x1e, 0x58, 0x43, 0x8f, 0x76, 0x0c, 0xfc, 0xa5, 0x46,
-	0x89, 0x0f, 0xb5, 0x79, 0x92, 0x32, 0xd1, 0x77, 0x06, 0xd5, 0x61, 0xf3, 0xa8, 0x35, 0x32, 0x37,
-	0xf8, 0x2c, 0x49, 0x19, 0xd5, 0x14, 0xb9, 0x05, 0x6d, 0x21, 0x43, 0x2e, 0x77, 0xa5, 0x6a, 0xf8,
-	0xb9, 0x16, 0x82, 0x65, 0xa1, 0x9b, 0xd0, 0x64, 0x59, 0xbc, 0x4b, 0xa9, 0x63, 0x0a, 0xb0, 0x2c,
-	0x2e, 0x13, 0x86, 0xd0, 0x10, 0xd1, 0x19, 0x5b, 0x85, 0xa2, 0xdf, 0xc0, 0x6f, 0x75, 0xca, 0x6f,
-	0x4d, 0x11, 0xa6, 0x25, 0x4d, 0x0e, 0xc0, 0x4b, 0x44, 0xc0, 0xc3, 0x67, 0xc1, 0x72, 0xd3, 0x77,
-	0x07, 0xd6, 0xd0, 0xa5, 0x8d, 0x44, 0xd0, 0xf0, 0xd9, 0xe9, 0x86, 0xdc, 0x01, 0x50, 0x04, 0x0f,
-	0xb3, 0x05, 0x13, 0x7d, 0x0f, 0x0b, 0xf5, 0xca, 0x42, 0x34, 0x7c, 0x46, 0x15, 0x41, 0x3d, 0x6e,
-	0x56, 0x82, 0x10, 0x70, 0xe2, 0x38, 0x15, 0x7d, 0x18, 0x58, 0xc3, 0x16, 0xc5, 0xf5, 0x63, 0xc7,
-	0xad, 0xf6, 0x1c, 0xea, 0x14, 0xa1, 0x3c, 0xf3, 0x7f, 0xb0, 0xc1, 0x51, 0x97, 0x55, 0x89, 0x59,
-	0xb8, 0x62, 0xa8, 0xa5, 0x47, 0x71, 0x4d, 0xae, 0x41, 0x5d, 0x9c, 0x85, 0x47, 0x1f, 0xdf, 0x45,
-	0xf5, 0x5a, 0xd4, 0x44, 0xe4, 0x3a, 0x78, 0x5a, 0x91, 0x25, 0xdb, 0xf6, 0xab, 0x48, 0xb9, 0x08,
-	0x9c, 0xb2, 0x2d, 0x79, 0x1b, 0x1a, 0x4a, 0x09, 0x45, 0x39, 0x7a, 0x17, 0xcb, 0x62, 0x45, 0xfc,
-	0x3f, 0x3a, 0x1e, 0x80, 0x1b, 0xf1, 0xe8, 0xee, 0x47, 0xcf, 0x73, 0xde, 0x6f, 0x20, 0xbb, 0x8b,
-	0xd5, 0xb9, 0x64, 0x2e, 0xc3, 0x34, 0x58, 0x6e, 0x04, 0x2a, 0xe7, 0x50, 0x17, 0x81, 0xd3, 0x8d,
-	0x50, 0x95, 0x35, 0x39, 0xdb, 0x4a, 0xd4, 0x0e, 0x2b, 0x23, 0x34, 0x51, 0x08, 0xe9, 0x80, 0x1d,
-	0xcd, 0x51, 0x28, 0x8f, 0xda, 0xd1, 0x5c, 0x29, 0x22, 0x92, 0xaf, 0x59, 0xbf, 0x89, 0x99, 0xb8,
-	0xf6, 0x7f, 0xb4, 0xa0, 0xae, 0xdf, 0x4b, 0xa5, 0xc7, 0x33, 0x94, 0xab, 0x45, 0xed, 0x78, 0x46,
-	0xae, 0x42, 0x4d, 0x86, 0xb3, 0x94, 0x19, 0xad, 0x74, 0xb0, 0x77, 0xdc, 0xea, 0x45, 0xc7, 0x75,
-	0x2e, 0x3e, 0x6e, 0xed, 0xb5, 0xe3, 0xbe, 0x0f, 0x3d, 0x99, 0xcc, 0xd3, 0x50, 0x9c, 0x05, 0x9c,
-	0x15, 0x69, 0x12, 0x85, 0x02, 0xe5, 0x6a, 0xd3, 0xae, 0xc1, 0xa9, 0x81, 0xfd, 0xa7, 0xe0, 0x96,
-	0xbd, 0xb1, 0xff, 0x76, 0xd6, 0x9b, 0xdf, 0xce, 0xde, 0x7b, 0x3b, 0xad, 0x4d, 0xb5, 0xd4, 0xc6,
-	0xbf, 0x0f, 0x9d, 0x63, 0x33, 0x6d, 0xf7, 0x1f, 0xa8, 0x79, 0x26, 0x7d, 0x68, 0x44, 0x6b, 0xce,
-	0x59, 0x26, 0xcd, 0x38, 0x96, 0xa1, 0x62, 0x38, 0xfb, 0x6a, 0xcd, 0x84, 0xc4, 0xa2, 0x0e, 0x2d,
-	0x43, 0xff, 0x67, 0x0b, 0x6a, 0x7a, 0x77, 0x0f, 0xaa, 0x2b, 0xb1, 0x30, 0xcd, 0xa7, 0x96, 0x64,
-	0x02, 0xbd, 0x57, 0x13, 0x1e, 0xa0, 0x67, 0xe0, 0xf7, 0x9b, 0x47, 0xd7, 0xca, 0x7e, 0xdf, 0x3f,
-	0xc1, 0x49, 0x65, 0x37, 0xdd, 0x8f, 0x62, 0x5d, 0x75, 0x04, 0xee, 0x72, 0x63, 0xf6, 0x3a, 0xb8,
-	0xf7, 0xca, 0xa8, 0x34, 0xa3, 0x53, 0xb6, 0x2d, 0xb7, 0x35, 0x96, 0x1b, 0x9d, 0x3f, 0x86, 0x16,
-	0x67, 0x8b, 0x24, 0xcf, 0xcc, 0x9e, 0x1a, 0xee, 0xe9, 0x8c, 0x4a, 0xc7, 0x2a, 0x37, 0x34, 0x75,
-	0x16, 0x86, 0x13, 0x17, 0xea, 0x31, 0x93, 0x61, 0x92, 0xfa, 0x7f, 0xda, 0xd0, 0xd6, 0x1e, 0x45,
-	0xf5, 0x05, 0x2f, 0xb3, 0xa9, 0xbd, 0xb7, 0xb0, 0xdf, 0xfc, 0x16, 0xd5, 0x8b, 0xe7, 0xc8, 0xb9,
-	0x7c, 0x8e, 0x6a, 0xaf, 0xcd, 0xd1, 0x0d, 0xe5, 0x24, 0x92, 0x05, 0x69, 0xb2, 0x4a, 0xa4, 0x99,
-	0x24, 0x4f, 0x21, 0x4f, 0x14, 0x40, 0x06, 0xd0, 0x8c, 0xf2, 0x4c, 0x3f, 0x61, 0xb4, 0xc5, 0x61,
-	0x6a, 0xd3, 0xf3, 0x10, 0xf9, 0x14, 0xba, 0x42, 0xe6, 0x3c, 0x5c, 0xb0, 0x40, 0xbd, 0x07, 0xcb,
-	0x62, 0x9c, 0xa9, 0x73, 0xef, 0x33, 0xd5, 0xf4, 0x44, 0xb3, 0xb4, 0x23, 0xf6, 0xe2, 0x7d, 0x9f,
-	0x83, 0x7d, 0x9f, 0xd3, 0xfd, 0xd6, 0x2c, 0xfb, 0xed, 0xb1, 0xe3, 0xd6, 0x7b, 0x0d, 0x63, 0x59,
-	0xdf, 0x59, 0xd0, 0xd9, 0x2f, 0x4d, 0x7c, 0x70, 0xb2, 0x3c, 0x2f, 0x50, 0xe1, 0x73, 0x2e, 0xfe,
-	0x45, 0x9e, 0x17, 0x27, 0x15, 0x8a, 0x1c, 0xb9, 0x0d, 0xb5, 0x34, 0x8f, 0xc2, 0x14, 0x85, 0x6e,
-	0x1e, 0xb5, 0xcb, 0xa4, 0x27, 0x0a, 0x3c, 0xa9, 0x50, 0xcd, 0x92, 0x77, 0xc0, 0x16, 0x63, 0xd3,
-	0x69, 0xb0, 0xbb, 0xc9, 0xf8, 0xa4, 0x42, 0x6d, 0x31, 0x26, 0x37, 0xa1, 0xba, 0x88, 0x84, 0x69,
-	0xa6, 0x66, 0x49, 0x3f, 0x3c, 0x9e, 0x9e, 0x54, 0xa8, 0x62, 0x26, 0x1e, 0x34, 0x8c, 0x1a, 0x7e,
-	0x1d, 0x1c, 0x75, 0x00, 0xff, 0x3a, 0xd4, 0xf0, 0x1b, 0xca, 0x50, 0xd4, 0x05, 0x4a, 0x8b, 0xc5,
-	0xcb, 0xfc, 0x64, 0x83, 0x3d, 0x1d, 0x2b, 0x9b, 0x60, 0x59, 0x5c, 0xe4, 0x89, 0x19, 0x1f, 0x8f,
-	0xee, 0x62, 0xe5, 0xc2, 0xba, 0xdf, 0xcc, 0xff, 0x30, 0x13, 0x29, 0x7c, 0xb6, 0x8e, 0x96, 0x4c,
-	0x9a, 0xb9, 0x34, 0x91, 0xc2, 0x0b, 0xce, 0xe6, 0xc9, 0x73, 0x3c, 0xa6, 0x47, 0x4d, 0xa4, 0xfb,
-	0x46, 0x3f, 0x58, 0x94, 0x86, 0x42, 0x7b, 0x8a, 0xa7, 0xfa, 0x06, 0xc1, 0x63, 0x85, 0xa9, 0x41,
-	0x14, 0x82, 0xa1, 0x91, 0x78, 0x54, 0x2d, 0x15, 0x12, 0x46, 0x29, 0x76, 0x88, 0x47, 0xd5, 0x52,
-	0xb5, 0x4e, 0x18, 0x45, 0x4c, 0x08, 0x6c, 0x4e, 0x17, 0x09, 0x4f, 0x23, 0xaa, 0x3f, 0x3f, 0x80,
-	0x2b, 0x82, 0x45, 0x9c, 0xc9, 0xe0, 0x5c, 0x96, 0x87, 0x59, 0x5d, 0x4d, 0xdc, 0xdb, 0xe5, 0x0e,
-	0xa1, 0x37, 0xcf, 0x79, 0xc4, 0x02, 0x25, 0x46, 0x20, 0xe4, 0x36, 0x65, 0xa6, 0x15, 0x3a, 0x88,
-	0x3f, 0x0d, 0xe5, 0xd9, 0x54, 0xa1, 0xe4, 0x16, 0x74, 0x84, 0x60, 0xc1, 0x72, 0x85, 0xf5, 0xd4,
-	0x38, 0xe9, 0xee, 0x68, 0x0a, 0xc1, 0x4e, 0x57, 0xaa, 0xd8, 0xa3, 0xd8, 0x7f, 0x61, 0x41, 0xf5,
-	0xe1, 0xf1, 0xf4, 0x32, 0x39, 0x8d, 0x6c, 0xf6, 0x1b, 0x64, 0xab, 0x5e, 0x2c, 0x9b, 0xf3, 0x0f,
-	0xb2, 0xdd, 0x86, 0x4e, 0xc1, 0x59, 0xcc, 0xe6, 0x49, 0xc6, 0xe2, 0x40, 0xe9, 0xa5, 0xc5, 0x6d,
-	0xbf, 0x42, 0xef, 0x45, 0xa9, 0xf2, 0xec, 0x48, 0x01, 0x99, 0x4c, 0xc2, 0x54, 0x04, 0xb3, 0x34,
-	0x9f, 0x19, 0xa9, 0xbb, 0xe7, 0xf0, 0x49, 0x9a, 0xcf, 0xfc, 0x6f, 0x2c, 0xe8, 0x94, 0x66, 0x22,
-	0x8a, 0x3c, 0x13, 0x4a, 0x82, 0x9a, 0xf6, 0x25, 0x6b, 0xbf, 0x83, 0xd1, 0x87, 0xa8, 0xe6, 0xfe,
-	0xa3, 0xa7, 0xfc, 0x8b, 0xdf, 0x41, 0x47, 0x0f, 0xa0, 0xae, 0x0f, 0x44, 0x3e, 0x01, 0xf3, 0xdb,
-	0x8e, 0xbc, 0x55, 0x26, 0xee, 0xf9, 0xde, 0xc1, 0xb5, 0xbf, 0xc3, 0xfa, 0x06, 0x7e, 0xe5, 0x43,
-	0x6b, 0xf2, 0xee, 0x6f, 0xdf, 0xbb, 0xd6, 0x8b, 0x97, 0x87, 0xd6, 0x2f, 0x2f, 0x0f, 0xad, 0xdf,
-	0x5f, 0x1e, 0x5a, 0xdf, 0xfe, 0x71, 0x58, 0x81, 0x5e, 0xce, 0x17, 0x23, 0x99, 0x2c, 0x37, 0xa3,
-	0xe5, 0x06, 0x7f, 0xf1, 0xcd, 0xea, 0xf8, 0x67, 0xfc, 0x57, 0x00, 0x00, 0x00, 0xff, 0xff, 0xef,
-	0xf4, 0xfe, 0x9c, 0x55, 0x0a, 0x00, 0x00,
+func init() { proto.RegisterFile("backup.proto", fileDescriptor_backup_f13518ccfad72a94) }
+
+var fileDescriptor_backup_f13518ccfad72a94 = []byte{
+	// 1263 bytes of a gzipped FileDescriptorProto
+	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xac, 0x56, 0xcf, 0x8e, 0x1b, 0xc5,
+	0x13, 0xf6, 0x8c, 0xc7, 0xf6, 0x4c, 0xf9, 0xdf, 0xa4, 0x95, 0x5f, 0x7e, 0xd6, 0x86, 0x6c, 0xac,
+	0x89, 0x02, 0x86, 0x83, 0x83, 0x76, 0x43, 0x2e, 0x08, 0xa1, 0x78, 0x13, 0xb2, 0xc9, 0x86, 0x65,
+	0xd5, 0x0e, 0x20, 0x72, 0x19, 0x8d, 0x67, 0xda, 0xde, 0x91, 0xc7, 0x33, 0x43, 0xf7, 0xac, 0x13,
+	0xf3, 0x12, 0x5c, 0x79, 0x01, 0x24, 0x0e, 0xdc, 0x78, 0x89, 0x48, 0x70, 0xe0, 0x82, 0xc4, 0x11,
+	0x85, 0x67, 0xe0, 0x8e, 0xba, 0xba, 0xc7, 0x59, 0xe7, 0xcf, 0x2e, 0x42, 0x9c, 0xdc, 0xf5, 0x55,
+	0x75, 0x75, 0xf7, 0x57, 0x55, 0xdf, 0x18, 0x5a, 0x93, 0x20, 0x9c, 0x9f, 0xe4, 0xc3, 0x9c, 0x67,
+	0x45, 0x46, 0xea, 0xca, 0xda, 0x6a, 0xcf, 0x97, 0x3c, 0x0f, 0xf3, 0x89, 0x82, 0xb7, 0xda, 0x8c,
+	0xf3, 0x8c, 0xaf, 0xcd, 0x8b, 0xb3, 0x6c, 0x96, 0xe1, 0xf2, 0x86, 0x5c, 0x69, 0xb4, 0xcb, 0x4f,
+	0x44, 0x81, 0x4b, 0x05, 0x78, 0xbf, 0x99, 0x00, 0x23, 0xcc, 0xf7, 0x29, 0x2b, 0x02, 0x72, 0x05,
+	0x20, 0x4c, 0x4e, 0x44, 0xc1, 0xb8, 0x1f, 0x47, 0x3d, 0xa3, 0x6f, 0x0c, 0x2c, 0xea, 0x68, 0xe4,
+	0x7e, 0x44, 0xde, 0x81, 0x6e, 0xe9, 0x5e, 0x32, 0x2e, 0xe2, 0x2c, 0xed, 0x99, 0x7d, 0x63, 0xe0,
+	0xd0, 0x8e, 0x86, 0xbf, 0x50, 0x28, 0xf1, 0xa0, 0x36, 0x8d, 0x13, 0x26, 0x7a, 0x56, 0xbf, 0x3a,
+	0x68, 0xee, 0xb4, 0x86, 0xfa, 0x05, 0x9f, 0xc4, 0x09, 0xa3, 0xca, 0x45, 0xae, 0x41, 0x5b, 0x14,
+	0x01, 0x2f, 0xd6, 0xa9, 0x6a, 0x78, 0x5c, 0x0b, 0xc1, 0x32, 0xd1, 0x55, 0x68, 0xb2, 0x34, 0x5a,
+	0x87, 0xd4, 0x31, 0x04, 0x58, 0x1a, 0x95, 0x01, 0x03, 0x68, 0x88, 0xf0, 0x98, 0x2d, 0x02, 0xd1,
+	0x6b, 0xe0, 0x59, 0x9d, 0xf2, 0xac, 0x31, 0xc2, 0xb4, 0x74, 0x93, 0x2d, 0x70, 0x62, 0xe1, 0xf3,
+	0xe0, 0x89, 0x3f, 0x5f, 0xf6, 0xec, 0xbe, 0x31, 0xb0, 0x69, 0x23, 0x16, 0x34, 0x78, 0x72, 0xb0,
+	0x24, 0x37, 0x00, 0xa4, 0x83, 0x07, 0xe9, 0x8c, 0x89, 0x9e, 0x83, 0x89, 0xdc, 0x32, 0x11, 0x0d,
+	0x9e, 0x50, 0xe9, 0xa0, 0x0e, 0xd7, 0x2b, 0x41, 0x08, 0x58, 0x51, 0x94, 0x88, 0x1e, 0xf4, 0x8d,
+	0x41, 0x8b, 0xe2, 0xfa, 0x81, 0x65, 0x57, 0x5d, 0x8b, 0x5a, 0x79, 0x50, 0x1c, 0x7b, 0x3f, 0x9a,
+	0x60, 0xc9, 0xc7, 0xca, 0xc0, 0x34, 0x58, 0x30, 0xe4, 0xd2, 0xa1, 0xb8, 0x26, 0x97, 0xa0, 0x2e,
+	0x8e, 0x83, 0x9d, 0x0f, 0x6e, 0x21, 0x7b, 0x2d, 0xaa, 0x2d, 0x72, 0x19, 0x1c, 0xc5, 0xc8, 0x9c,
+	0xad, 0x7a, 0x55, 0x74, 0xd9, 0x08, 0x1c, 0xb0, 0x15, 0xf9, 0x3f, 0x34, 0x24, 0x13, 0xd2, 0x65,
+	0xa9, 0x5d, 0x2c, 0x8d, 0xa4, 0xe3, 0xbf, 0xe1, 0x71, 0x0b, 0xec, 0x90, 0x87, 0xb7, 0x6e, 0x3e,
+	0xcd, 0x78, 0xaf, 0x81, 0xde, 0xb5, 0x2d, 0xef, 0x55, 0x64, 0x45, 0x90, 0xf8, 0xf3, 0xa5, 0x40,
+	0xe6, 0x2c, 0x6a, 0x23, 0x70, 0xb0, 0x14, 0x32, 0xb3, 0x72, 0x4e, 0x56, 0x05, 0x72, 0x87, 0x99,
+	0x11, 0x1a, 0x49, 0x84, 0x74, 0xc0, 0x0c, 0xa7, 0x48, 0x94, 0x43, 0xcd, 0x70, 0x2a, 0x19, 0x11,
+	0xf1, 0x37, 0xac, 0xd7, 0xc4, 0x48, 0x5c, 0x7b, 0x3f, 0x19, 0x50, 0x57, 0xf5, 0x92, 0xe1, 0xd1,
+	0x04, 0xe9, 0x6a, 0x51, 0x33, 0x9a, 0x90, 0x8b, 0x50, 0x2b, 0x82, 0x49, 0xc2, 0x34, 0x57, 0xca,
+	0xd8, 0xb8, 0x6e, 0xf5, 0xac, 0xeb, 0x5a, 0x67, 0x5f, 0xb7, 0xf6, 0xca, 0x75, 0xdf, 0x05, 0xb7,
+	0x88, 0xa7, 0x49, 0x20, 0x8e, 0x7d, 0xce, 0xf2, 0x24, 0x0e, 0x03, 0x81, 0x74, 0xb5, 0x69, 0x57,
+	0xe3, 0x54, 0xc3, 0xde, 0x11, 0xd8, 0x65, 0x6f, 0x6c, 0xd6, 0xce, 0x78, 0x73, 0xed, 0xcc, 0x8d,
+	0xda, 0x29, 0x6e, 0xaa, 0x25, 0x37, 0xde, 0x1d, 0xe8, 0xec, 0xe9, 0x69, 0xbb, 0x73, 0x57, 0xce,
+	0x33, 0xe9, 0x41, 0x23, 0x3c, 0xe1, 0x9c, 0xa5, 0x85, 0x1e, 0xc7, 0xd2, 0x94, 0x1e, 0xce, 0xbe,
+	0x3e, 0x61, 0xa2, 0xc0, 0xa4, 0x16, 0x2d, 0x4d, 0xef, 0x17, 0x03, 0x6a, 0x6a, 0xb7, 0x0b, 0xd5,
+	0x85, 0x98, 0xe9, 0xe6, 0x93, 0x4b, 0x32, 0x02, 0xf7, 0xc5, 0x84, 0xfb, 0xa8, 0x19, 0x78, 0x7e,
+	0x73, 0xe7, 0x52, 0xd9, 0xef, 0x9b, 0x37, 0xd8, 0xaf, 0xac, 0xa7, 0xfb, 0x7e, 0xa4, 0xb2, 0x0e,
+	0xc1, 0x9e, 0x2f, 0xf5, 0x5e, 0x0b, 0xf7, 0x5e, 0x18, 0x96, 0x62, 0x74, 0xc0, 0x56, 0xe5, 0xb6,
+	0xc6, 0x7c, 0xa9, 0xe2, 0x77, 0xa1, 0xc5, 0xd9, 0x2c, 0xce, 0x52, 0xbd, 0xa7, 0x86, 0x7b, 0x3a,
+	0xc3, 0x52, 0xb1, 0xca, 0x0d, 0x4d, 0x15, 0x85, 0xe6, 0xc8, 0x86, 0x7a, 0xc4, 0x8a, 0x20, 0x4e,
+	0xbc, 0xbf, 0xaa, 0xd0, 0x56, 0x1a, 0x45, 0xd5, 0x03, 0xcf, 0x93, 0xa9, 0x8d, 0x5a, 0x98, 0x6f,
+	0xae, 0x45, 0xf5, 0xec, 0x39, 0xb2, 0xce, 0x9f, 0xa3, 0xda, 0x2b, 0x73, 0x74, 0x45, 0x2a, 0x49,
+	0xc1, 0xfc, 0x24, 0x5e, 0xc4, 0x85, 0x9e, 0x24, 0x47, 0x22, 0x0f, 0x25, 0x40, 0xfa, 0xd0, 0x0c,
+	0xb3, 0x54, 0x95, 0x30, 0x5c, 0xe1, 0x30, 0xb5, 0xe9, 0x69, 0x88, 0x7c, 0x0c, 0x5d, 0x51, 0x64,
+	0x3c, 0x98, 0x31, 0x5f, 0xd6, 0x83, 0xa5, 0x11, 0xce, 0xd4, 0xa9, 0xfa, 0x8c, 0x95, 0x7b, 0xa4,
+	0xbc, 0xb4, 0x23, 0x36, 0xec, 0x4d, 0x9d, 0x83, 0x4d, 0x9d, 0x53, 0xfd, 0xd6, 0x5c, 0xcf, 0xe2,
+	0x11, 0xb8, 0x61, 0xb6, 0xc8, 0x39, 0x13, 0xf2, 0xf2, 0x7e, 0xb1, 0xca, 0x59, 0xaf, 0xd5, 0x37,
+	0x06, 0x9d, 0x9d, 0xeb, 0xe5, 0x69, 0x1b, 0xcc, 0x0f, 0xf7, 0x5e, 0x44, 0x3f, 0x5a, 0xe5, 0x8c,
+	0x76, 0xc3, 0x4d, 0xc0, 0xfb, 0x08, 0xba, 0x2f, 0xc5, 0x90, 0x26, 0x34, 0x3e, 0x3f, 0x3c, 0x38,
+	0xfc, 0xec, 0xcb, 0x43, 0xb7, 0x42, 0x1a, 0x50, 0x7d, 0xf8, 0xf8, 0xa6, 0x6b, 0x10, 0x80, 0xfa,
+	0xf8, 0xf0, 0xf6, 0xd1, 0xd1, 0x57, 0xae, 0x49, 0x6c, 0xb0, 0x1e, 0x8f, 0x1f, 0xdd, 0x71, 0xab,
+	0x0f, 0x2c, 0xbb, 0xee, 0x36, 0xb4, 0x86, 0x7e, 0x6f, 0x40, 0x67, 0xf3, 0xad, 0xc4, 0x03, 0x2b,
+	0xcd, 0xb2, 0x1c, 0x4b, 0x7e, 0xea, 0xb3, 0x72, 0x98, 0x65, 0xf9, 0x7e, 0x85, 0xa2, 0x8f, 0x5c,
+	0x87, 0x5a, 0x92, 0x85, 0x41, 0x82, 0x95, 0x6f, 0xee, 0xb4, 0xcb, 0xa0, 0x87, 0x12, 0xdc, 0xaf,
+	0x50, 0xe5, 0x25, 0x6f, 0x81, 0x29, 0x76, 0x75, 0xeb, 0xc3, 0x9a, 0xda, 0xdd, 0xfd, 0x0a, 0x35,
+	0xc5, 0x2e, 0xb9, 0x0a, 0xd5, 0x59, 0x28, 0x74, 0x77, 0x37, 0x4b, 0xf7, 0xbd, 0xbd, 0xf1, 0x7e,
+	0x85, 0x4a, 0xcf, 0xc8, 0x81, 0x86, 0x2e, 0x8f, 0x57, 0x07, 0x4b, 0x5e, 0xc0, 0xbb, 0x0c, 0x35,
+	0x3c, 0x43, 0x2a, 0x9c, 0x7c, 0x40, 0xa9, 0xf9, 0xf8, 0x98, 0x9f, 0x4d, 0x30, 0xc7, 0xbb, 0x52,
+	0xb7, 0x58, 0x1a, 0xe5, 0x59, 0xac, 0xe7, 0xd9, 0xa1, 0x6b, 0x5b, 0x7e, 0x16, 0xd4, 0x00, 0xe8,
+	0x8f, 0xaa, 0xb6, 0x24, 0x3e, 0x39, 0x09, 0xe7, 0xac, 0xd0, 0x42, 0xa1, 0x2d, 0x89, 0xe7, 0x9c,
+	0x4d, 0xe3, 0xa7, 0x78, 0x4d, 0x87, 0x6a, 0x4b, 0x35, 0xb2, 0xea, 0xa0, 0x30, 0x09, 0x84, 0x12,
+	0x39, 0x47, 0x36, 0x32, 0x82, 0x7b, 0x12, 0x93, 0xca, 0x20, 0x04, 0x43, 0x65, 0x73, 0xa8, 0x5c,
+	0x4a, 0x24, 0x08, 0x13, 0x6c, 0x59, 0x87, 0xca, 0xa5, 0xec, 0xe5, 0x20, 0x0c, 0x99, 0x10, 0x38,
+	0x2d, 0x36, 0x3a, 0x1c, 0x85, 0xc8, 0x81, 0x79, 0x0f, 0x2e, 0x08, 0x16, 0x72, 0x56, 0xf8, 0xa7,
+	0xa2, 0x1c, 0x8c, 0xea, 0x2a, 0xc7, 0xed, 0x75, 0xec, 0x00, 0xdc, 0x69, 0xc6, 0x43, 0xe6, 0x4b,
+	0x32, 0x7c, 0x51, 0xac, 0x12, 0xa6, 0x7b, 0xb3, 0x83, 0xf8, 0x51, 0x50, 0x1c, 0x8f, 0x25, 0x4a,
+	0xae, 0x41, 0x47, 0x08, 0xe6, 0xcf, 0x17, 0x98, 0x4f, 0xce, 0xb7, 0x6a, 0xd7, 0xa6, 0x10, 0xec,
+	0x60, 0x21, 0x93, 0xdd, 0x8f, 0xbc, 0x67, 0x06, 0x54, 0xef, 0xed, 0x8d, 0xcf, 0xa3, 0x53, 0xd3,
+	0x66, 0xbe, 0x81, 0xb6, 0xea, 0xd9, 0xb4, 0x59, 0xaf, 0xa1, 0xed, 0x3a, 0x74, 0x72, 0xce, 0x22,
+	0x36, 0x8d, 0x53, 0x16, 0xf9, 0x92, 0x2f, 0x45, 0x6e, 0xfb, 0x05, 0x7a, 0x3b, 0x4c, 0xe4, 0x47,
+	0x24, 0x94, 0x40, 0x5a, 0xc4, 0x41, 0x22, 0xfc, 0x49, 0x92, 0x4d, 0x34, 0xd5, 0xdd, 0x53, 0xf8,
+	0x28, 0xc9, 0x26, 0xde, 0xb7, 0x06, 0x74, 0xca, 0x19, 0x13, 0x79, 0x96, 0x0a, 0x49, 0x41, 0x4d,
+	0x09, 0xa5, 0xb1, 0xd9, 0xc1, 0x28, 0x8c, 0x54, 0xf9, 0xfe, 0xa5, 0xc8, 0xfd, 0x83, 0x3f, 0x66,
+	0x3b, 0x77, 0xa1, 0xae, 0x2e, 0x44, 0x3e, 0x04, 0xfd, 0x67, 0x93, 0xfc, 0xef, 0xb5, 0x72, 0xb0,
+	0x75, 0xe9, 0x65, 0x58, 0xbd, 0xc0, 0xab, 0xbc, 0x6f, 0x8c, 0xde, 0xfe, 0xfd, 0x07, 0xdb, 0x78,
+	0xf6, 0x7c, 0xdb, 0xf8, 0xf5, 0xf9, 0xb6, 0xf1, 0xc7, 0xf3, 0x6d, 0xe3, 0xbb, 0x3f, 0xb7, 0x2b,
+	0xe0, 0x66, 0x7c, 0x36, 0x2c, 0xe2, 0xf9, 0x72, 0x38, 0x5f, 0xe2, 0x5f, 0xd0, 0x49, 0x1d, 0x7f,
+	0x76, 0xff, 0x0e, 0x00, 0x00, 0xff, 0xff, 0xd2, 0x64, 0xee, 0x78, 0xe6, 0x0a, 0x00, 0x00,
 }
diff --git a/proto/backup.proto b/proto/backup.proto
index ec349ad67..fc5014d63 100644
--- a/proto/backup.proto
+++ b/proto/backup.proto
@@ -116,6 +116,16 @@ message BackupRequest {
     // specifies which cf to backup.
     bool is_raw_kv = 10;
     string cf = 11;
+    
+    // algorithm used for compress sst file
+    enum CompressionType {
+        UNKNOWN = 0;
+        LZ4 = 1;
+        SNAPPY = 2;
+        ZSTD = 3;
+    }
+
+    CompressionType compression_type = 12;
 }
 
 message StorageBackend {