【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", 0).Err()
### 如何在 Docker 中集成 RedisGolang 为了实现 RedisGolang 的集成并将其容器化,可以按照以下方法操作: #### 配置 Redis 容器 首先,在 Docker 中启动一个 Redis 实例作为状态存储服务。可以通过指定如下配置来创建 Redis 容器[^1]: ```bash docker run --name redis-container -d redis ``` 此命令会拉取官方的 Redis 镜像并以后台模式运行。 #### 创建 Go 应用程序并与 Redis 进行交互 接下来,编写一段简单的 Go 程序用于连接到 Redis 并执行基本的操作。以下是完整的代码示例: ```go package main import ( "context" "fmt" "log" "github.com/go-redis/redis/v8" ) func main() { rdb := redis.NewClient(&redis.Options{ Addr: "redis-container:6379", // 使用 Redis 容器名称作为主机名 Password: "", // 如果设置了密码,则在此处填写 DB: 0, // 默认数据库编号 }) ctx := context.Background() err := rdb.Set(ctx, "key", "value", 0).Err() if err != nil { log.Fatalf("Error setting key: %v\n", err) } val, err := rdb.Get(ctx, "key").Result() if err != nil { log.Fatalf("Error getting key: %v\n", err) } fmt.Println("Key value:", val) } ``` 上述代码展示了如何通过 `github.com/go-redis/redis` 包建立与 Redis 数据库之间的连接,并设置以及获取键值对数据。 #### 构建和运行 Go 应用程序的 Docker 映像 要将该应用程序打包成 Docker 映像以便于分发和部署,请先定义一份 `Dockerfile` 文件: ```dockerfile FROM golang:1.19 AS builder WORKDIR /app COPY . . RUN go mod download && \ CGO_ENABLED=0 GOOS=linux go build -o app . FROM alpine:latest WORKDIR /root/ COPY --from=builder /app/app . CMD ["./app"] ``` 完成之后,利用下面这条指令生成映像文件: ```bash docker build -t my-go-app . ``` 最后一步就是同时启动两个容器——一个是已经存在的 Redis 容器,另一个是我们新构建好的 Go 应用程序容器。这里推荐采用 Docker Compose 来简化多容器环境下的管理工作流程[^2]。 #### 编写 docker-compose.yml 文件 ```yaml version: '3' services: redis: image: "redis:alpine" container_name: redis-container ports: - "6379:6379" go-app: build: . depends_on: - redis environment: REDIS_HOST: redis-container ``` 随后只需简单地输入以下命令即可一键启动整个项目栈: ```bash docker-compose up ``` 这样就完成了在一个基于 Docker 的环境中成功集成了 RedisGolang 的全过程。 ---
评论 74
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

寸 铁

感谢您的支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值