1
scys 2020-03-05 17:33:14 +08:00 1
自己写,两个需求都简单。map 加个锁就行
|
2
Vegetable 2020-03-05 17:33:55 +08:00 1
sync.Map
|
3
Vegetable 2020-03-05 17:35:19 +08:00
|
4
guonaihong 2020-03-05 17:48:30 +08:00 2
|
5
blackcurrant OP 当达到最大数量或内存时,要能自动删除近期最少使用(LRU)的值。
有现成的库吗?自己写好像有点麻烦。 |
6
ysmood 2020-03-05 17:54:53 +08:00 1
不知道这个能否满足你的要求 https://github.com/ysmood/umi
|
7
sunny352787 2020-03-05 17:55:03 +08:00 1
手撸一个 redis ?
|
8
scys 2020-03-05 18:15:46 +08:00
@guonaihong 收了,感谢先,近来可能用上
|
9
scys 2020-03-05 18:16:36 +08:00
@blackcurrant 做个计算器,然后用 sync.Map ,没入一个对象,重新计算下内存大小。
感觉都是简单的事情,就是包装个 Add/Dell 方法 |
10
fordoo 2020-03-05 18:22:51 +08:00 1
|
11
Muninn 2020-03-05 18:26:55 +08:00 1
小打小闹用 sync.Map
想分布式就麻烦了 自己根据需求挑吧 https://libs.garden/go/search?q=cache&sort=popular |
12
zjj19950716 2020-03-05 20:07:58 +08:00 via iPhone 1
groupcache
|
13
littlewing 2020-03-05 20:27:01 +08:00 1
不考虑用 redis 的原因是啥?
|
14
23571113 2020-03-06 00:28:00 +08:00 via Android
LRUCache 很简单,可以做到查找更新都是 log(N)复杂度。
|
15
23571113 2020-03-06 00:32:40 +08:00 via Android
但是 go 这种"modern"语言居然不支持泛型,所以 cache 也用起来难受。
|
16
imnaive 2020-03-06 10:07:20 +08:00
建议用读写锁操作含类型的 map,用 sync.map 会丢失类型,每次都要检查类型很麻烦
|
17
zichen 2020-03-06 15:38:51 +08:00
本地的话 map 加锁或者 sync.map ,分布式用 redis,有原子操作需求上 lua 脚本。
|