golang操作redis

         下面是一些go语言常见的一些redis操作。

package main

import (
	"fmt"
	"time"

	"github.com/go-redis/redis"
)

func err_handler(err error) {
	fmt.Printf("err_handler, error:%s\n", err.Error())
	panic(err.Error())
}

func standalon_redis_test() {
	fmt.Printf("standalon_redis_test")

	client := redis.NewClient(&redis.Options{
		Addr:     "localhost:6379",
		Password: "",
		DB:       0,
	})

	defer client.Close()

	pong, err := client.Ping().Result()
	if err != nil {
		fmt.Printf("ping error[%s]\n", err.Error())
		err_handler(err)
	}
	fmt.Printf("ping result: %s\n", pong)

	//set / get test
	fmt.Printf("set/get test\n")
	err = client.Set("foo", "bar2", 0).Err()
	if err != nil {
		fmt.Printf("try set key[foo] to value[bar] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	err = client.Set("foo1", "bar1", time.Hour*2).Err()
	if err != nil {
		fmt.Printf("try set key[foo1] to value[bar1] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	// get value
	value, err := client.Get("foo").Result()
	if err != nil {
		fmt.Printf("try get key[foo] error[%s]\n", err.Error())
		// err_handler(err)
	}

	fmt.Printf("key[foo]'s value is %s\n", value)

	value, err = client.Get("foo1").Result()
	if err != nil {
		fmt.Printf("try get key[foo1] error[%s]\n", err.Error())
		// err_handler(err)
	}

	fmt.Printf("key[foo1]'s value is %s\n", value)

	value, err = client.Get("foo2").Result()
	if err != nil {
		fmt.Printf("try get key[foo2] error[%s]\n", err.Error())
		// err_handler(err)
	}

	fmt.Printf("key[foo2]'s value is %s\n", value)

	// get ttl
	duration, err := client.TTL("foo").Result()
	if err != nil {
		fmt.Printf("try get ttl of key[foo] error[%s]\n", err.Error())
		err_handler(err)
	}

	fmt.Printf("key[foo]' ttl is [%s] %fs\n",
		duration.String(), duration.Seconds())

	duration, err = client.TTL("foo1").Result()
	if err != nil {
		fmt.Printf("try get ttl of key[foo1] error[%s]\n", err.Error())
		err_handler(err)
	}

	fmt.Printf("key[foo1]' ttl is [%s] %ds\n",
		duration.String(), int64(duration.Seconds()))

	// list test
	fmt.Printf("list test\n")
	err = client.RPush("tqueue", "tmsg2").Err()
	err = client.RPush("tqueue", "tmsg1").Err()
	if err != nil {
		fmt.Printf("rpush list[tqueue] error[%s]\n", err.Error())
		err_handler(err)
	}

	list_len, err := client.LLen("tqueue").Result()
	if err != nil {
		fmt.Printf("try get len of list[tqueue] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	fmt.Printf("len of list[tqueue] is %d\n", list_len)

	result, err := client.BLPop(time.Second*1, "tqueue").Result()
	if err != nil {
		fmt.Printf("blpop list[tqueue] error[%s]\n", err.Error())
		err_handler(err)
	}
	fmt.Printf("blpop list[tqueue], value[%s]\n", result[1])

	fmt.Printf("hmap test\n")

	err = client.HSet("tmap", "1", "f1").Err()
	if err != nil {
		fmt.Printf("try hset map[tmap] field[1] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	err = client.HSet("tmap", "2", "f2").Err()
	if err != nil {
		fmt.Printf("try hset map[tmap] field[2] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	kv_map := make(map[string]interface{})
	kv_map["3"] = "f3"
	kv_map["4"] = "f4"

	err = client.HMSet("tmap", kv_map).Err()
	if err != nil {
		fmt.Printf("try mset map[tmap] field[3] field[4] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	map_len, err := client.HLen("tmap").Result()
	if err != nil {
		fmt.Printf("try get len of map[tmap] error[%s]\n", err.Error())
		err_handler(err)
	}
	fmt.Printf("len of map[tmap] is %d\n", map_len)

	// get map value
	value, err = client.HGet("tmap", "1").Result()
	if err != nil {
		fmt.Printf("try get field[1] value of map[tmap] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	fmt.Printf("field[1] value of map[tmap] is %s\n", value)

	// hgetall
	result_kv, err := client.HGetAll("tmap").Result()
	if err != nil {
		fmt.Printf("try hgetall map[tmap] error[%s]\n", err.Error())
		err_handler(err)
	}

	for k, v := range result_kv {
		fmt.Printf("map[tmap] %s = %s\n", k, v)
	}

	fmt.Printf("pubsub test\n")
	pubsub := client.Subscribe("test_channel")

	_, err = pubsub.Receive()
	if err != nil {
		fmt.Printf("try subscribe channel[test_channel] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	// go channel to used to receive message
	ch := pubsub.Channel()

	// publish a message
	err = client.Publish("test_channel", "hello").Err()
	if err != nil {
		fmt.Printf("try publish message to channel[test_channel] error[%s]\n",
			err.Error())
		err_handler(err)
	}

	time.AfterFunc(time.Second*2, func() {
		_ = pubsub.Close()
	})

	// consume message
	for {
		msg, ok := <-ch
		if !ok {
			break
		}

		fmt.Printf("recv message[%s] from channel[%s]\n",
			msg.Payload, msg.Channel)
	}

	client.SAdd("kevin","123")
	client.SAdd("kevin","1234")

	zsetKey := "language_rank"
	languages := []redis.Z{
		redis.Z{Score: 90.0, Member: "Golang"},
		redis.Z{Score: 98.0, Member: "Java"},
		redis.Z{Score: 95.0, Member: "Python"},
		redis.Z{Score: 97.0, Member: "JavaScript"},
		redis.Z{Score: 99.0, Member: "C/C++"},
	}
	client.ZAdd(zsetKey, languages[3]).Result()
}

func main() {
	fmt.Println("redis_test!")

	standalon_redis_test()

}

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

盼盼编程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值