怎么用redigo操作redis?

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 本文介绍了使用Go语言的`redigo`库操作Redis数据库的方法。`redigo`支持Redis的所有命令,可通过`go get github.com/gomodule/redigo/redis`安装。文章详细讲解了如何建立Redis连接、执行基本的字符串操作(如设置与获取键值)、设置键值过期时间、判断键值是否存在等,并进一步演示了对Redis的数据结构如List、Set、Hash及ZSet的操作方法。此外,还提供了使用连接池以提升性能的示例。值得注意的是,`redigo`自身并不支持Redis集群功能,如需使用需引入额外的库。

前言

redigo能用于go操作redis,用于实现Redis数据库的基本操作,支持Redis的所有命令

redigo使用

redigo依赖安装

使用以下命令安装redigo依赖,以前使用的是这个命令,但是这个依赖过时了,使用最下面的安装依赖

arduino

代码解读

复制代码

 go get github.com/garyburd/redigo/redis
 

redigo最新依赖

arduino

代码解读

复制代码

 go get github.com/gomodule/redigo/redis

redigo使用

说明: redigo使用Do()方法操作redis所有的api

redigo连接redis

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}

	a, err1 := c.Do("ping")
	if err1 != nil {
		fmt.Println("连接失败:", err1)
		return
	}
	fmt.Println(a)

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

输出结果为:

备注:

如果redis有密码的话,使用以下连接

go

代码解读

复制代码

c, err := redis.Dial("tcp", "localhost:6379", redis.DialPassword("123456"))
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}

redigo操作字符串

redis字符串的命令为: 设置数据为:

sql

代码解读

复制代码

SET a1 a1

获取数据为

sql

代码解读

复制代码

GET a1

redigo操作字符串

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}

	_, err1 := c.Do("set", "a1", "a1")
	if err1 != nil {
		fmt.Println("设置数据失败:", err1)
		return
	}
	val, err2 := c.Do("get", "a1")
	if err != nil {
		fmt.Println("获取字符串失败:", err2)
		return
	}
	strVal, _ := redis.String(val, nil)
	fmt.Println("数据为: ", strVal)

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

设置键值过期时间示例

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
	"time"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}

	_, err1 := c.Do("set", "hello1", "test", "EX", "5")
	if err1 != nil {
		fmt.Println("设置过期时间失败:", err1)
		return
	}
	time.Sleep(time.Second * 6)
	valWithEx, _ := redis.String(c.Do("get", "hello1"))
	fmt.Println("获取值为:", valWithEx)

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

redigo判断键值是否存在

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}

	// 是否存在指定key
	exists, _ := c.Do("exists", "hello10")
	flag, _ := redis.Int(exists, nil)
	fmt.Println("hello10是否存在:", flag == 1)
	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

redigo操作List

将一个或多个值插入到列表头部

代码解读

复制代码

LPUSH list1 aa

在列表中添加一个或多个值到列表尾部

kotlin

代码解读

复制代码

rpush list val

获取列表指定范围内的元素

代码解读

复制代码

 LRANGE runoobkey 0 10

redigo操作List

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}
	c.Do("lpush", "list1", "l1")

	c.Do("rpush", "list1", "l3")
	list, _ := c.Do("lrange", "list1", "0", "100")
	l, _ := redis.Values(list, nil)
	for _, val := range l {
		fmt.Println(string(val.([]byte)))
	}

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

redigo操作Set

往set1添加数据

代码解读

复制代码

SADD set1 redis  aaa

获取set1数据

代码解读

复制代码

SMEMBERS set1

redigo操作set

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}
	c.Do("sadd", "set1", "a1", "a2")

	list, _ := c.Do("smembers", "set1")
	l, _ := redis.Values(list, nil)
	for _, val := range l {
		fmt.Println(string(val.([]byte)))
	}

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

redigo操作hash

redis操作hash,将哈希表 key 中的字段 field 的值设为value

markdown

代码解读

复制代码

	HSET key field value

获取在哈希表中指定 key 的所有字段和值

vbnet

代码解读

复制代码

 HGETALL key
 

redigo操作hash

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}
	_, err = c.Do("HSet", "books", "abc", 10)
	if err != nil {
		fmt.Println(err)
		return
	}

	r, err := redis.Int(c.Do("HGet", "books", "abc"))
	if err != nil {
		fmt.Println("get abc failed,", err)
		return
	}

	fmt.Println(r)

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

redigo操作zset

向有序集合添加一个或多个成员,或者更新已存在成员的分数

css

代码解读

复制代码

ZADD key score1 member1 [score2 member2]

通过分数返回有序集合指定区间内的成员

arduino

代码解读

复制代码

ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT]

redigo操作zset

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

func main() {
	c, err := redis.Dial("tcp", "localhost:6379")
	if err != nil {
		fmt.Println("redis连接失败:", err)
		return
	}
	_, err = c.Do("zadd", "runoobkey", 1, "redis")
	if err != nil {
		fmt.Println(err)
		return
	}

	r, err := c.Do("ZRANGE", "runoobkey", 0, 10, "WITHSCORES")
	if err != nil {
		fmt.Println("get abc failed,", err)
		return
	}

	l, _ := redis.Values(r, nil)
	for _, val := range l {
		fmt.Println(string(val.([]byte)))
	}

	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)
}

redigo使用连接池

go

代码解读

复制代码

package main

import (
	"fmt"
	"github.com/gomodule/redigo/redis"
)

var pool *redis.Pool

func init() {
	pool = &redis.Pool{
		MaxIdle:     8,
		MaxActive:   0,  
		IdleTimeout: 300, 
		Dial: func() (redis.Conn, error) { 
			return redis.Dial("tcp", "localhost:6379")
		},
	}
}

func main() {
	c := pool.Get()
	defer func(c redis.Conn) {
		err := c.Close()
		if err != nil {

		}
	}(c)

	_, err := c.Do("set", "hello5", "aaa")
	if err != nil {
		fmt.Println(err)
		return
	}

	r, err := redis.Strings(c.Do("get", "hello5"))
	if err != nil {
		fmt.Println("获取键值失败:", err)
		return
	}
	fmt.Println(r)
	err1 := pool.Close()
	if err1 != nil {
		return
	}
}

总结

redigo的包操作较为简练,一般为操作redis的命令,至于在开发中的技术选型,看个人习惯以及是否能提高自己开发效率而定,但是redigo自身不支持集群,这点需要注意,要支持集群,需要引入其他包


转载来源:https://juejin.cn/post/7302605813205794842

相关文章
|
安全 Java
ReentrantLock、ReentrantReadWriteLock、StampedLock讲解
ReentrantLock、ReentrantReadWriteLock、StampedLock讲解
324 0
|
Web App开发 缓存 前端开发
LightProxy 全能代理抓包工具
LightProxy 是 IFE 团队开发的一款基于 Electron 和 whistle 的开源桌面代理软件,致力于让前端开发人员能够精确的掌握自己的开发环境,通过 HTTP 代理使用规则转发、修改每一个请求和响应的内容。
LightProxy 全能代理抓包工具
|
4月前
|
人工智能 运维 API
Dify开发者必看:如何破解MCP集成与Prompt迭代难题?
Dify 是一个面向AI时代的开源大语言模型(LLM)应用开发平台,致力于让复杂的人工智能应用构建变得简单高效,目前已在全球范围内形成显著影响力,其 GitHub 仓库 Star 数截至 2025 年 6 月已突破 100,000+,目前,Dify 已经成为 LLMOps 领域增长最快的开源项目之一。
|
存储 Java C++
怎样定义和引用二维数组
怎样定义和引用二维数组
290 2
|
机器学习/深度学习 算法 Python
深度解析机器学习中过拟合与欠拟合现象:理解模型偏差背后的原因及其解决方案,附带Python示例代码助你轻松掌握平衡技巧
【10月更文挑战第10天】机器学习模型旨在从数据中学习规律并预测新数据。训练过程中常遇过拟合和欠拟合问题。过拟合指模型在训练集上表现优异但泛化能力差,欠拟合则指模型未能充分学习数据规律,两者均影响模型效果。解决方法包括正则化、增加训练数据和特征选择等。示例代码展示了如何使用Python和Scikit-learn进行线性回归建模,并观察不同情况下的表现。
1585 3
|
NoSQL Redis
Redis——批量设置key的过期时间
Redis——批量设置key的过期时间
297 1
|
算法 API 图形学
【Qt 学习笔记】QWidget的geometry属性及window frame的影响
【Qt 学习笔记】QWidget的geometry属性及window frame的影响
1007 2
|
存储 缓存 大数据
Starrocks执行查询报错:Memory of process exceed limit. Used: XXX, Limit: XXX. Mem usage has exceed the limit of BE
Starrocks执行查询报错:Memory of process exceed limit. Used: XXX, Limit: XXX. Mem usage has exceed the limit of BE
|
NoSQL Redis
蓝易云 - redis报错WRONGTYPE Operation against a key holding the wrong kind of value
解决这个问题的方法是检查你的代码,确保你对每个键使用的命令与该键的类型匹配。你可以使用 `TYPE`命令来确定一个键的类型。例如,`TYPE mykey`将返回 `mykey`的类型。
580 3
|
传感器 存储 供应链
plant simulation物流系统仿真案例
plant simulation物流系统仿真案例
665 0

热门文章

最新文章