You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
64 lines
1.6 KiB
64 lines
1.6 KiB
package elastic
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog"
|
|
"github.com/chrislusf/seaweedfs/weed/pb/filer_pb"
|
|
jsoniter "github.com/json-iterator/go"
|
|
elastic "github.com/olivere/elastic/v7"
|
|
)
|
|
|
|
func (store *ElasticStore) KvDelete(ctx context.Context, key []byte) (err error) {
|
|
deleteResult, err := store.client.Delete().
|
|
Index(indexKV).
|
|
Type(indexType).
|
|
Id(string(key)).
|
|
Do(ctx)
|
|
if err == nil {
|
|
if deleteResult.Result == "deleted" || deleteResult.Result == "not_found" {
|
|
return nil
|
|
}
|
|
}
|
|
glog.Errorf("delete key(id:%s) %v.", string(key), err)
|
|
return fmt.Errorf("delete key %v.", err)
|
|
}
|
|
|
|
func (store *ElasticStore) KvGet(ctx context.Context, key []byte) (value []byte, err error) {
|
|
searchResult, err := store.client.Get().
|
|
Index(indexKV).
|
|
Type(indexType).
|
|
Id(string(key)).
|
|
Do(ctx)
|
|
if elastic.IsNotFound(err) {
|
|
return nil, filer_pb.ErrNotFound
|
|
}
|
|
if searchResult != nil && searchResult.Found {
|
|
esEntry := &ESKVEntry{}
|
|
if err := jsoniter.Unmarshal(searchResult.Source, esEntry); err == nil {
|
|
return []byte(esEntry.Value), nil
|
|
}
|
|
}
|
|
glog.Errorf("find key(%s),%v.", string(key), err)
|
|
return nil, filer_pb.ErrNotFound
|
|
}
|
|
|
|
func (store *ElasticStore) KvPut(ctx context.Context, key []byte, value []byte) (err error) {
|
|
esEntry := &ESKVEntry{string(value)}
|
|
val, err := jsoniter.Marshal(esEntry)
|
|
if err != nil {
|
|
glog.Errorf("insert key(%s) %v.", string(key), err)
|
|
return fmt.Errorf("insert key %v.", err)
|
|
}
|
|
_, err = store.client.Index().
|
|
Index(indexKV).
|
|
Type(indexType).
|
|
Id(string(key)).
|
|
BodyJson(string(val)).
|
|
Do(ctx)
|
|
if err != nil {
|
|
return fmt.Errorf("kv put: %v", err)
|
|
}
|
|
return nil
|
|
}
|