Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/quangtung97/go-memcache
Go Memcached Client For Meta Commands
https://github.com/quangtung97/go-memcache
client memcached meta-command
Last synced: about 2 months ago
JSON representation
Go Memcached Client For Meta Commands
- Host: GitHub
- URL: https://github.com/quangtung97/go-memcache
- Owner: QuangTung97
- License: mit
- Created: 2021-12-23T10:32:19.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2023-10-26T04:28:04.000Z (about 1 year ago)
- Last Synced: 2024-04-16T00:16:54.563Z (9 months ago)
- Topics: client, memcached, meta-command
- Language: Go
- Homepage:
- Size: 183 KB
- Stars: 9
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# High Performance Memcached Client
[![go-memcache](https://github.com/QuangTung97/go-memcache/actions/workflows/go.yml/badge.svg)](https://github.com/QuangTung97/go-memcache/actions/workflows/go.yml)
[![Coverage Status](https://coveralls.io/repos/github/QuangTung97/go-memcache/badge.svg?branch=master)](https://coveralls.io/github/QuangTung97/go-memcache?branch=master)### Why this Library?
A Simple Memcached Client Library.
Similar to: https://github.com/bradfitz/gomemcache. \
But faster (up to 2x in some benchmarks) and supporting pipelined DELETE & SET operationsAnd mostly focused on the new meta commands:
https://github.com/memcached/memcached/wiki/MetaCommands \
To facilitate more complex caching algorithms (e.g. memcached lease).It implemented using Batching & Pipelining to reduce syscalls,
batching can happen between clients of the same connection.Please checkout this document for better understanding of request options and response values of this library:
https://github.com/memcached/memcached/blob/master/doc/protocol.txt### Examples
Examples can be found here: https://github.com/QuangTung97/go-memcache/tree/master/examples
```go
pipeline := client.Pipeline()
defer pipeline.Finish()fn1 := pipeline.MGet("KEY01", memcache.MGetOptions{})
fn2 := pipeline.MGet("KEY02", memcache.MGetOptions{})getResp, err := fn1()
fmt.Printf("GET: %+v %+v\n", getResp, err)getResp, err = fn2()
fmt.Printf("GET: %+v %+v\n", getResp, err)
```In this example, two meta get commands will be sent only in the call:
```go
getResp, err := fn1()
```It will try to batch as much number of commands
as possible to the underlining TCP Connections.But if you do like this:
```go
pipeline := client.Pipeline()
defer pipeline.Finish()fn1 := pipeline.MGet("KEY01", memcache.MGetOptions{})
getResp, err := fn1()
fmt.Printf("GET: %+v %+v\n", getResp, err)fn2 := pipeline.MGet("KEY02", memcache.MGetOptions{})
getResp, err = fn2()
fmt.Printf("GET: %+v %+v\n", getResp, err)
```Then no batching is possible.
The line `defer pipeline.Finish()` is the best practise for preventing cases like this:
```go
pipeline := client.Pipeline()
defer pipeline.Finish()pipeline.MSet("KEY01", []byte("key data 01"), memcache.MSetOptions{})
pipeline.MSet("KEY02", []byte("key data 02"), memcache.MSetOptions{})
```without `pipeline.Finish()` the two set commands will **NOT** be delivered to the memcached server. \
Because the returned functions should be called, ``pipeline.Finsh()`` will do the calling if one forgotten.```
fn := pipeline.MSet("KEY01", []byte("key data 01"), memcache.MSetOptions{})
_, _ = fn()
```