2015-05-23 20:04:16 +01:00
|
|
|
package memcached
|
2015-01-13 23:31:27 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
|
|
|
|
mc "github.com/bradfitz/gomemcache/memcache"
|
2015-05-23 20:04:16 +01:00
|
|
|
"github.com/myodc/go-micro/store"
|
2015-01-13 23:31:27 +00:00
|
|
|
)
|
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
type mstore struct {
|
2015-01-13 23:31:27 +00:00
|
|
|
Client *mc.Client
|
|
|
|
}
|
|
|
|
|
2015-05-23 21:25:55 +01:00
|
|
|
func (m *mstore) Get(key string) (*store.Item, error) {
|
2015-01-13 23:31:27 +00:00
|
|
|
kv, err := m.Client.Get(key)
|
|
|
|
if err != nil && err == mc.ErrCacheMiss {
|
|
|
|
return nil, errors.New("key not found")
|
|
|
|
} else if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if kv == nil {
|
|
|
|
return nil, errors.New("key not found")
|
|
|
|
}
|
|
|
|
|
2015-05-23 21:25:55 +01:00
|
|
|
return &store.Item{
|
|
|
|
Key: kv.Key,
|
|
|
|
Value: kv.Value,
|
2015-01-13 23:31:27 +00:00
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
func (m *mstore) Del(key string) error {
|
2015-01-13 23:31:27 +00:00
|
|
|
return m.Client.Delete(key)
|
|
|
|
}
|
|
|
|
|
2015-05-23 21:25:55 +01:00
|
|
|
func (m *mstore) Put(item *store.Item) error {
|
2015-01-13 23:31:27 +00:00
|
|
|
return m.Client.Set(&mc.Item{
|
2015-05-23 21:25:55 +01:00
|
|
|
Key: item.Key,
|
|
|
|
Value: item.Value,
|
2015-01-13 23:31:27 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2015-05-23 20:04:16 +01:00
|
|
|
func NewStore(addrs []string, opts ...store.Option) store.Store {
|
2015-05-16 00:34:02 +01:00
|
|
|
if len(addrs) == 0 {
|
|
|
|
addrs = []string{"127.0.0.1:11211"}
|
2015-01-13 23:31:27 +00:00
|
|
|
}
|
2015-05-23 20:04:16 +01:00
|
|
|
return &mstore{
|
2015-05-16 00:34:02 +01:00
|
|
|
Client: mc.New(addrs...),
|
2015-01-13 23:31:27 +00:00
|
|
|
}
|
|
|
|
}
|