seaweedfs/weed/filer/hbase/hbase_store_kv.go

76 lines
2.2 KiB
Go
Raw Normal View History

2020-12-24 05:44:53 +00:00
package hbase
import (
"context"
"github.com/chrislusf/seaweedfs/weed/filer"
"github.com/tsuna/gohbase/hrpc"
2020-12-24 20:10:35 +00:00
"time"
2020-12-24 05:44:53 +00:00
)
const(
COLUMN_NAME = "a"
)
func (store *HbaseStore) KvPut(ctx context.Context, key []byte, value []byte) (err error) {
2020-12-24 20:10:35 +00:00
return store.doPut(ctx, store.cfKv, key, value, 0)
2020-12-24 05:44:53 +00:00
}
func (store *HbaseStore) KvGet(ctx context.Context, key []byte) (value []byte, err error) {
return store.doGet(ctx, store.cfKv, key)
}
func (store *HbaseStore) KvDelete(ctx context.Context, key []byte) (err error) {
return store.doDelete(ctx, store.cfKv, key)
}
2020-12-24 20:10:35 +00:00
func (store *HbaseStore) doPut(ctx context.Context, cf string, key, value []byte, ttlSecond int32) (err error) {
if ttlSecond > 0 {
return store.doPutWithOptions(ctx, cf, key, value, hrpc.Durability(hrpc.AsyncWal), hrpc.TTL(time.Duration(ttlSecond)*time.Second))
}
return store.doPutWithOptions(ctx, cf, key, value, hrpc.Durability(hrpc.AsyncWal))
}
func (store *HbaseStore) doPutWithOptions(ctx context.Context, cf string, key, value []byte, options ...func(hrpc.Call) error) (err error) {
2020-12-24 07:23:05 +00:00
values := map[string]map[string][]byte{cf: map[string][]byte{}}
2020-12-24 05:44:53 +00:00
values[cf][COLUMN_NAME] = value
2020-12-24 20:10:35 +00:00
putRequest, err := hrpc.NewPut(ctx, store.table, key, values, options...)
2020-12-24 05:44:53 +00:00
if err != nil {
return err
}
_, err = store.Client.Put(putRequest)
if err != nil {
return err
}
return nil
}
func (store *HbaseStore) doGet(ctx context.Context, cf string, key []byte) (value []byte, err error) {
family := map[string][]string{cf: {COLUMN_NAME}}
getRequest, err := hrpc.NewGet(context.Background(), store.table, key, hrpc.Families(family))
if err != nil {
return nil, err
}
getResp, err := store.Client.Get(getRequest)
if err != nil {
return nil, err
}
if len(getResp.Cells) == 0 {
return nil, filer.ErrKvNotFound
}
return getResp.Cells[0].Value, nil
}
func (store *HbaseStore) doDelete(ctx context.Context, cf string, key []byte) (err error) {
2020-12-24 07:23:05 +00:00
values := map[string]map[string][]byte{cf: map[string][]byte{}}
2020-12-24 05:44:53 +00:00
values[cf][COLUMN_NAME] = nil
2020-12-24 20:10:35 +00:00
deleteRequest, err := hrpc.NewDel(ctx, store.table, key, values, hrpc.Durability(hrpc.AsyncWal))
2020-12-24 05:44:53 +00:00
if err != nil {
return err
}
_, err = store.Client.Delete(deleteRequest)
if err != nil {
return err
}
return nil
}