复述,中数据一致性的方案

  

背景:
现在复述,在互联中有大量的使用,根据业务的不同,其使用上也有所不同,但一般都有数据存储和缓存的一致性问题,下面就给大家介绍几个比较成熟实用的方案,希望对大家有帮助,如果大家有好的方案和建议欢迎给我留言

  

<强>方式1:
数据库保存数据,复述,不存在复述,启动后,从数据库加载数据不要求强一致实时性的读请求,都由复述,处理要求强一致实时性的读请求,由数据库处理写请求有2种处理方式,由数据库处理

  

应用先写道数据库,然后更新复述,
应用先写道数据库,然后其它守护进程同步到复述,优点:复述,启动不用处理复述,数据和数据库不一致缺点:复述,启动给数据库很大的读压力

  

<强>方式2:
数据库和复述,分别处理不同的数据类型数据库处理要求强一致实时性的数据,例如金融数据,交易数据复述,处理不要求强一致实时性的数据,例如网站最热贴排行榜

  

复述和MySQL数据的同步,代码级别大致可以这样做:读:读复述→没有,读MySQL→把MySQL数据写回复述,写:写MySQL→成功,写复述,

  

并发不高的情况:读:读复述→没有,读mysql→把mysql数据写回复述,有的话直接从复述中取;写:写mysql→成功,再写复述;

  

并发高的情况:读:读复述→没有,读mysql→把mysql数据写回复述,有的话直接从复述中取;写:异步话,先写入复述的缓存,就直接返回;定期或特定动作将数据保存到mysql,可以做到多次更新,一次保存;

  

——备注:如果写复述,要使用复述的事务:
127.0.0.1:6379>看id

127.0.0.1:6379>多

127.0.0.1:6379>增加id

127.0.0.1:6379>排队;执行
1)(整数)342183
127.0.0.1:6379>

  

<强>方式3:
使用lua脚本:复述,在使用lua使用同时只允许一个脚本执行,符合事务的原子性,但一个lua脚本不能执行时间过大,不然会阻塞

  

EVAL
EVAL命令对Lua脚本进行执行求值。

  

语法:EVAL脚本numkeys关键(重要…)参数[arg…]

  

脚本lua脚本内容注意的是脚本不应该是lua函数。
numkeys表示指定键名参数的个数。
键[键…)表示脚本对应的关键值列表在脚本中可以使用键键[1][2][3]键键[n] n从1开始。
参数(参数…)命名行中传递的参数列表在脚本中可以使用ARGV [1] ARGV [2] ARGV [3] ARGV [n] n从1开始。

  

一个示例胜过千言万语的解释

  

eval“返回{键[1],[2]键,ARGV [1], ARGV [2]}“;2 id名称3 mytest
执行上面脚本返回

  

1)“id"
2)“name"

  

3)“2“

  

4)“mytest"

复述,中数据一致性的方案