Skip to content

Commit

Permalink
docs: redis example
Browse files Browse the repository at this point in the history
  • Loading branch information
wwwangxc committed Nov 7, 2022
1 parent b3c0f28 commit 34045f5
Showing 1 changed file with 144 additions and 0 deletions.
144 changes: 144 additions & 0 deletions redis/example_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,144 @@
package redis_test

import (
"context"
"encoding/json"
"fmt"
"time"

"github.com/wwwangxc/gopkg/redis"
)

func ExampleClientProxy() {
// new client proxy
cli := redis.NewClientProxy("client_name",
redis.WithClientDSN("dsn"), // set dsn, default use database.client.dsn
redis.WithClientMaxIdle(20), // set max idel. default 2048
redis.WithClientMaxActive(100), // set max active. default 0
redis.WithClientIdleTimeout(180000), // set idle timeout. unit millisecond, default 180000
redis.WithClientTimeout(1000), // set command timeout. unit millisecond, default 1000
redis.WithClientMaxConnLifetime(10000), // set max conn life time, default 0
redis.WithClientWait(true), // set wait
)

// Do sends a command to server and returns the received reply.
cli.Do(context.Background(), "GET", "foo")

// Connection
c := cli.Conn()
defer c.Close()
c.Send("SET", "foo", "bar")
c.Send("GET", "foo")
c.Flush()
c.Receive() // reply from SET
c.Receive() // reply from GET

// Gets a distributed lock provider
_ = cli.Locker()

// Gets an object fetcher
_ = cli.Fetcher()
}

func ExampleLockerProxy() {
// new locker proxy
l := redis.NewLockerProxy("client_name",
redis.WithClientDSN("dsn"), // set dsn, default use database.client.dsn
redis.WithClientMaxIdle(20), // set max idel. default 2048
redis.WithClientMaxActive(100), // set max active. default 0
redis.WithClientIdleTimeout(180000), // set idle timeout. unit millisecond, default 180000
redis.WithClientTimeout(1000), // set command timeout. unit millisecond, default 1000
redis.WithClientMaxConnLifetime(10000), // set max conn life time, default 0
redis.WithClientWait(true), // set wait
)

// try lock
// not block the current goroutine.
// return uuid when the lock is acquired
// return error when lock fail or lock not acquired
// support reentrant unlock
// support automatically renewal
uuid, err := l.TryLock(context.Background(), "locker_key",
redis.WithLockExpire(1000*time.Millisecond),
redis.WithLockHeartbeat(500*time.Millisecond))

if err != nil {

// return ErrLockNotAcquired when lock not acquired
if redis.IsLockNotAcquired(err) {
fmt.Printf("lock not acquired\n")
return
}

fmt.Printf("try lock fail. error: %v\n", err)
return
}

defer func() {

// return ErrLockNotExist if the key does not exist
// return ErrNotOwnerOfKey if the uuid invalid
// support reentrant unlock
if err := l.Unlock(context.Background(), "locker_key", uuid); err != nil {
fmt.Printf("unlock fail. error: %v\n", err)
}
}()

// reentrant lock when uuid not empty
// will block the current goroutine until lock is acquired when not reentrant lock
_, err = l.Lock(context.Background(), "locker_key",
redis.WithLockUUID(uuid),
redis.WithLockExpire(1000*time.Millisecond),
redis.WithLockHeartbeat(500*time.Millisecond))

if err != nil {
fmt.Printf("lock fail. error: %v\n", err)
return
}

f := func() error {
// do something...
return nil
}

// try get lock first and call f() when lock acquired. Unlock will be performed
// regardless of whether the f reports an error or not.
if err := l.LockAndCall(context.Background(), "locker_key", f); err != nil {
fmt.Printf("lock and call fail. error: %v\n", err)
return
}
}

func ExampleFetcherProxy() {
obj := struct {
FieldA string `json:"field_a"`
FieldB int `json:"field_b"`
}{}

callback := func() (interface{}, error) {
// load object
return nil, nil
}

// new fetcher proxy
f := redis.NewFetcherProxy("client_name",
redis.WithClientDSN("dsn"), // set dsn, default use database.client.dsn
redis.WithClientMaxIdle(20), // set max idel. default 2048
redis.WithClientMaxActive(100), // set max active. default 0
redis.WithClientIdleTimeout(180000), // set idle timeout. unit millisecond, default 180000
redis.WithClientTimeout(1000), // set command timeout. unit millisecond, default 1000
redis.WithClientMaxConnLifetime(10000), // set max conn life time, default 0
redis.WithClientWait(true), // set wait
)

// fetch object
err := f.Fetch(context.Background(), "fetcher_key", &obj,
redis.WithFetchCallback(callback, 1000*time.Millisecond),
redis.WithFetchUnmarshal(json.Unmarshal),
redis.WithFetchMarshal(json.Marshal))

if err != nil {
fmt.Printf("fetch fail. error: %v\n", err)
return
}
}

0 comments on commit 34045f5

Please sign in to comment.