2017-03-05 回答
应用redis实现数据的读写,同时利用队列处理器定时将数据写入mysql,此种情况存在的问题主要是如何保证mysql与redis的数据同步,二者数据同步的关键在于mysql数据库中主键,方案是在redis启动时去mysql读取所有表键值存入redis中,往redis写数据时,对redis主键自增并进行读取,若mysql更新失败,则需要及时清除缓存及同步redis主键。
string tbname = "login";
//获取mysql表主键值--redis启动时
long id = mysql.getid(tbname);
//设置redis主键值--redis启动时
redisservice.set(tbname, string.valueof(id));
system.out.println(id);
long l = redisservice.incr(tbname);
system.out.println(l);
login login = new login();
login.setid(l);
login.setname("redis");
redisservice.hmset(string.valueof(login.getid()), login);
boolean b = mysql.insert("insert into login(id,name) values(" + login.getid() + ",'" + login.getname() + "')");
/**
*
* 队列处理器更新mysql失败:
*
* 清除缓存数据,同时主键值自减
*/
if (!b){
redisservice.delkeyanddecr(tbname, "login:"+string.valueof(login.getid()));
}
system.out.println(redisservice.exists("login:"+string.valueof(login.getid())));
system.out.println(redisservice.get(tbname));