分布式缓存(memcached)的数据同步问题
两台服务器:一台是memcached服务器,另外一台是自己写的逻辑服务器。
逻辑服务器只做逻辑运算,memcached缓存用户数据,逻辑服务器需要数据的时候就从memcached上面获取,并暂时缓存到本地,修改完用户数据后,再保存到memcached服务器,并清空本地的该数据。
这样会有一个问题,逻辑服务器的多个线程同时修改memcached上的一个用户数据的时候,会存在并发问题,可能导致memcached上面的数据被覆盖。
我的想法是在逻辑服务器这边给用户数据加一个锁,要修改某个用户数据的时候,先获取该用户的锁,然后再取memcached上面取到数据,然后修改数据,然后保存到memcached,然后释放锁。
感觉这种方式效率可能会比较低,不知道有没有更好的实现方式,请各位高手指点!