22 Commits

Author SHA1 Message Date
  lijianbin c5138187e6 同步跃恒redis 2 years ago
  guzeng 3f9c1e63be debu 2 years ago
  guzeng 41be6a2de4 debug 2 years ago
  listen 792d021307 增加scard方法 2 years ago
  guzeng ba36879934 更新pb.go 2 years ago
  listen da2be2e85b 更新方法参数 2 years ago
  guzeng e95aa2f8ba 更新pb.go 2 years ago
  listen ab07817052 Merge branch 'master' of https://git.tetele.net/tgo/redisrpc 2 years ago
  listen 9a1da461ea 增加集合成员数方法 2 years ago
  guzeng 1fe8afd6bb 加减client 2 years ago
  guzeng 74208f60e1 数量加减方法 2 years ago
  guzeng baeafb732c 数量加减方法 2 years ago
  guzeng 4daaf09687 client for watch 2 years ago
  guzeng c5f525ccfa 更新pb.go 2 years ago
  listen f150be842d 增加SetNx方法 2 years ago
  listen 4a8da13dd0 加入hincrby方法 2 years ago
  guzeng da19f10b5f pb.go 2 years ago
  listen 41454d5ef7 更新 2 years ago
  guzeng 6b20f6695d 增加HIncrby 2 years ago
  listen 7791674df3 commit 2 years ago
  listen af8ad992c8 加入+1方法 2 years ago
  guzeng 6a2bc7a0f8 增加扣减库存方法 2 years ago
14 changed files with 602 additions and 14 deletions
Split View
  1. +8
    -3
      go.mod
  2. +7
    -8
      go.sum
  3. +23
    -0
      hash.go
  4. +12
    -0
      hash_test.go
  5. +51
    -0
      num.go
  6. +15
    -0
      num_test.go
  7. +202
    -0
      redis.pb.go
  8. +42
    -0
      redis.proto
  9. +137
    -0
      set.go
  10. +25
    -1
      set_test.go
  11. +24
    -0
      string.go
  12. +2
    -2
      string_test.go
  13. +24
    -0
      watch_test.go
  14. +30
    -0
      wath.go

+ 8
- 3
go.mod View File

@ -1,9 +1,14 @@
module git.tetele.net/tgo/redisrpc
go 1.14
go 1.17
require (
git.tetele.net/tgo/conf v0.35.3
github.com/chai2010/protorpc v1.0.0
git.tetele.net/tgo/conf v0.47.0
github.com/chai2010/protorpc v1.1.3
github.com/golang/protobuf v1.5.2
)
require (
github.com/golang/snappy v0.0.3 // indirect
google.golang.org/protobuf v1.26.0 // indirect
)

+ 7
- 8
go.sum View File

@ -1,17 +1,16 @@
git.tetele.net/tgo/conf v0.25.0 h1:fopDch45xw/di5fLvvzwltFiGiXrilMobZwQNO678Wo=
git.tetele.net/tgo/conf v0.25.0/go.mod h1:DogEBvxG2fGdukpoobTVFE2b4Fd5OTE9FJ3Xetyn47E=
git.tetele.net/tgo/conf v0.35.3 h1:OQEa87qN5bAbscjMhaoTRinLnv8xZg1WErl5JXgFZco=
git.tetele.net/tgo/conf v0.35.3/go.mod h1:AWVIBEDE5dtotthUgR0SWaR2Qa6/f+O5WQ3s7Tj8q7A=
github.com/chai2010/protorpc v1.0.0 h1:aJ45G9sl1utSKo35EqnBSTs5jqTpdJDJAuZMMYPAtFo=
github.com/chai2010/protorpc v1.0.0/go.mod h1:woR3WwjaQDqFjlzdVsFEKiK5Ur12QL8mYxVPjfr5z54=
git.tetele.net/tgo/conf v0.47.0 h1:2nGvXjyFV6gO7BPliG4lwERP/bgTOeSJpUv/I2ALGPg=
git.tetele.net/tgo/conf v0.47.0/go.mod h1:AWVIBEDE5dtotthUgR0SWaR2Qa6/f+O5WQ3s7Tj8q7A=
github.com/chai2010/protorpc v1.1.3 h1:VJK5hIoZn0XCGol0GmbxZkUG6FbTI5LP2Lam6RVd15w=
github.com/chai2010/protorpc v1.1.3/go.mod h1:/wO0kiyVdu7ug8dCMrA2yDr2vLfyhsLEuzLa9J2HJ+I=
github.com/golang/protobuf v1.0.0/go.mod h1:6lQm79b+lXiMfvg/cZm0SGofjICqVBUtrP5yJMmIC1U=
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
github.com/golang/snappy v0.0.0-20170215233205-553a64147049 h1:K9KHZbXKpGydfDN0aZrsoHpLJlZsBrGMFWbgLDGnPZk=
github.com/golang/snappy v0.0.0-20170215233205-553a64147049/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
github.com/golang/snappy v0.0.3 h1:fHPg5GQYlCeLIPB9BZqMVR5nR9A+IM5zcgeTdjMYmLA=
github.com/golang/snappy v0.0.3/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q=
github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU=
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543 h1:E7g+9GITq07hpfrRu66IVDexMakfv52eLZ2CXBWiKr4=
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk=


+ 23
- 0
hash.go View File

@ -3,6 +3,7 @@ package redisrpc
import (
"encoding/json"
"log"
"strconv"
"github.com/golang/protobuf/proto"
)
@ -172,3 +173,25 @@ func HExists(key string, field string, url ...string) (int64, error) {
return res.GetRet(), nil
}
func HIncrby(key, field string, value int, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &HSetRequest{proto.String(key), proto.String(field), proto.String(strconv.Itoa(value)), nil}
res := &HSetResponse{}
err = conn.HIncrby(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}

+ 12
- 0
hash_test.go View File

@ -2,6 +2,7 @@ package redisrpc
import (
// "strconv"
"log"
"testing"
// "tgo/helper"
)
@ -53,3 +54,14 @@ func Test_HSet(t *testing.T) {
ret, err := HGetList("test2")
t.Log(ret, err)
}
func Test_Incrby(t *testing.T){
res,err := HIncrby("test_incr","26_26",2)
if err != nil {
log.Println(err.Error())
}
log.Println(res)
}

+ 51
- 0
num.go View File

@ -0,0 +1,51 @@
package redisrpc
import (
"github.com/golang/protobuf/proto"
)
//加
func Incrby(key string, value int64, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &AddRequest{proto.String(key), proto.Int64(value), nil}
res := &AddResponse{}
err = conn.Incrby(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}
//减
func Decrby(key string, value int64, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &AddRequest{proto.String(key), proto.Int64(value), nil}
res := &AddResponse{}
err = conn.Decrby(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}

+ 15
- 0
num_test.go View File

@ -0,0 +1,15 @@
package redisrpc
import (
"testing"
// "time"
)
func Test_Decrby(t *testing.T) {
c, err := Decrby("test_incrby", 2)
t.Log(c)
t.Log(err)
}

+ 202
- 0
redis.pb.go View File

@ -29,6 +29,12 @@ It has these top-level messages:
LSetResponse
LRangeRequest
LLenRequest
AddRequest
AddResponse
ZSetRequest
ZSetResponse
ZRangeRequest
ZScanRequest
*/
package redisrpc
@ -473,12 +479,169 @@ func (m *LLenRequest) GetKey() string {
return ""
}
// 数值增加
type AddRequest struct {
Key *string `protobuf:"bytes,1,opt,name=key" json:"key,omitempty"`
Value *int64 `protobuf:"varint,2,opt,name=value" json:"value,omitempty"`
XXX_unrecognized []byte `json:"-"`
}
func (m *AddRequest) Reset() { *m = AddRequest{} }
func (m *AddRequest) String() string { return proto.CompactTextString(m) }
func (*AddRequest) ProtoMessage() {}
func (m *AddRequest) GetKey() string {
if m != nil && m.Key != nil {
return *m.Key
}
return ""
}
func (m *AddRequest) GetValue() int64 {
if m != nil && m.Value != nil {
return *m.Value
}
return 0
}
type AddResponse struct {
Ret *int64 `protobuf:"varint,1,opt,name=ret" json:"ret,omitempty"`
XXX_unrecognized []byte `json:"-"`
}
func (m *AddResponse) Reset() { *m = AddResponse{} }
func (m *AddResponse) String() string { return proto.CompactTextString(m) }
func (*AddResponse) ProtoMessage() {}
func (m *AddResponse) GetRet() int64 {
if m != nil && m.Ret != nil {
return *m.Ret
}
return 0
}
// 有序集合添加值
type ZSetRequest struct {
Key *string `protobuf:"bytes,1,opt,name=key" json:"key,omitempty"`
Score *string `protobuf:"bytes,2,opt,name=score" json:"score,omitempty"`
Member *string `protobuf:"bytes,3,opt,name=member" json:"member,omitempty"`
XXX_unrecognized []byte `json:"-"`
}
func (m *ZSetRequest) Reset() { *m = ZSetRequest{} }
func (m *ZSetRequest) String() string { return proto.CompactTextString(m) }
func (*ZSetRequest) ProtoMessage() {}
func (m *ZSetRequest) GetKey() string {
if m != nil && m.Key != nil {
return *m.Key
}
return ""
}
func (m *ZSetRequest) GetScore() string {
if m != nil && m.Score != nil {
return *m.Score
}
return ""
}
func (m *ZSetRequest) GetMember() string {
if m != nil && m.Member != nil {
return *m.Member
}
return ""
}
// 设置响应结构
type ZSetResponse struct {
Ret *int64 `protobuf:"varint,1,opt,name=ret" json:"ret,omitempty"`
XXX_unrecognized []byte `json:"-"`
}
func (m *ZSetResponse) Reset() { *m = ZSetResponse{} }
func (m *ZSetResponse) String() string { return proto.CompactTextString(m) }
func (*ZSetResponse) ProtoMessage() {}
func (m *ZSetResponse) GetRet() int64 {
if m != nil && m.Ret != nil {
return *m.Ret
}
return 0
}
// 有序集合取值
type ZRangeRequest struct {
Key *string `protobuf:"bytes,1,opt,name=key" json:"key,omitempty"`
Start *int64 `protobuf:"varint,2,opt,name=start" json:"start,omitempty"`
Stop *int64 `protobuf:"varint,3,opt,name=stop" json:"stop,omitempty"`
XXX_unrecognized []byte `json:"-"`
}
func (m *ZRangeRequest) Reset() { *m = ZRangeRequest{} }
func (m *ZRangeRequest) String() string { return proto.CompactTextString(m) }
func (*ZRangeRequest) ProtoMessage() {}
func (m *ZRangeRequest) GetKey() string {
if m != nil && m.Key != nil {
return *m.Key
}
return ""
}
func (m *ZRangeRequest) GetStart() int64 {
if m != nil && m.Start != nil {
return *m.Start
}
return 0
}
func (m *ZRangeRequest) GetStop() int64 {
if m != nil && m.Stop != nil {
return *m.Stop
}
return 0
}
type ZScanRequest struct {
Key *string `protobuf:"bytes,1,opt,name=key" json:"key,omitempty"`
Field *string `protobuf:"bytes,2,opt,name=field" json:"field,omitempty"`
Len *int64 `protobuf:"varint,3,opt,name=len" json:"len,omitempty"`
XXX_unrecognized []byte `json:"-"`
}
func (m *ZScanRequest) Reset() { *m = ZScanRequest{} }
func (m *ZScanRequest) String() string { return proto.CompactTextString(m) }
func (*ZScanRequest) ProtoMessage() {}
func (m *ZScanRequest) GetKey() string {
if m != nil && m.Key != nil {
return *m.Key
}
return ""
}
func (m *ZScanRequest) GetField() string {
if m != nil && m.Field != nil {
return *m.Field
}
return ""
}
func (m *ZScanRequest) GetLen() int64 {
if m != nil && m.Len != nil {
return *m.Len
}
return 0
}
func init() {
}
type RedisService interface {
Get(in *GetRequest, out *GetStringResponse) error
Set(in *SetRequest, out *SetResponse) error
SetNx(in *SetRequest, out *DelResponse) error
Del(in *DelRequest, out *DelResponse) error
HGet(in *HGetRequest, out *GetStringResponse) error
HSet(in *HSetRequest, out *HSetResponse) error
@ -488,13 +651,22 @@ type RedisService interface {
HGetList(in *GetRequest, out *HGetListResponse) error
HExists(in *HGetRequest, out *DelResponse) error
Exists(in *GetRequest, out *DelResponse) error
HIncrby(in *HSetRequest, out *HSetResponse) error
SAdd(in *SSetRequest, out *SSetResponse) error
SIsmember(in *SSetRequest, out *SSetResponse) error
SRem(in *SSetRequest, out *SSetResponse) error
SCard(in *SMembersRequest, out *SSetResponse) error
LLpush(in *LSetRequest, out *LSetResponse) error
LRpush(in *LSetRequest, out *LSetResponse) error
LRange(in *LRangeRequest, out *HGetListResponse) error
LLen(in *LLenRequest, out *LSetResponse) error
ReduceStock(in *SetRequest, out *SetResponse) error
Incrby(in *AddRequest, out *AddResponse) error
Decrby(in *AddRequest, out *AddResponse) error
ZAdd(in *ZSetRequest, out *ZSetResponse) error
ZIncrBy(in *ZSetRequest, out *ZSetResponse) error
ZRange(in *ZRangeRequest, out *HGetListResponse) error
ZScan(in *ZScanRequest, out *HGetListResponse) error
}
// AcceptRedisServiceClient accepts connections on the listener and serves requests
@ -572,6 +744,9 @@ func (c *RedisServiceClient) Get(in *GetRequest, out *GetStringResponse) error {
func (c *RedisServiceClient) Set(in *SetRequest, out *SetResponse) error {
return c.Call("RedisService.Set", in, out)
}
func (c *RedisServiceClient) SetNx(in *SetRequest, out *DelResponse) error {
return c.Call("RedisService.SetNx", in, out)
}
func (c *RedisServiceClient) Del(in *DelRequest, out *DelResponse) error {
return c.Call("RedisService.Del", in, out)
}
@ -599,6 +774,9 @@ func (c *RedisServiceClient) HExists(in *HGetRequest, out *DelResponse) error {
func (c *RedisServiceClient) Exists(in *GetRequest, out *DelResponse) error {
return c.Call("RedisService.Exists", in, out)
}
func (c *RedisServiceClient) HIncrby(in *HSetRequest, out *HSetResponse) error {
return c.Call("RedisService.HIncrby", in, out)
}
func (c *RedisServiceClient) SAdd(in *SSetRequest, out *SSetResponse) error {
return c.Call("RedisService.SAdd", in, out)
}
@ -608,6 +786,9 @@ func (c *RedisServiceClient) SIsmember(in *SSetRequest, out *SSetResponse) error
func (c *RedisServiceClient) SRem(in *SSetRequest, out *SSetResponse) error {
return c.Call("RedisService.SRem", in, out)
}
func (c *RedisServiceClient) SCard(in *SMembersRequest, out *SSetResponse) error {
return c.Call("RedisService.SCard", in, out)
}
func (c *RedisServiceClient) LLpush(in *LSetRequest, out *LSetResponse) error {
return c.Call("RedisService.LLpush", in, out)
}
@ -620,6 +801,27 @@ func (c *RedisServiceClient) LRange(in *LRangeRequest, out *HGetListResponse) er
func (c *RedisServiceClient) LLen(in *LLenRequest, out *LSetResponse) error {
return c.Call("RedisService.LLen", in, out)
}
func (c *RedisServiceClient) ReduceStock(in *SetRequest, out *SetResponse) error {
return c.Call("RedisService.ReduceStock", in, out)
}
func (c *RedisServiceClient) Incrby(in *AddRequest, out *AddResponse) error {
return c.Call("RedisService.Incrby", in, out)
}
func (c *RedisServiceClient) Decrby(in *AddRequest, out *AddResponse) error {
return c.Call("RedisService.Decrby", in, out)
}
func (c *RedisServiceClient) ZAdd(in *ZSetRequest, out *ZSetResponse) error {
return c.Call("RedisService.ZAdd", in, out)
}
func (c *RedisServiceClient) ZIncrBy(in *ZSetRequest, out *ZSetResponse) error {
return c.Call("RedisService.ZIncrBy", in, out)
}
func (c *RedisServiceClient) ZRange(in *ZRangeRequest, out *HGetListResponse) error {
return c.Call("RedisService.ZRange", in, out)
}
func (c *RedisServiceClient) ZScan(in *ZScanRequest, out *HGetListResponse) error {
return c.Call("RedisService.ZScan", in, out)
}
// DialRedisService connects to an RedisService at the specified network address.
func DialRedisService(network, addr string) (*RedisServiceClient, *rpc.Client, error) {


+ 42
- 0
redis.proto View File

@ -103,10 +103,43 @@ message LLenRequest{
string key = 1;
}
//
message AddRequest {
string key = 1;
int64 value = 2;
}
message AddResponse {
int64 ret = 1;
}
//
message ZSetRequest{
string key = 1;
string score = 2;
string member = 3;
}
//
message ZSetResponse {
int64 ret = 1;
}
//
message ZRangeRequest{
string key = 1;
int64 start = 2;
int64 stop = 3;
}
message ZScanRequest {
string key = 1;
string field = 2;
int64 len = 3;
}
// rpc方法
service RedisService {
rpc Get (GetRequest) returns (GetStringResponse); // 使key查询
rpc Set (SetRequest) returns (SetResponse);
rpc SetNx (SetRequest) returns (DelResponse); //
rpc Del (DelRequest) returns (DelResponse);
rpc HGet (HGetRequest) returns (GetStringResponse); // 使hash key查询
rpc HSet (HSetRequest) returns (HSetResponse);
@ -116,11 +149,20 @@ service RedisService {
rpc HGetList(GetRequest) returns (HGetListResponse); //get hash all
rpc HExists(HGetRequest) returns (DelResponse); //hash键是否存在
rpc Exists(GetRequest) returns (DelResponse); //
rpc HIncrby(HSetRequest) returns (HSetResponse); //hash数值+-1
rpc SAdd(SSetRequest) returns (SSetResponse); //
rpc SIsmember(SSetRequest) returns (SSetResponse); //
rpc SRem(SSetRequest) returns (SSetResponse); //
rpc SCard(SMembersRequest) returns (SSetResponse); //
rpc LLpush(LSetRequest) returns (LSetResponse); //
rpc LRpush(LSetRequest) returns (LSetResponse); //
rpc LRange(LRangeRequest) returns (HGetListResponse); //
rpc LLen(LLenRequest) returns (LSetResponse); //
rpc ReduceStock(SetRequest) returns(SetResponse);//
rpc Incrby(AddRequest) returns(AddResponse);//
rpc Decrby(AddRequest) returns(AddResponse);//
rpc ZAdd(ZSetRequest) returns (ZSetResponse); //
rpc ZIncrBy(ZSetRequest) returns (ZSetResponse); //
rpc ZRange(ZRangeRequest) returns (HGetListResponse);
rpc ZScan(ZScanRequest) returns(HGetListResponse);//zset match
}

+ 137
- 0
set.go View File

@ -1,6 +1,9 @@
package redisrpc
import (
"encoding/json"
"log"
"github.com/golang/protobuf/proto"
)
@ -74,3 +77,137 @@ func SIsmember(key string, field string, url ...string) (int64, error) {
return res.GetRet(), nil
}
/**
* 集合成员数
*/
func SCard(key string, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &SMembersRequest{proto.String(key), nil}
res := &SSetResponse{}
err = conn.SCard(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}
//设置
func ZAdd(key, score, member string, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &ZSetRequest{proto.String(key), proto.String(score), proto.String(member), nil}
res := &ZSetResponse{}
err = conn.ZAdd(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}
//递增
func ZIncrBy(key, inc, member string, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &ZSetRequest{proto.String(key), proto.String(inc), proto.String(member), nil}
res := &ZSetResponse{}
err = conn.ZIncrBy(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}
/**
* 集合成员
*/
func ZRange(key string, start, stop int64, url ...string) ([]map[string]string, error) {
conn, _, err := Conn(url...)
if err != nil {
return nil, err
}
defer conn.Close()
req := &ZRangeRequest{proto.String(key), proto.Int64(start), proto.Int64(stop), nil}
res := &HGetListResponse{}
err = conn.ZRange(req, res)
if err != nil {
return nil, err
}
value := res.GetList()
var list []map[string]string
err = json.Unmarshal(value, &list)
if err != nil {
log.Println("json unmarshal error:", err)
return nil, err
}
return list, nil
}
/**
* 集合成员
*/
func ZScan(key, field string, len int64, url ...string) ([]string, error) {
conn, _, err := Conn(url...)
if err != nil {
return nil, err
}
defer conn.Close()
req := &ZScanRequest{proto.String(key), proto.String(field), proto.Int64(len), nil}
res := &HGetListResponse{}
err = conn.ZScan(req, res)
if err != nil {
return nil, err
}
value := res.GetList()
var list []string
err = json.Unmarshal(value, &list)
if err != nil {
log.Println("json unmarshal error:", err)
return nil, err
}
return list, nil
}

+ 25
- 1
set_test.go View File

@ -2,8 +2,9 @@ package redisrpc
import (
// "strconv"
"testing"
// "tgo/helper"
// "unicode/utf8"
)
func Test_SAdd(t *testing.T) {
@ -19,3 +20,26 @@ func Test_SAdd(t *testing.T) {
t.Log(err)
}
func Test_SCard(t *testing.T) {
res, err := SCard("test_article")
t.Log(res)
t.Log(err)
}
func Test_ZSet(t *testing.T) {
Del("zset-test")
res, err := ZAdd("zset-test", "2", "{\"keyword\":\"test\",\"id\":\"12\"}")
t.Log("ZAdd: ", res, err)
ress, err := ZScan("zset-test", "*test*", 10)
t.Log("ZScan: ", ress, err)
list, err := ZRange("zset-test", 0, 100)
t.Log("ZRangexx: ", list, err)
// res, err = ZIncrBy("zset-test", "2", "test")
// t.Log("ZIncrBy: ", res, err)
}

+ 24
- 0
string.go View File

@ -95,3 +95,27 @@ func Exists(key string, url ...string)(int64, error){
return res.GetRet(), nil
}
//设置如果不存在
func SetNx(key, value string, ttl int64, url ...string) (int64, error) {
conn, _, err := Conn(url...)
if err != nil {
return 0, err
}
defer conn.Close()
req := &SetRequest{proto.String(key), proto.String(value), proto.Int64(ttl), nil}
res := &DelResponse{}
err = conn.SetNx(req, res)
if err != nil {
return 0, err
}
return res.GetRet(), nil
}

+ 2
- 2
string_test.go View File

@ -15,7 +15,7 @@ func Test_Get(t *testing.T) {
func Test_Set(t *testing.T) {
c, err := Set("test", "1111", 7200)
c, err := Set("test", "222", 10)
t.Log(c)
t.Log(err)
@ -27,4 +27,4 @@ func Test_Del(t *testing.T) {
t.Log(c)
t.Log(err)
}
}

+ 24
- 0
watch_test.go View File

@ -0,0 +1,24 @@
package redisrpc
import (
"log"
"testing"
// "time"
)
func Test_ReduceStock(t *testing.T) {
ch := make(chan int)
for i := 0; i < 100; i++ {
go func() {
log.Println("start")
reply, err := ReduceStock("test_watch", "2")
log.Println(reply)
log.Println(err)
log.Println("end")
}()
}
<-ch
}

+ 30
- 0
wath.go View File

@ -0,0 +1,30 @@
package redisrpc
import (
"github.com/golang/protobuf/proto"
)
/**
* 使用用户名查询
*/
func ReduceStock(key string, value string, url ...string) (string, error) {
conn, _, err := Conn(url...)
if err != nil {
return "", err
}
defer conn.Close()
req := &SetRequest{proto.String(key), proto.String(value), proto.Int64(0), nil}
res := &SetResponse{}
err = conn.ReduceStock(req, res)
if err != nil {
return "", err
}
return res.GetRet(), nil
}

Loading…
Cancel
Save