Go语言中Redis缓存与本地内存缓存实战

 更新时间:2025年03月21日 09:22:28   作者:zhuyasen  
在现代高并发系统中,缓存技术是提升性能和降低数据库压力的关键手段,本文将为大家介绍一下Redis缓存与本地内存缓存的具体应用,需要的可以了解下

在现代高并发系统中,缓存技术是提升性能和降低数据库压力的关键手段。无论是分布式系统中的Redis缓存,还是本地高效的本地内存缓存,合理使用都能让你的应用如虎添翼。今天,我们将基于go-dev-frame/sponge/pkg/cache库的代码示例,深入探讨这两种缓存的原理与使用方法,带你从零到一掌握缓存技术。

缓存的原理:为什么它如此重要

缓存的核心思想是通过将频繁访问的数据存储在快速读取的介质中,减少对底层存储(如数据库)的直接请求。以Redis为例,它是一个高性能的键值对存储系统,支持持久化、网络分布式部署,适合大规模分布式应用。而本地内存缓存则利用程序运行时的RAM,速度更快但容量有限,通常用于单机场景或临时数据存储。两者的共同目标是:降低延迟,提升吞吐量

cache库中,无论是Redis还是本地内存缓存,都通过统一的接口封装了SetGetDelete操作。这种设计不仅简化了开发,还提供了灵活的扩展性。接下来,我们将通过代码示例,逐一剖析它们的实现与应用。

使用Redis缓存:分布式性能的保障

Redis以其高可用性和丰富的数据结构著称。在cache中,我们可以通过以下代码快速集成Redis缓存:

package main

import (
	"context"
	"fmt"
	"time"

	"github.com/redis/go-redis/v9"
	"github.com/go-dev-frame/sponge/pkg/cache"
	"github.com/go-dev-frame/sponge/pkg/encoding"
)

// User 结构体示例
type User struct {
	ID   int
	Name string
}

func main() {
	// 初始化 Redis 客户端
	redisClient := redis.NewClient(&redis.Options{
		Addr:     "localhost:6379",
		Password: "",
		DB:       0,
	})

	cachePrefix := "user:"
	jsonEncoding := encoding.JSONEncoding{}
	newObject := func() interface{} {
		return &User{}
	}

	// 创建 Redis 缓存实例
	c := cache.NewRedisCache(redisClient, cachePrefix, jsonEncoding, newObject)

	ctx := context.Background()
	user := &User{ID: 1, Name: "Alice"}

	// 设置缓存数据
	err := c.Set(ctx, "1", user, 10*time.Minute)
	if err != nil {
		fmt.Println("缓存存储失败:", err)
		return
	}

	// 获取缓存数据
	var cachedUser User
	err = c.Get(ctx, "1", &cachedUser)
	if err != nil {
		fmt.Println("缓存读取失败:", err)
		return
	}
	fmt.Println("从缓存获取用户:", cachedUser)

	// 删除缓存
	c.Delete(ctx, "1")
}

原理剖析

NewRedisCache函数通过Redis客户端、cachePrefix(键前缀,用于命名空间隔离)、jsonEncoding(序列化方式)和newObject(反序列化目标对象构造器)初始化缓存实例。Set方法将数据序列化为JSON后存入Redis,Get方法则反序列化回指定对象。这种设计兼顾了灵活性与类型安全,非常适合需要跨服务共享数据的场景。

使用本地内存缓存:单机性能的极致追求

对于不依赖分布式的场景,本地内存缓存是一个轻量高效的选择。以下是一个基于sponge/pkg/cache的本地内存缓存示例:

package main

import (
	"context"
	"fmt"
	"time"

	"github.com/go-dev-frame/sponge/pkg/cache"
	"github.com/go-dev-frame/sponge/pkg/encoding"
)

// User 结构体示例
type User struct {
	ID   int
	Name string
}

func main() {
	// 初始化内存缓存
	cachePrefix := "user:"
	jsonEncoding := encoding.JSONEncoding{}
	newObject := func() interface{} {
		return &User{}
	}

	// 创建内存缓存实例
	c := cache.NewMemoryCache(cachePrefix, jsonEncoding, newObject)

	ctx := context.Background()
	user := &User{ID: 2, Name: "Bob"}

	// 设置缓存数据
	err := c.Set(ctx, "2", user, 10*time.Minute)
	if err != nil {
		fmt.Println("缓存存储失败:", err)
		return
	}

	// 获取缓存数据
	var cachedUser User
	err = c.Get(ctx, "2", &cachedUser)
	if err != nil {
		fmt.Println("缓存读取失败:", err)
		return
	}
	fmt.Println("从缓存获取用户:", cachedUser)

	// 删除缓存
	c.Delete(ctx, "2")
}

原理剖析

本地内存缓存基于本地RAM实现,默认使用类似bigcache的底层库,支持配置最大容量和淘汰策略(如LRU)。通过InitGlobalMemory可以自定义缓存参数,但即使不初始化也能直接使用默认配置。它的优势在于无需网络IO,延迟极低,适合高频读写的场景。

Redis vs 本地内存缓存:如何选择?

Redis:适用于分布式系统、需要持久化或跨进程共享数据的场景。缺点是网络开销和部署成本较高。

本地内存缓存:适合单机高性能需求或临时数据存储,简单易用但容量受限,且重启后数据丢失。

总结

通过cache库,Go开发者可以轻松集成Redis和本地内存缓存,满足不同场景的性能需求。无论是分布式系统的Redis,还是单机场景的本地内存缓存,它们都以统一接口降低了学习成本,同时保留了高度的灵活性。

到此这篇关于Go语言中Redis缓存与本地内存缓存实战的文章就介绍到这了,更多相关Go Redis缓存与本地内存缓存内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Go语言并发之context标准库的使用详解

    Go语言并发之context标准库的使用详解

    Context的出现是为了解决在大型应用程序中的并发环境下,协调和管理多个goroutine之间的通信、超时和取消操作的问题,本文就来和大家简单聊聊它的具体用法,希望对大家有所帮助
    2023-06-06
  • Go语言学习笔记之反射用法详解

    Go语言学习笔记之反射用法详解

    这篇文章主要介绍了Go语言学习笔记之反射用法,详细分析了Go语言中反射的概念、使用方法与相关注意事项,需要的朋友可以参考下
    2017-05-05
  • Golang 内存模型详解(一)

    Golang 内存模型详解(一)

    这篇文章主要介绍了Golang 内存模型详解(一),本文讲解了Go内存模型interface、,需要的朋友可以参考下
    2014-10-10
  • 我为什么喜欢Go语言(简洁的Go语言)

    我为什么喜欢Go语言(简洁的Go语言)

    从2000年至今,也写了11年代码了,期间用过VB、Delphi、C#、C++、Ruby、Python,一直在寻找一门符合自己心意和理念的语言。我很在意写代码时的手感和执行的效率,所以在Go出现之前一直没有找到
    2014-10-10
  • Go语言中零拷贝的原理与实现详解

    Go语言中零拷贝的原理与实现详解

    零拷贝是相对于用户态来讲的,即数据在用户态不发生任何拷贝,那么零拷贝的原理是什么,又是如何实现的呢,下面小编就来和大家详细聊聊吧
    2023-08-08
  • Gin 接收前端传参几种方式小结

    Gin 接收前端传参几种方式小结

    本文主要介绍了Gin 接收前端传参几种方式小结,包括路径参数、查询字符串、表单数据、JSON数据和文件上传,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2026-03-03
  • Go json omitempty如何实现可选属性

    Go json omitempty如何实现可选属性

    在Go语言中,使用`omitempty`可以帮助我们在进行JSON序列化和反序列化时,忽略结构体中的零值或空值,本文介绍了如何通过将字段类型改为指针类型,并在结构体的JSON标签中添加`omitempty`来实现这一功能,例如,将float32修改为*float32
    2024-09-09
  • 详解Go语言中的监视器模式与配置热更新

    详解Go语言中的监视器模式与配置热更新

    这篇文章主要为大家详细介绍了Go语言中的监视器模式与配置热更新的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-03-03
  • 浅析Go语言中数组的这些细节

    浅析Go语言中数组的这些细节

    这篇文章主要为大家详细介绍了Go语言中数组一些细节的相关资料,文中的示例代码讲解详细,对我们学习Go语言有一定的帮助,需要的可以了解一下
    2022-11-11
  • Go语言metrics应用监控指标基本使用说明

    Go语言metrics应用监控指标基本使用说明

    这篇文章主要为大家介绍了Go语言metrics应用监控指标的基本使用说明,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02

最新评论