GO学习之 数据库(Redis)

这篇具有很好参考价值的文章主要介绍了GO学习之 数据库(Redis)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

GO系列

1、GO学习之Hello World
2、GO学习之入门语法
3、GO学习之切片操作
4、GO学习之 Map 操作
5、GO学习之 结构体 操作
6、GO学习之 通道(Channel)
7、GO学习之 多线程(goroutine)
8、GO学习之 函数(Function)
9、GO学习之 接口(Interface)
10、GO学习之 网络通信(Net/Http)
11、GO学习之 微框架(Gin)
12、GO学习之 数据库(mysql)
13、GO学习之 数据库(Redis)
14、GO学习之 搜索引擎(ElasticSearch)
15、GO学习之 消息队列(Kafka)
16、GO学习之 远程过程调用(RPC)
17、GO学习之 goroutine的调度原理

前言

按照公司目前的任务,go 学习是必经之路了,虽然行业卷,不过技多不压身,依旧努力!!!
一个项目想要提高访问速度和性能,缓存是很重要的一步,甚至可以说是必不可少,那目前最最流行的还是 Redis 缓存,那 Go 中怎么对Redis进行操作呢?有哪些第三方的函数库可以方便我们使用呢?

一、Redis 简介

尽管说起 Redis 大家都很熟悉,不过个人觉得再熟悉的东西也难免有疏忽的点。
Redis(Remote Dictionary Server)是一个开源的高性能的基于key-value内存数据存储系统,遵循 BSD 协议,通常被用作缓存数据库消息队列。Redis 支持多种数据结构,比如:string、list、set、zset、hash等。
Redis优点如下(不限于):

  1. 高性能:Redis基于内存进行数据读写,速度非常快。
  2. 数据结构多样性:Redis 支持多样数据结构,适用于不同的数据存储需求。
  3. 支持持久化:Redis可以持久化数据到磁盘,防止数据丢失,有 RDBAOF混合持久化方式。
  4. 支持分布式:Redis提供了分布式存储的支持,以集群的方式提供服务,有 主从(master - slave)、哨兵(Sentinel)、集群(Cluster)集群方式。
  5. 功能更加丰富:Redis提供了更加丰富的功能,比如:发布订阅、Lua脚本执行等。

Redis 缺点如下(不限于):

  1. 内存限制:Redis数据存储在内存中,受限于内存大小,不适用与存储大量数据。
  2. 数据持久化效率:数据持久化可能会影响Redis性能。

二、Redis 基本操作

首先下载 Redis 的第三方库:

针对简单的 Redis 操作,操作比较容易上手。

go get github.com/go-redis/redis

2.1 get - set 操作

package main

import (
	"fmt"
	"log"

	"github.com/go-redis/redis"
)

func main() {
	// 创建一个Redis客户端
	client := redis.NewClient(&redis.Options{
		Addr:     "192.168.1.199:6379",
		Password: "",
		DB:       0,
	})

	// 设置一个 key - value
	key := "key-2"
	value := "Hello Redis"
	// err := client.Set(key, value, 0).Err()
	err := client.Set(key, value, 0).Err()
	if err != nil {
		log.Fatal(err)
	}
	fmt.Println("set key 成功!")

	// 获取一个key
	val, gErr := client.Get(key).Result()
	if gErr != nil {
		log.Fatal(gErr)
	}
	fmt.Println("获取到:", key, val)
}

运行结果:

PS D:\workspaceGo\src\redis> go run .\getset.go
set key 成功!
获取到: key-2 Hello Redis

2.2 lpush - lpop 操作

package main

import (
	"fmt"
	"log"

	"github.com/go-redis/redis"
)

func main() {
	// 创建一个Redis客户端
	client := redis.NewClient(&redis.Options{
		Addr:     "192.168.1.199:6379",
		Password: "",
		DB:       0,
	})

	key := "myList"
	value := "element-"
	// 向列表中添加元素
	for i := 0; i < 3; i++ {
		err := client.LPush(key, fmt.Sprint(value, i)).Err()
		if err != nil {
			log.Fatal(err)
		}
	}
	fmt.Println("Lpush 成功!")

	// 向列表中获取元素
	elements, lErr := client.LPop(key).Result()
	if lErr != nil {
		log.Fatal(lErr)
	}
	fmt.Printf("获取到列表 %s:%v", key, elements)
}

运行结果:

PS D:\workspaceGo\src\redis> go run .\listTest.go
Lpush 成功!
获取到列表 myList:element-2

2.3 hset - hget 操作

package main

import (
	"fmt"
	"log"

	"github.com/go-redis/redis"
)

func main() {
	// 创建一个Redis客户端
	client := redis.NewClient(&redis.Options{
		Addr:     "192.168.1.199:6379",
		Password: "",
		DB:       0,
	})

	key := "myHash"
	field := "field-"
	// 向 hash 中设置字段和值
	for i := 0; i < 3; i++ {
		err := client.HSet(key, fmt.Sprint(field, i), i).Err()
		if err != nil {
			log.Fatal(err)
		}
	}
	fmt.Println("向 myHash 中添加值成功")

	// 从 hash 中获取字段和值
	value, hErr := client.HGet(key, fmt.Sprint(field, 0)).Result()
	if hErr != nil {
		log.Fatal(hErr)
	}
	fmt.Printf("hash中的第一个字段:%s 值:%v \n", "field-0", value)

	// 获取所有的 字段 和 值
	allValue, haErr := client.HGetAll(key).Result()
	if haErr != nil {
		log.Fatal(hErr)
	}
	fmt.Println("hash中的所有字段和值", allValue)
}

运行结果:

PS D:\workspaceGo\src\redis> go run .\hashTest.go
向 myHash 中添加值成功
hash中的第一个字段:field-0 值:0
hash中的所有字段和值 map[field-0:0 field-1:1 field-2:2]

2.4 sadd - smembers 操作

package main

import (
	"fmt"
	"log"

	"github.com/go-redis/redis"
)

func main() {
	// 创建一个Redis客户端
	client := redis.NewClient(&redis.Options{
		Addr:     "192.168.1.199:6379",
		Password: "",
		DB:       0,
	})

	key := "mySet"
	value := "element-"
	// 向集合中添加元素
	for i := 0; i < 3; i++ {
		err := client.SAdd(key, fmt.Sprint(value, i)).Err()
		if err != nil {
			log.Fatal(err)
		}
	}
	fmt.Println("向集合 mySet 中添加元素完成!")

	// 从 mySet 集合中获取元素
	values, smErr := client.SMembers(key).Result()
	if smErr != nil {
		log.Fatal(smErr)
	}
	fmt.Println("从 mySet 集合中获取的元素:", values)
}

运行结果:

PS D:\workspaceGo\src\redis> go run .\setTest.go
向集合 mySet 中添加元素完成!
从 mySet 集合中获取的元素: [element-1 element-0 element-2]

三、第三方库

Redis 还有其他第三方库,比如:github.com/go-redis/redis/v8golang.org/x/net/context 上下文配合,可以在操作 Redis 过程中进行错误信息和元信息的追踪,以便实现更复杂的业务逻辑。

go get github.com/go-redis/redis/v8
go get golang.org/x/net/context

还有其他的,比如:

  • github.com/gomodule/redigo:提供了更底层的接口,允许更精细地控制 Redis 操作。
  • github.com/bsm/redislock:提供了分布式锁的实现,用于分布式系统中保证数据一致性。
  • github.com/alicebob/miniredis:这是一个内从中模拟 Redis 服务器的库,用于单元集成测试。

四、总结

此篇仅仅用了 github.com/go-redis/redis 库对 Redis 的基本操作针对不同的数据结构进行了简单的操作,其实如若对 Redis 的命令熟悉,那用 Go 来操作 Redis 就不复杂了。
总之,Redis 是一个功能丰富、高性能的内存数据存储系统,适用于缓存、数据库和消息队列等多种应用场景。在使用 Redis 缓存时,需要考虑数据存储需求、缓存失效策略等因素,以实现更高效的数据访问和管理。


现阶段还是对 Go 语言的学习阶段,想必有一些地方考虑的不全面,本文示例全部是亲自手敲代码并且执行通过。
如有问题,还请指教。
评论去告诉我哦!!!一起学习一起进步!!!文章来源地址https://www.toymoban.com/news/detail-661928.html

到了这里,关于GO学习之 数据库(Redis)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis缓存数据库(四)

    目录 一、概述 1、Redis Sentinel 1.1、docker配置Redis Sentinel环境 2、Redis存储方案 2.1、哈希链 2.2、哈希环 3、Redis分区(Partitioning)  4、Redis面试题 Redis Sentinel为Redis提供了 高可用解决方案 。实际上这意味着使用Sentinel可以部署一套Redis, 在没有人为干预的情况下去应付各种各样的失

    2024年02月05日
    浏览(42)
  • golang操作数据库--gorm框架、redis

    ①引入 ②初始化 ③增删改查 官网: http://gorm.io/ ①引入 ②初始化 ③增删改查 说明:Debug()可以查看执行的sql语句。 ④gorm gen的使用 a.先安装 (会安装到gopath的bin目录下,windows电脑,需要将该路径加入到系统路径) eg : b.举例: 说明1:windows电脑go install之后,把exe添加到系统路

    2024年02月10日
    浏览(30)
  • redis数据库缓存服务器

    redis比mysql访问数据快 非关系型数据库以键值对的方式存储数据 作用:加快访问速度,缓解数据库压力 redis最新版本7 特点 丰富的数据结构 list,set,hash等数据结构的存储 支持持久化 支持事务 “一个完整的动作,要么全部执行,要么什么也没有做” 支持主从支持高可用,支持

    2024年02月05日
    浏览(44)
  • Redis如何保证缓存和数据库一致性?

    现在我们在面向增删改查开发时,数据库数据量大时或者对响应要求较快,我们就需要用到Redis来拿取数据。 Redis:是一种高性能的内存数据库,它将数据以键值对的形式存储在内存中,具有读写速度快、支持多种数据类型、原子性操作、丰富的特性等优势。 优势: 性能极高

    2024年01月16日
    浏览(53)
  • Redis---数据库和缓存如何保证一致性?

    用「读 + 写」请求的并发的场景来分析: 假如某个用户数据在缓存中不存在,请求 A 读取数据时从数据库中查询到年龄为 20,在未写入缓存中时另一个请求 B 更新数据。它更新数据库中的年龄为 21,并且清空缓存。这时请求 A 把从数据库中读到的年龄为 20 的数据写入到缓存

    2024年01月24日
    浏览(41)
  • Redis如何保障缓存与数据库的数据一致性问题?

    目录 一.最经典的数据库加缓存的双写双删模式 二. 高并发场景下的缓存+数据库双写不一致问题分析与解决方案设计 三、上面高并发的场景下,该解决方案要注意的问题 1.1 Cache Aside Pattern概念以及读写逻辑 (1)读的时候,先读缓存,缓存没有的话,那么就读数据库,然后取

    2023年04月21日
    浏览(35)
  • redis的缓存更新策略以及如何保证redis与数据库的数据一致性

    redis的缓存更新策略有这么几种: 1、由应用直接和redis以及数据库相连接:         查询数据时,应用去redis中查询,查不到的话再由应用去数据库中查询,并将查询结果放在redis;         更新数据时,由应用去触发redis数据的删除以及数据库的update。 2、应用只跟redi

    2024年02月13日
    浏览(39)
  • 数据库缓存服务——NoSQL之Redis配置与优化

    目录 一、缓存概念 1.1 系统缓存 1.2 缓存保存位置及分层结构 1.2.1 DNS缓存 1.2.2 应用层缓存 1.2.3 数据层缓存 1.2.4 硬件缓存 二、关系型数据库与非关系型数据库 2.1 关系型数据库 2.2 非关系型数据库 2.3 关系型数据库和非关系型数据库区别: 2.4 非关系型数据库产生背景 2.5 总结

    2024年02月15日
    浏览(36)
  • Redis数据库 | 发布订阅、主从复制、哨兵模式、缓存雪崩

    💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! Redis 发布订阅 (pub/sub) 是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息 Redis 客户端可以订阅任意数量的频道 Redis主从复制是指在Redis中设置一个主节点(Master)和一个或多个从节点(Slave),

    2024年02月15日
    浏览(35)
  • Springboot+Redis:实现缓存 减少对数据库的压力

    🎉🎉欢迎光临,终于等到你啦🎉🎉 🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀 🌟持续更新的专栏 Redis实战与进阶 本专栏讲解Redis从原理到实践 这是苏泽的个人主页可以看到我其他的内容哦👇👇 努力的苏泽 http://suzee.blog.csdn.net/   目录 缓存如何实现?

    2024年03月24日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包