golang 中有什么好用的 cache 方案?

2020 年 3 月 5 日
 blackcurrant
本来准备直接用 map 做 cache,但 map 不支持 concurrent,并且我还希望能满足下面两点:
- 支持设置 cache 的最大数量
- 支持设置 cache 的最大内存使用量

有什么推荐吗?
6122 次点击
所在节点    Go 编程语言
17 条回复
scys
2020 年 3 月 5 日
自己写,两个需求都简单。map 加个锁就行
Vegetable
2020 年 3 月 5 日
sync.Map
Vegetable
2020 年 3 月 5 日
guonaihong
2020 年 3 月 5 日
https://github.com/allegro/bigcache
应该可以满足你。
blackcurrant
2020 年 3 月 5 日
当达到最大数量或内存时,要能自动删除近期最少使用(LRU)的值。
有现成的库吗?自己写好像有点麻烦。
ysmood
2020 年 3 月 5 日
不知道这个能否满足你的要求 https://github.com/ysmood/umi
sunny352787
2020 年 3 月 5 日
手撸一个 redis ?
scys
2020 年 3 月 5 日
@guonaihong 收了,感谢先,近来可能用上
scys
2020 年 3 月 5 日
@blackcurrant 做个计算器,然后用 sync.Map ,没入一个对象,重新计算下内存大小。
感觉都是简单的事情,就是包装个 Add/Dell 方法
fordoo
2020 年 3 月 5 日
Muninn
2020 年 3 月 5 日
小打小闹用 sync.Map

想分布式就麻烦了 自己根据需求挑吧
https://libs.garden/go/search?q=cache&sort=popular
zjj19950716
2020 年 3 月 5 日
groupcache
littlewing
2020 年 3 月 5 日
不考虑用 redis 的原因是啥?
23571113
2020 年 3 月 6 日
LRUCache 很简单,可以做到查找更新都是 log(N)复杂度。
23571113
2020 年 3 月 6 日
但是 go 这种"modern"语言居然不支持泛型,所以 cache 也用起来难受。
imnaive
2020 年 3 月 6 日
建议用读写锁操作含类型的 map,用 sync.map 会丢失类型,每次都要检查类型很麻烦
zichen
2020 年 3 月 6 日
本地的话 map 加锁或者 sync.map ,分布式用 redis,有原子操作需求上 lua 脚本。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://study.congcong.us/t/650147

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX