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.mzph.cn/web/62424.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue项目开发 如何实现父组件与子组件数据间的双向绑定?

在 Vue.js 中,实现父组件与子组件数据之间的双向绑定,可以通过以下几种方式。下面我将介绍几种常见的方法,并解释它们的实现原理和适用场景。 1. 使用 v-model 实现双向绑定 v-model 是 Vue.js 中最常见的双向绑定方式,它可以使…

React第十七章(useRef)

useRef 当你在React中需要处理DOM元素或需要在组件渲染之间保持持久性数据时,便可以使用useRef。 import { useRef } from react; const refValue useRef(initialValue) refValue.current // 访问ref的值 类似于vue的ref,Vue的ref是.value,其次就是vu…

【C++】内存分布、new、delete、 operator new、operator delete

内存分布 在C语言和C中,程序内存被划分成六个部分: 内核空间、栈、内存映射段、堆、数据段、代码段 栈:又称堆栈,主要为非静态局部变量、函数参数、返回值等,栈的生长方向是向下生长的 内存映射段:高效的…

代码随想录算法训练营day37|动态规划part5

今天的几道题目都比较简单,思路也比较相似,都是利用完全背包。完全背包和01背包的不同点在于完全背包每个元素可以取多次,而01背包只能取1次,所以在dp一维数组遍历时,完全背包仍然要从前往后遍历,并且无论是…

混合云策略在安全领域受到青睐

Genetec 发布了《2025 年物理安全状况报告》,该报告根据超过 5,600 名该领域领导者(其中包括 100 多名来自澳大利亚和新西兰的领导者)的回应,揭示了物理安全运营的趋势。 报告发现,澳大利亚和新西兰的组织采用混合云策…

FastAPI解决跨域报错net::ERR_FAILED 200 (OK)

目录 一、跨域问题的本质 二、FastAPI中的CORS处理 1. 安装FastAPI和CORS中间件 2. 配置CORS中间件 3. 运行FastAPI应用 三、解决跨域报错的步骤 四、案例:解决Vue.js与FastAPI的跨域问题 1. Vue.js前端应用 2. FastAPI后端API 3. 配置CORS中间件 4. 运行和测试 五…

为什么 JavaScript 中的 `new` 运算符报错?

在 JavaScript 中,new 运算符通常用于创建一个新对象并调用构造函数来初始化对象。然而,new 运算符可能会引发一些错误,通常是由于以下原因导致的: 构造函数没有正确的定义: 如果使用 new 运算符调用的函数没有正确地定…

霍尔效应电流传感器

适用于大电流,低功耗的电流检测: TVS选型: RS232的隔离电路: 单片机采集200伏高压 如何做隔离电路: 采用线性光电耦合器HCNR200实现高压直流母线电压的精确采样。还是用电阻分压,只是在ADC检测阶段加上隔离芯片:

如何设置Java爬虫的异常处理?

在Java爬虫中设置异常处理是非常重要的,因为网络请求可能会遇到各种问题,如连接超时、服务器错误、网络中断等。通过合理的异常处理,可以确保爬虫的稳定性和健壮性。以下是如何在Java爬虫中设置异常处理的步骤和最佳实践: 1. 使用…

ceph /etc/ceph-csi-config/config.json: no such file or directory

环境 rook-ceph 部署的 ceph。 问题 kubectl describe pod dragonfly-redis-master-0Warning FailedMount 7m59s (x20 over 46m) kubelet MountVolume.MountDevice failed for volume "pvc-c63e159a-c940-4001-bf0d-e6141634cc55" : rpc error: cod…

【计网笔记】习题

物理层 不属于物理层接口规范定义范畴的是(C) A. 接口形状 B. 引脚功能 C. 物理地址 D. 信号电平 【2023-912】光网络只能通过导向型介质传播。() 【2017-408】若信道在无噪声情况下的极限数据传输速率不小于信噪比为30dB条件下的…

最新 AI 编程工具全面对比:v0、Bolt.new、Cursor、Windsurf

随着人工智能的快速发展,越来越多的 AI 驱动的开发工具应运而生,旨在提升开发效率、优化开发流程,并减轻开发者的工作负担。在这个背景下,四款新兴的 AI 编程工具:v0、Bolt.new、Cursor 和 Windsurf,各具特…

【C++算法】35.位运算_两整数之和

文章目录 题目链接:题目描述:解法C 算法代码: 题目链接: 371. 两整数之和 题目描述: 解法 笔试的话直接 return ab; 接下来讲一下这题的解法: 位运算(异或运算-无进位相加&#xff…

PyCharm+Selenium+Pytest配置小记

1、下载ChromeDriver: Chrome130以后的Driver下载: Chrome for Testing availabilityhttps://googlechromelabs.github.io/chrome-for-testing/ (1)查看自己Crome浏览器的版本:设置-->关于 Chrome; &…

【C++】虚函数

类中声明函数成员的时候,在函数的前面加上virtual关键字,则该成员为虚函数 虚函数的特点 如果在类中定义的虚函数,那么系统会为这个类维护一个虚函数表类中会多出4个字节的指针去指向这个虚函数表,在虚函数表中保存了虚函数的首…

如何在UI自动化测试中创建稳定的定位器?

如何在UI自动化测试中创建稳定的定位器? 前言1. 避免使用绝对路径2. 避免在定位器中使用索引3. 避免多个类名的定位器4. 避免动态和自动生成的ID5. 确保定位器唯一6. 处理隐藏元素的策略7. 谨慎使用基于文本的定位器8. 使用AI创建稳定的定位器 总结 前言 在自动化测…

明日宣讲 香港科技大学广州|数据科学与分析学域硕博招生宣讲会【湖南大学专场】

📣📣📣明日宣讲 香港科技大学广州|数据科学与分析学域硕博招生宣讲会【湖南大学专场】 时间:2024年12月10日(星期二)15:00 地点:湖南大学信息科学与工程学院624会议室 报名链接&…

BurpSuite-8(FakeIP与爬虫审计)

声明:学习视频来自b站up主 泷羽sec,如涉及侵权马上删除文章 感谢泷羽sec 团队的教学 视频地址:IP伪造和爬虫审计_哔哩哔哩_bilibili 一、FakeIP 1.配置环境 BurpSuite是java环境下编写的,而今天的插件是python编写的&#xff0c…

2024 一带一路暨金砖国家技能发展与技术创新大赛【网络安全防护治理实战技能赛项】样题(中职组)

2024 一带一路暨金砖国家技能发展与技术创新大赛【网络安全防护治理实战技能赛项】样题(中职组) 1.基础设置和安全强化(xxx 分)1.3. 任务内容: 2.安全监测和预警(xxx 分)2.1. 任务一:建立目录安…

Qt C++ 显示多级结构体,包括结构体名、变量名和值

文章目录 mainwindow.hmainwindow.cppstructures.hmain.cpp QTreeView 和 QStandardItemModel 来实现。以下是实现这一功能的步骤和示例代码: 定义多级结构体: 假设你有一个多级结构体,如下所示: struct SubStruct {int subValue…