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

2020-03-05 17:29:27 +08:00
 blackcurrant
本来准备直接用 map 做 cache,但 map 不支持 concurrent,并且我还希望能满足下面两点:
- 支持设置 cache 的最大数量
- 支持设置 cache 的最大内存使用量

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

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

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

https://www.v2ex.com/t/650147

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

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

© 2021 V2EX