1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- //go:build elastic
- // +build elastic
- package elastic
- import (
- "context"
- "fmt"
- "github.com/seaweedfs/seaweedfs/weed/filer"
- jsoniter "github.com/json-iterator/go"
- elastic "github.com/olivere/elastic/v7"
- "github.com/seaweedfs/seaweedfs/weed/glog"
- )
- 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 value, filer.ErrKvNotFound
- }
- if searchResult != nil && searchResult.Found {
- esEntry := &ESKVEntry{}
- if err := jsoniter.Unmarshal(searchResult.Source, esEntry); err == nil {
- return esEntry.Value, nil
- }
- }
- glog.Errorf("find key(%s),%v.", string(key), err)
- return value, filer.ErrKvNotFound
- }
- func (store *ElasticStore) KvPut(ctx context.Context, key []byte, value []byte) (err error) {
- esEntry := &ESKVEntry{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
- }
|