分布式缓存(memcached)的数据同步问题

haojian11 2011-12-29 11:32:19
两台服务器:一台是memcached服务器,另外一台是自己写的逻辑服务器。

逻辑服务器只做逻辑运算,memcached缓存用户数据,逻辑服务器需要数据的时候就从memcached上面获取,并暂时缓存到本地,修改完用户数据后,再保存到memcached服务器,并清空本地的该数据。

这样会有一个问题,逻辑服务器的多个线程同时修改memcached上的一个用户数据的时候,会存在并发问题,可能导致memcached上面的数据被覆盖。

我的想法是在逻辑服务器这边给用户数据加一个锁,要修改某个用户数据的时候,先获取该用户的锁,然后再取memcached上面取到数据,然后修改数据,然后保存到memcached,然后释放锁。

感觉这种方式效率可能会比较低,不知道有没有更好的实现方式,请各位高手指点!
...全文
168 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
xietingyan 2011-12-29
  • 打赏
  • 举报
回复
缓存不经常修改的数据吧,如果不经常修改加锁也不会是什么问题吧

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧