首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我应该添加锁来点燃缓存,因为它将在不同的线程中进行读写吗?

我应该添加锁来点燃缓存,因为它将在不同的线程中进行读写吗?
EN

Stack Overflow用户
提问于 2018-04-16 19:06:58
回答 1查看 488关注 0票数 0

我有两个线程,每个线程添加/修改点燃缓存的值,它喜欢:

代码语言:javascript
复制
cache = ignite.getOrCreateCache("IniteTestCache")
valMap = cache.get(key)

获取值valMap(java )中的项,处理它,然后删除它,然后更新缓存:cache.put(key, a)以使valMap项下降,

在另一个线程中:

代码语言:javascript
复制
cache = ignite.getOrCreateCache("IniteTestCache")
valMap = cache.get(key)

valMap添加新项,并将其放回缓存cache.put(key, a)以向其添加新项。

问题:

当我使用相同的键对同一个缓存进行操作时,是否应该向As添加锁:

代码语言:javascript
复制
lock()
value=cache.get(key)
modification to value
cache.put(key,value)
unlock()

或者我使用原子到缓存配置使点燃自动完成这为我,或者我需要使用事务缓存,并添加锁缓存?

还是有更好的方法来避免锁定以获得高性能?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-17 03:10:51

我建议在这个用例中使用EntryProcessorhttps://apacheignite.readme.io/docs/jcache#entryprocessor

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49864562

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档