Golang基于内存的键值存储缓存库go-cache

2025-03-04 17:50

本文主要是介绍Golang基于内存的键值存储缓存库go-cache,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Golang基于内存的键值存储缓存库go-cache》go-cache是一个内存中的key:valuestore/cache库,适用于单机应用程序,本文主要介绍了Golang基于内存的键值存储缓存库...

go-cache是一种内存中的key:value store/cache库,类似于Memcached,适用于在一台机器上运行的应用程序(单机应用程序)。

文档

https://pkg.go.dev/github.com/patrickmn/go-cache
https://github.com/patrickmn/go-cache
https://patrickmn.com/projects/go-cache/

安装

go get github.com/patrickmn/go-cache

方法

func New(defaultExpiration, cleanupInterval time.Duration) *Cache

func (c *cache) Set(k string, x interface{}, d time.Duration)

func (c *cache) Get(k string) (interface{}, bool)

示例1

import (
    "fmt"
    "time"

    "github.com/patrickmn/go-cache"
)

func main() {
    // 设置默认过期时间10秒;清理间隔30分钟
    caching := cache.New(<strong>10*time.Second</strong>, 30*time.Minute)

    // 设置过期时间
    caching.Set("k1", "v1", 10*time.Second)
   <strong>time.Sleep(</strong><strong>5 China编程* time.Second)
</strong>  // 获取数据
    value, ok := caching.Get("k1")

    if !ok {
     php   fmt.Println("ok值为", ok)
    }
    fmt.Printf("k1对应的值是: %v\n", value)
}

Golang基于内存的键值存储缓存库go-cache

示例2

import (
    "fmt"
    "time"

    "github.com/patrickmn/go-cache"
)

func main() {
    // 设置默认过期时间10秒;清理间隔30分钟
    caching := cache.New(<strong>10*time.Second</strong>, 30*time.Minute)

    // 设置过期时间
    caching.Set("k1", "v1", 10*time.Second)
    <strong>time.Sleep(</strong><strong>15 * time.Second)
</strong>  // 获取数据
    value, ok := caching.Get("k1")

    if !ok {
        fmt.Println("ok值为", ok)
    }
    fmt.Printf("k1对应的值是: %v\n", value)
}

Golang基于内存的键值存储缓存库go-cache

使用注意点

1)尽量存放那些相对不怎么变化的数据, 适用于所有的 local cache(包括 map, sync.map)

2)go-cache 的过期检查时China编程间要设置相对较小, 也不能过小

3)那些高 QPS 的接口尽量不要去直接 Set 数据, 如果必须China编程 Set 可以采用异步操作

4)监控 go-cache 里面 key 的数量, 如果过多时, 需要及时调整参数

优点

(主要优点:本质上是一个具有过期时间的线程安全的 map[string]interface{},它不需要序列化或通过网络传输其内容)

1)简单易用,适合快速集成到现有项目中;
2)支持过期时间,可以自动淘汰过期的缓存项;
3)支持多种数据类型的缓存;

缺点

1)性能略低于其他库,不适合高并发读写的场景;
2)不支持分布式缓存。

注意

go-cache是一个内存缓存库,它主要用于单进程内的缓存操作。这意味着如果在服务 A 中设置了某个键值对,服务 B 无法直接访问服务 A 的缓存实例,因为它们是独立的进程,每个进程都有自己的缓存实例。
如果希望在多个服务之间共享缓存数据,需要使用一个分布式的缓存解决方案,例如 Redis、Memcached 或其他支持分布式缓存的系统。这些系统可以在多个服务之间共享数据,并且支持跨服务的数据一致性。

go-cache 和 redis 缓存对比

1)功能特性:

Go Cache 是一个 Go 语言的内存缓存库,使用起来非常简单,适合处理轻量级缓存需求。它提供了基本的 Get、Set、Delete 等缓存操作接口,并支持缓存过期时间和自动清理过期缓存。但是,它只能存储在内存中,无法持久化到磁盘,不适用于大规模数据和高并发场景。

Redis 是一个基于内存的高性能键值存储系统,支持多种数据结构、高并发访问和持久化等功能。Redis 除了支持基本的 Get、Set、Delete 等操作外,还支持多种高级特性,如发布/订阅、事务、Lua 脚本等。Redis 的持久化机制包括 RDB 和 AandroidOF 两种方式,可以保证数据不会因服务器重启或宕机而丢失。Redis 还支持分布式架构,可以通过主从复制和集群等方式进行数据分片和高可用性保障。

2)性能表现:

由于 Go Cache 是一个纯内存缓存,因此在处理轻量级数据时,性能较为优秀,适合处理小规模数据和短期存储需求。

Redis 的性能则相对更为出色,尤其是在处理大规模数据和高并发访问时,Redis 的性能表现更为卓越。Redis 的数据结构支持多种类型,包括字符串、列表、哈希、集合和有序集合等,可以满足不同应用场景的需求。

3)适用场景:

Go Cache 适用于轻量级的应用场景,比如 Web 应用中的页面片段、会话信息等短期存储数据。

Redis 则适用于更加复杂的应用场景,比如高并发的 Web 应用、数据分析、实时计算、消息队列等。

综上所述,Go Cache 和 Redis 都是优秀的缓存解决方案,但是它们的功能特性、性能表现和适用场景略有不同。如果应用场景是轻量级的、短期存储的数据,可以选择 Go Cache;如果需要处理大规模的、高并发访问的数据,可以选择 Redis。

到此这篇关于golang基于内存的键值存储缓存库 go-cache的文章就介绍到这了,更多相关Golang缓存库 go-cache内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Golang基于内存的键值存储缓存库go-cache的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153639

相关文章

go中空接口的具体使用

《go中空接口的具体使用》空接口是一种特殊的接口类型,它不包含任何方法,本文主要介绍了go中空接口的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录接口-空接口1. 什么是空接口?2. 如何使用空接口?第一,第二,第三,3. 空接口几个要注意的坑坑1:坑2:坑3:接口-空接口1. 什么是空接

Python如何使用__slots__实现节省内存和性能优化

《Python如何使用__slots__实现节省内存和性能优化》你有想过,一个小小的__slots__能让你的Python类内存消耗直接减半吗,没错,今天咱们要聊的就是这个让人眼前一亮的技巧,感兴趣的... 目录背景:内存吃得满满的类__slots__:你的内存管理小助手举个大概的例子:看看效果如何?1.

golang 日志log与logrus示例详解

《golang日志log与logrus示例详解》log是Go语言标准库中一个简单的日志库,本文给大家介绍golang日志log与logrus示例详解,感兴趣的朋友一起看看吧... 目录一、Go 标准库 log 详解1. 功能特点2. 常用函数3. 示例代码4. 优势和局限二、第三方库 logrus 详解1.

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.

Redis解决缓存击穿问题的两种方法

《Redis解决缓存击穿问题的两种方法》缓存击穿问题也叫热点Key问题,就是⼀个被高并发访问并且缓存重建业务较复杂的key突然失效了,无数的请求访问会在瞬间给数据库带来巨大的冲击,本文给大家介绍了Re... 目录引言解决办法互斥锁(强一致,性能差)逻辑过期(高可用,性能优)设计逻辑过期时间引言缓存击穿:给

Java实现数据库图片上传与存储功能

《Java实现数据库图片上传与存储功能》在现代的Web开发中,上传图片并将其存储在数据库中是常见的需求之一,本文将介绍如何通过Java实现图片上传,存储到数据库的完整过程,希望对大家有所帮助... 目录1. 项目结构2. 数据库表设计3. 实现图片上传功能3.1 文件上传控制器3.2 图片上传服务4. 实现

Go语言中最便捷的http请求包resty的使用详解

《Go语言中最便捷的http请求包resty的使用详解》go语言虽然自身就有net/http包,但是说实话用起来没那么好用,resty包是go语言中一个非常受欢迎的http请求处理包,下面我们一起来学... 目录安装一、一个简单的get二、带查询参数三、设置请求头、body四、设置表单数据五、处理响应六、超

C语言中的浮点数存储详解

《C语言中的浮点数存储详解》:本文主要介绍C语言中的浮点数存储详解,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、首先明确一个概念2、接下来,讲解C语言中浮点型数存储的规则2.1、可以将上述公式分为两部分来看2.2、问:十进制小数0.5该如何存储?2.3 浮点