golang中使用redis
兩個都是非常優秀的redisclient庫,也是redis官網上推薦,筆者選擇是的是go-redis,因為go-redis封裝了redis的大部分命令,不用關心redis的命令的細節,直接呼叫相應介面就行;redigo是基於命令的,傳送一個命令,然後在解析reply;所以相對而言,筆者覺得go-redis介面更友好;
這裡也稍微做個廣告,如果有朋友是用c++的,可以嘗試下筆者開源的一個c++版的redisclient:, 跟go-redis類似,封裝了redis大部分的命令,支援redis standalone, sentinel, cluster mode, 介面友好好用
1. go-redis的安裝
go get
2. 測試程式碼
// redis_test project main.gopackage main import ( "fmt" "time" "github.com/go-redis/redis") func err_handler(err error) { fmt.Printf("err_handler, error:%sn", 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: %sn", pong) fmt.Printf("----------------------------------------n") // set / get test fmt.Printf("set/get testn") err = client.Set("foo", "bar", 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 %sn", 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 %sn", 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 %sn", 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] %fsn", 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] %dsn", duration.String(), int64(duration.Seconds())) fmt.Printf("----------------------------------------n") // list test fmt.Printf("list testn") 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 %dn", 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("----------------------------------------n") fmt.Printf("hmap testn") 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 %dn", 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 %sn", 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 = %sn", k, v) } fmt.Printf("----------------------------------------n") fmt.Printf("pubsub testn") 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) } } func main() { fmt.Println("redis_test!") standalon_redis_test() }
作者:yandaren
連結:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/3402/viewspace-2817467/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 使用 golang 寫一個 redis-cliGolangRedis
- 使用golang實現redis伺服器GolangRedis伺服器
- Golang中context使用GolangContext
- Golang操作RedisGolangRedis
- Golang 實現 Redis(5): 使用跳錶實現 SortedSetGolangRedis
- Golang 實現 Redis(9): 使用GeoHash 搜尋附近的人GolangRedis
- Redis在.net中的使用(2).net專案中的Redis使用Redis
- spring boot中redis使用Spring BootRedis
- golang開發:類庫篇(二) Redis連線池的使用GolangRedis
- Redis在.net中的使用(5)Redis持久化Redis持久化
- golang 中 time 包使用教程之基礎使用篇Golang
- Redis在.net中的使用(6)Redis併發鎖Redis
- golang-event在以太坊中的使用Golang
- Redis 中 HyperLogLog 的使用場景Redis
- Redis 中 BitMap 的使用場景Redis
- Redis 中 Keys 與 Scan 的使用Redis
- redis分散式鎖實現(golang版)Redis分散式Golang
- Redis在.net中的使用(1)下載安裝RedisRedis
- Golang中struct結構標籤(Tag)的使用GolangStruct
- GoLang中字串的一些使用總結Golang字串
- SpringBoot中Shiro快取使用Redis、EhcacheSpring Boot快取Redis
- Redis在.net中的使用(7)redis部署為Windows服務RedisWindows
- Redis 中的原子操作(3)-使用Redis實現分散式鎖Redis分散式
- Golang 實現 Redis(6): 實現 pipeline 模式的 redis 客戶端GolangRedis模式客戶端
- Golang 庫 Redis 對 data 型別的支援GolangRedis型別
- Golang 實現 Redis(10): 本地原子性事務GolangRedis
- Golang 實現 Redis(11): RDB 檔案解析GolangRedis
- 一文掌握Golang中IO包使用與原理Golang
- Golang中如何正確的使用sarama包操作Kafka?GolangKafka
- golang中go mod使用第三方包Golang
- C#中使用Redis學習二 在.NET4.5中使用redis hash操作C#Redis
- golang的time使用Golang
- Redis在遊戲業務中的使用Redis遊戲
- redis中lua指令碼的簡單使用Redis指令碼
- Golang 實現 Redis(7): Redis 叢集與一致性 HashGolangRedis
- Golang 實現 Redis(8): TCC分散式事務GolangRedis分散式
- golang 中 channel 的詳細使用、使用注意事項及死鎖分析Golang
- golang 中fmt用法Golang