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

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

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

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

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

感觉这种方式效率可能会比较低,不知道有没有更好的实现方式,请各位高手指点!
...全文
648 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
haojian11 2012-01-17
  • 打赏
  • 举报
回复
目前有不同类型的线程可能修改同一个数据
haojian11 2012-01-17
  • 打赏
  • 举报
回复
我希望解决的是数据同步的问题啊
haojian11 2011-12-29
  • 打赏
  • 举报
回复
补充:逻辑服务器是用java实现的。
gufeiy1 2011-12-29
  • 打赏
  • 举报
回复
将用户数据按用户名进行hash%线程数,每个线程处理相应的用户数据

20,811

社区成员

发帖
与我相关
我的任务
社区描述
Hadoop生态大数据交流社区,致力于有Hadoop,hive,Spark,Hbase,Flink,ClickHouse,Kafka,数据仓库,大数据集群运维技术分享和交流等。致力于收集优质的博客
社区管理员
  • 分布式计算/Hadoop社区
  • 涤生大数据
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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