主页 > 知识库 > 使用go操作redis的有序集合(zset)

使用go操作redis的有序集合(zset)

热门标签:服务外包 地方门户网站 呼叫中心市场需求 铁路电话系统 百度竞价排名 网站排名优化 AI电销 Linux服务器

我就废话不多说了,大家还是直接看代码吧~

package main
import (
 "fmt"
 "github.com/garyburd/redigo/redis"
)
func main() {
 // 连接redis数据库,指定数据库的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.")
 }
 // 函数退出时关闭连接
 defer conn.Close()
 // 执行一个有序zset插入
 _, err = conn.Do("ZADD", "mykey", "INCR", 1, "robot1")
 if err != nil {
 fmt.Println("redis set failed:", err)
 }
 // 再执行一个有序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实现

zset

初衷是在不用Redis的前提下实现排行榜

项目地址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

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:
  • SpringBoot集成Redisson实现延迟队列的场景分析
  • springboot+websocket+redis搭建的实现
  • java、spring、springboot中整合Redis的详细讲解
  • 关于Springboot2.x集成lettuce连接redis集群报超时异常Command timed out after 6 second(s)
  • 如何自定义redis工具jar包供其他SpringBoot项目直接使用
  • 使用SpringBoot集成redis的方法
  • springboot连接Redis的教程详解
  • SpringBoot和Redis实现Token权限认证的实例讲解
  • SpringBoot集成Redis实现消息队列的方法
  • springboot基于Redis发布订阅集群下WebSocket的解决方案
  • springboot2整合redis使用lettuce连接池的方法(解决lettuce连接池无效问题)
  • php使用redis的有序集合zset实现延迟队列应用示例
  • SpringBoot使用Redis的zset统计在线用户信息

标签:湘潭 崇左 衡水 兰州 湖南 铜川 仙桃 黄山

巨人网络通讯声明:本文标题《使用go操作redis的有序集合(zset)》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266