简单好用的缓存库 gcache
GoCN
共 3288字,需浏览 7分钟
· 2022-06-27
1.前言
开发时,如果你需要对数据进行临时缓存,按照一定的淘汰策略,那么gcache你一定不要错过。gcache golang的缓存库。它支持可扩展的Cache,可以选择 LFU,LRU、ARC等淘汰算法。
2.特性
gcache 有很多特性:
支持过期淘汰算法Cache,比如 LFU, LRU和ARC Goroutine安全 支持事件处理程序,淘汰、清除、添加 (可选) 自动加载缓存,如果它不存在 (可选) … ….
更多功能特性请查看:gcache (文末链接点击可直接跳转哦~)
3.快速安装
直接get即可使用。
$ go get -u https://github.com/bluele/gcache
4.简单举例
package main
import (
"github.com/bluele/gcache"
"fmt"
)
func main() {
gc := gcache.New(20).
LRU().
Build()
gc.Set("key", "ok")
value, err := gc.Get("key")
if err != nil {
panic(err)
}
fmt.Println("Get:", value)
}
执行,控制台输出如下:
Get: ok
5.设置淘汰时间举例
package main
import (
"github.com/bluele/gcache"
"fmt"
"time"
)
func main() {
gc := gcache.New(20).
LRU().
Build()
gc.SetWithExpire("key", "ok", time.Second*10)
value, _ := gc.Get("key")
fmt.Println("Get:", value)
// Wait for value to expire
time.Sleep(time.Second*10)
value, err := gc.Get("key")
if err != nil {
panic(err)
}
fmt.Println("Get:", value)
}
执行,控制台输出如下:
Get: ok
panic: Key not found.
goroutine 1 [running]:
main.main()
/Users/laocheng/work/code/market-data-backend/utils/t/2.go:22 +0x21b
exit status 2
6.其他算法举例
6.1 最不经常使用(LFU)
func main() {
// size: 10
gc := gcache.New(10).
LFU().
Build()
gc.Set("key", "value")
}
6.2 最近使用最少的(LRU)
func main() {
// size: 10
gc := gcache.New(10).
LRU().
Build()
gc.Set("key", "value")
}
6.3 自适应替换缓存(ARC) 在LRU和LFU之间不断平衡,以提高综合结果。
func main() {
// size: 10
gc := gcache.New(10).
ARC().
Build()
gc.Set("key", "value")
}
7.添加hanlder使用
func main() {
gc := gcache.New(2).
AddedFunc(func(key, value interface{}) {
fmt.Println("added key:", key)
}).
Build()
for i := 0; i < 3; i++ {
gc.Set(i, i*i)
}
}
执行,控制台输出如下:
added key: 0
added key: 1
added key: 2
可以在set时候做一些额外的处理。
8.总结
gcache 是一个非常简单,又好用的缓存库,它支持LFU,LRU、ARC等淘汰算法。如果你在开发时候有这方面的需求,不妨试试看,相信一定会喜欢上的!
参考资料:
gcache
往期推荐
想要了解Go更多内容,欢迎扫描下方👇 关注 公众号,回复关键词 [实战群] ,就有机会进群和我们进行交流
分享、在看与点赞,至少我要拥有一个叭~
评论
GCache基于 Golang 的缓存库
为Golang打造的缓存库。它支持可预期的Cache,LFU,LRU和ARC。功能支持可预见的Cache,LFU,LRU和ARC。Goroutine安全支持驱逐,清除和添加条目的事件处理程序。(可选)
GCache基于 Golang 的缓存库
0
requests-cacheRequests 的缓存库
requests-cache 是为 Python 的 Requests 库提供了持久化缓存支持的 P
requests-cacheRequests 的缓存库
0
requests-cacheRequests 的缓存库
requests-cache是为Python的Requests库提供了持久化缓存支持的Python模块。示例代码:import requestsimport requests_cacherequest
requests-cacheRequests 的缓存库
0
Ecache简单的缓存系统
ecache简单的缓存系统纯属学习介绍ECache->easycache简单粗暴的命名之前自己在做一个项目,服务器需要接入缓存。由于是云主机(屌丝你懂的),那点内存根本不够再安装个memcach
Ecache简单的缓存系统
0
WeavingDBC# 实现的缓存库
WeavingDBWeavingDB为满足C#项目的特殊使用与简单部署,而开发此WeavingDB。1.支持K-V方式。支持通配符方式匹配KEYS2.支持JSON数据的条件查询的内存缓存库。(目前JS
WeavingDBC# 实现的缓存库
0
FreeCacheGo 语言的缓存库
FreeCache是一个Go语言的缓存库,无额外的GC负荷。数百万对象的垃圾收集延迟仅在数百毫秒。特性:可存储数以百万计条目零垃圾收集负荷高并发而且线程安全的访问纯Go语言实现支持对象失效近乎LRU的
FreeCacheGo 语言的缓存库
0