我有两个线程,每个线程添加/修改点燃缓存的值,它喜欢:
cache = ignite.getOrCreateCache("IniteTestCache")
valMap = cache.get(key)获取值valMap(java )中的项,处理它,然后删除它,然后更新缓存:cache.put(key, a)以使valMap项下降,
在另一个线程中:
cache = ignite.getOrCreateCache("IniteTestCache")
valMap = cache.get(key)向valMap添加新项,并将其放回缓存cache.put(key, a)以向其添加新项。
问题:
当我使用相同的键对同一个缓存进行操作时,是否应该向As添加锁:
lock()
value=cache.get(key)
modification to value
cache.put(key,value)
unlock()或者我使用原子到缓存配置使点燃自动完成这为我,或者我需要使用事务缓存,并添加锁缓存?
还是有更好的方法来避免锁定以获得高性能?
发布于 2018-04-17 03:10:51
我建议在这个用例中使用EntryProcessor:https://apacheignite.readme.io/docs/jcache#entryprocessor
https://stackoverflow.com/questions/49864562
复制相似问题