我就廢話不多說了,大家還是直接看代碼吧~
package main
import (
"fmt"
"github.com/garyburd/redigo/redis"
)
func main() {
// 連接redis數(shù)據(jù)庫,指定數(shù)據(jù)庫的IP和端口
conn, err := redis.Dial("tcp", "36.99.16.197:6379")
if err != nil {
fmt.Println("Connect to redis error", err)
return
} else {
fmt.Println("Connect to redis ok.")
}
// 函數(shù)退出時關(guān)閉連接
defer conn.Close()
// 執(zhí)行一個有序zset插入
_, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot1")
if err != nil {
fmt.Println("redis set failed:", err)
}
// 再執(zhí)行一個有序zset插入
_, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot2")
if err != nil {
fmt.Println("redis set failed:", err)
}
// 讀取指定zset
user_map, err := redis.StringMap(conn.Do("ZRANGE", "mykey", 0, 10, "withscores"))
if err != nil {
fmt.Println("redis get failed:", err)
} else {
fmt.Printf("Get mykey: %v \n", user_map)
}
for user := range user_map {
fmt.Printf("user name: %v %v\n", user, user_map[user])
}
}
輸出:
Connect to redis ok.
Get mykey: map[robot1:1 robot2:1]
user name: robot1 1
user name: robot2 1
補充:Redis中zset的golang實現(xiàn)
zset
初衷是在不用Redis的前提下實現(xiàn)排行榜
項目地址https://github.com/liyiheng/zset
Installation
go get -u github.com/liyiheng/zset
Usage
Removed RWLock in the SortedSet.
Just implement it yourself if you need.
s := zset.New()
// add data
s.Set(66, 1001, "test1")
s.Set(77, 1002, "test2")
s.Set(88, 1003, "test3")
s.Set(100, 1004, "liyiheng")
s.Set(99, 1005, "test4")
s.Set(44, 1006, "test5")
// update data
s.Set(44, 1001, "test1")
// get rank by id
rank, score, extra := s.GetRank(1004, false)
// get data by rank
id, score, extra := s.GetDataByRank(0, true)
// get data by id
dat, ok := s.GetData(1001)
// delete data by id
s.Delete(1001)
Benchmark
go test -test.bench=".*"
BenchmarkSortedSet_Add-4 1000000 4121 ns/op
BenchmarkSortedSet_GetRank-4 500000 3592 ns/op
BenchmarkSortedSet_GetDataByRank-4 2000000 667 ns/op
PASS
ok zset 11.365s
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
您可能感興趣的文章:- SpringBoot集成Redisson實現(xiàn)延遲隊列的場景分析
- springboot+websocket+redis搭建的實現(xiàn)
- java、spring、springboot中整合Redis的詳細(xì)講解
- 關(guān)于Springboot2.x集成lettuce連接redis集群報超時異常Command timed out after 6 second(s)
- 如何自定義redis工具jar包供其他SpringBoot項目直接使用
- 使用SpringBoot集成redis的方法
- springboot連接Redis的教程詳解
- SpringBoot和Redis實現(xiàn)Token權(quán)限認(rèn)證的實例講解
- SpringBoot集成Redis實現(xiàn)消息隊列的方法
- springboot基于Redis發(fā)布訂閱集群下WebSocket的解決方案
- springboot2整合redis使用lettuce連接池的方法(解決lettuce連接池?zé)o效問題)
- php使用redis的有序集合zset實現(xiàn)延遲隊列應(yīng)用示例
- SpringBoot使用Redis的zset統(tǒng)計在線用戶信息