当前位置: 首页 > news >正文

30天学会Go--第7天 GO语言 Redis 学习与实践

30天学会Go–第7天 GO语言 Redis 学习与实践

文章目录

  • 30天学会Go--第7天 GO语言 Redis 学习与实践
    • 前言
    • 一、Redis 基础知识
      • 1.1 Redis 的核心特性
      • 1.2 Redis 常见使用场景
    • 二、安装 Redis
      • 2.1 在 Linux 上安装
      • 2.2 在 Windows 上安装
      • 2.3 使用 Docker 安装 Redis
    • 三、Redis 常用命令
      • 3.1 基本操作
      • 3.2 数据结构操作
        • 字符串(String)
        • 哈希(Hash)
        • 列表(List)
        • 集合(Set)
        • 有序集合(Sorted Set)
    • 四、在 Go 中使用 Redis
      • 4.1 安装 go-redis
      • 4.2 使用示例
        • 代码示例
      • 4.3 代码解读
    • 五、Redis 高级功能
      • 5.1 发布/订阅(Pub/Sub)
        • 代码示例
      • 5.2 使用 Redis 实现分布式锁
        • 代码示例
    • 六、总结

前言

Redis 是一个高性能的开源内存数据库,常用于缓存、消息队列、会话存储等场景。它支持多种数据结构(如字符串、哈希、列表、集合、有序集合等)和丰富的操作命令,具有极高的性能和灵活性。

以下是 Redis 的基础知识、安装、常用命令,以及在 Go 中使用 Redis 的方法。

go语言官方编程指南:https://pkg.go.dev/stdopen in new window

go语言的官方文档学习笔记很全,推荐去官网学习

30天学会Go–第7天 GO语言 Redis 学习与实践(改):30天学会Go–第7天 GO语言 Redis 学习与实践(改)

本章讲redis有所欠缺,请移步新的blog

30天学会Go–第6天 GO语言 RESTful API 学习与实践:30天学会Go–第6天 GO语言 RESTful API 学习与实践-CSDN博客


一、Redis 基础知识

1.1 Redis 的核心特性

  • 内存存储:所有数据存储在内存中,读写速度极快。
  • 多种数据结构:支持字符串(String)、哈希(Hash)、列表(List)、集合(Set)、有序集合(Sorted Set)等。
  • 持久化:支持将内存数据持久化到磁盘(RDB 和 AOF 两种方式)。
  • 高可用:支持主从复制、哨兵模式和集群模式,提供高可用性和扩展性。
  • 丰富的功能:如发布/订阅(Pub/Sub)、事务、Lua 脚本等。

1.2 Redis 常见使用场景

  • 缓存:将经常访问的数据存储到 Redis 中,提高读取性能。
  • 会话存储:存储用户登录状态等会话信息。
  • 排行榜:利用有序集合(Sorted Set)实现排行榜功能。
  • 消息队列:使用列表(List)或发布/订阅功能实现消息队列。
  • 分布式锁:利用 Redis 的原子操作实现分布式锁。

二、安装 Redis

2.1 在 Linux 上安装

  1. 下载 Redis:
    wget http://download.redis.io/redis-stable.tar.gz
    
  2. 解压并编译:
    tar xzf redis-stable.tar.gz
    cd redis-stable
    make
    
  3. 启动 Redis:
    src/redis-server
    

2.2 在 Windows 上安装

  1. 下载 Redis for Windows:
    • Redis 官方不支持 Windows,但可以下载社区版:https://github.com/microsoftarchive/redis/releases
  2. 解压后运行 redis-server.exe 启动服务。

2.3 使用 Docker 安装 Redis

  1. 拉取 Redis 镜像:
    docker pull redis
    
  2. 启动 Redis 容器:
    docker run -d --name redis -p 6379:6379 redis
    

三、Redis 常用命令

3.1 基本操作

  • 连接 Redis

    redis-cli
    
  • 设置键值对

    SET key value
    
  • 获取键值

    GET key
    
  • 删除键

    DEL key
    
  • 检查键是否存在

    EXISTS key
    
  • 设置过期时间(秒)

    EXPIRE key seconds
    
  • 查看剩余过期时间

    TTL key
    

3.2 数据结构操作

字符串(String)
  • 增加值(适用于数值类型)

    INCR key
    INCRBY key increment
    DECR key
    DECRBY key decrement
    
哈希(Hash)
  • 设置哈希字段
    HSET key field value
    
  • 获取哈希字段值
    HGET key field
    
  • 获取所有字段和值
    HGETALL key
    
列表(List)
  • 从左插入元素

    LPUSH key value1 value2
    
  • 从右插入元素

    RPUSH key value1 value2
    
  • 获取列表范围内的元素

    LRANGE key start stop
    
  • 弹出最左边的元素

    LPOP key
    
集合(Set)
  • 添加元素到集合
    SADD key member1 member2
    
  • 获取集合中的所有元素
    SMEMBERS key
    
  • 检查元素是否存在
    SISMEMBER key member
    
有序集合(Sorted Set)
  • 添加元素并设置分数
    ZADD key score1 member1 score2 member2
    
  • 获取有序集合中的元素
    ZRANGE key start stop WITHSCORES
    

四、在 Go 中使用 Redis

在 Go 中使用 Redis,通常使用第三方库 go-redis。

4.1 安装 go-redis

运行以下命令安装:

go get github.com/redis/go-redis/v9

4.2 使用示例

以下是一个简单的示例,展示如何在 Go 中使用 Redis。

代码示例
package mainimport ("context""fmt""github.com/redis/go-redis/v9"
)var ctx = context.Background()func main() {// 1. 连接到 Redisrdb := redis.NewClient(&redis.Options{Addr:     "localhost:6379", // Redis 地址Password: "",               // 如果没有设置密码,留空DB:       0,                // 使用默认数据库})// 2. 写入数据err := rdb.Set(ctx, "key", "value", 0).Err()if err != nil {panic(err)}// 3. 读取数据val, err := rdb.Get(ctx, "key").Result()if err != nil {panic(err)}fmt.Println("key:", val)// 4. 检查键是否存在exists, err := rdb.Exists(ctx, "key").Result()if err != nil {panic(err)}fmt.Println("key exists:", exists)// 5. 删除键err = rdb.Del(ctx, "key").Err()if err != nil {panic(err)}fmt.Println("key deleted")
}

4.3 代码解读

  1. 连接 Redis

    • 使用 redis.NewClient 创建 Redis 客户端。
    • 配置地址、密码和数据库编号。
  2. 写入数据

    • 使用 Set 方法写入键值对。
    • 第三个参数为过期时间,0 表示不过期。
  3. 读取数据

    • 使用 Get 方法读取键的值。
  4. 检查键是否存在

    • 使用 Exists 方法检查键是否存在。
  5. 删除键

    • 使用 Del 方法删除键。

五、Redis 高级功能

5.1 发布/订阅(Pub/Sub)

Redis 支持发布/订阅模式,可以实现消息广播。

代码示例
// 发布消息
rdb.Publish(ctx, "channel1", "Hello, Redis!").Err()// 订阅消息
sub := rdb.Subscribe(ctx, "channel1")
ch := sub.Channel()
for msg := range ch {fmt.Println("Received message:", msg.Payload)
}

5.2 使用 Redis 实现分布式锁

Redis 的原子操作可以用来实现分布式锁。

代码示例
// 加锁
ok, err := rdb.SetNX(ctx, "lock_key", "lock_value", 10*time.Second).Result()
if err != nil || !ok {fmt.Println("Failed to acquire lock")return
}// 执行业务逻辑
fmt.Println("Lock acquired, executing task...")// 解锁
rdb.Del(ctx, "lock_key")

六、总结

Redis 是一个功能强大且灵活的内存数据库,在 Go 中使用 Redis 非常简单。通过学习 Redis 的基本命令和在 Go 中的集成,你可以轻松实现缓存、消息队列、分布式锁等功能。

http://www.lryc.cn/news/501443.html

相关文章:

  • java 使用JSqlParser和CCJSqlParser 解析sql
  • 基于spring boot的高校专业实习管理系统的设计与实现
  • OpenCV相机标定与3D重建(11)机器人世界手眼标定函数calibrateRobotWorldHandEye()的使用
  • 计算机网络ENSP课设--三层架构企业网络
  • 【openwrt】openwrt-21.02 基于IP地址使用ipset实现策略路由操作说明
  • Git:常用命令
  • 【2025最新版】搭建个人博客教程
  • 微信小程序实现联动删除输入验证码框
  • 数据库中decimal、float 和 double区别
  • 网络编程01
  • el-dialog修改其样式不生效加deep也没用
  • 三天精通一算法之快速排序
  • 互联网、物联网的相关标准
  • Linux题库及答案
  • Android 镜像模式和扩展模式区别探讨-Android14
  • 深度学习笔记之BERT(五)TinyBERT
  • 【时间序列预测】基于PyTorch实现CNN_BiLSTM算法
  • 联想Y7000 2024版本笔记本 RTX4060安装ubuntu22.04双系统及深度学习环境配置
  • VuePress学习
  • 一次“okhttp访问间隔60秒,提示unexpected end of stream“的问题排查过程
  • SQL最佳实践:避免使用COUNT=0
  • PG与ORACLE的差距
  • 树莓派3B+驱动开发(2)- LED驱动(传统模式)
  • 超详细搭建PhpStorm+PhpStudy开发环境
  • 分析比对vuex和store模式
  • C# 网络编程--基础核心内容
  • 【C++游戏程序】easyX图形库还原游戏《贪吃蛇大作战》(三)
  • uni-app H5端使用注意事项 【跨端开发系列】
  • SpringBoot中的@Configuration注解
  • 十二、路由、生命周期函数