【Redis】golang操作Redis基础入门

【Redis】golang操作Redis基础入门

大家好 我是寸铁
总结了一篇【Redis】golang操作Redis基础入门sparkles:
喜欢的小伙伴可以点点关注

Redis的作用

Redis(Remote Dictionary Server)是一个开源的内存数据库,它主要用于存储键值对,并提供多种数据结构的支持。Redis 的主要作用包括:

  • 1.缓存: Redis 可以作为缓存系统,将常用的数据缓存在内存中,以提高数据访问速度。由于 Redis 是基于内存的,所以读取速度非常快,适用于需要快速访问的场景,如网页缓存、API 响应缓存等。
  • 2.会话存储: 可以将用户会话信息存储在 Redis 中,实现分布式会话管理。这样可以避免单点故障,并且能够轻松地实现会话共享和负载均衡。
  • 3.消息队列: Redis 支持发布订阅(Pub/Sub)模式,可以用作简单的消息队列系统。发布者将消息发布到特定的频道,而订阅者则可以订阅这些频道以接收消息。这使得 Redis 在异步通信、任务队列等场景中非常有用。
  • 4.计数器和排行榜: Redis 的原子计数器和有序集合功能可用于实现计数器和排行榜功能。比如统计网站访问次数、文章点赞数、用户积分排行等。
  • 5.分布式锁: Redis 的 SETNX 和 EXPIRE 命令结合可以实现分布式锁,用于控制多个客户端对共享资源的访问,防止出现竞态条件。
  • 6.持久化: Redis 支持多种持久化方式,包括快照(snapshot)和日志(append-only file),可以将内存中的数据定期或实时地保存到磁盘上,以防止数据丢失。
  • 7.地理空间数据处理: Redis 支持地理空间数据类型(Geo),可以存储经纬度信息,并提供相关的距离计算、地理位置查询等功能。

总的来说,Redis 是一个功能丰富的内存数据库,可以用于多种场景,包括缓存、会话存储、消息队列、计数器和排行榜、分布式锁等,为应用程序提供高性能、高可用的数据存储和处理能力。


go实现

那怎么使用go语言实现Redis的基本操作呢?下面寸铁带你手把手实现!


建立redis连接

var rdb *redis.Client

// 建立redis连接
func init() {
   
	rdb = redis.NewClient(&redis.Options{
   
		Addr:     "localhost:6379",
		Password: "",
		DB:       0,
	})
}


字段说明

Addr: 指定 Redis 服务器的地址,包括主机和端口号。在这里是本地主机的默认 Redis 端口 6379。
Password: Redis 服务器的访问密码,如果 Redis 设置了密码,需要在此处填入密码。
DB: 指定连接的 Redis 数据库编号。Redis 支持多个数据库,默认使用的是第一个数据库编号为 0。


设置指定键的值

ctx := context.Background()
	err := rdb.Set(ctx, "rediskey", "redisvalue", 0).Err()
	if err != nil {
   
		panic(err)
	}
字段说明

上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“rediskey”,指定要设置的键名。
键值:“redisvalue”,指定要设置的键值。
过期时间:0,表示该键永不过期。


获取指定键的值

	getres, err := rdb.Get(ctx, "rediskey").Result()
	if err != nil {
   
		panic(err)
	}
	fmt.Println("get执行的result", getres) 
字段说明

上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“rediskey”,指定要获取值的键名。


执行原生的 Redis 命令

dores, err := rdb.Do(ctx, "GET", "rediskey").Result()
if err != nil {
   
    panic(err)
}
fmt.Println("do get 执行的result", dores.(string))
字段说明

上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
Redis 命令:“GET”,指定要执行的 Redis 命令是 GET。
命令参数:“rediskey”,指定 GET 命令的键名。


设置指定键的值,并返回键的旧值

oldres, err := rdb.GetSet(ctx, "rediskey", "newvalue").Result()
if err != nil {
   
    panic(err)
}
fmt.Println("GetSet执行的result", oldres) // redisvalue

字段说明

上下文(context):在 Go 中,上下文用于控制请求的生命周期,包括取消请求和设置超时时间等。
键名:“rediskey”,指定要设置值的键名。
新值:“newvalue”,指定要设置的新值。


键不存在时设置键的值

err = rdb.SetNX(ctx, "key3", "value3"

你可能感兴趣的:(go,数据库,Redis,redis,golang,数据库,CRUD,基本操作,分布式,键值对)