失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > redis如何保证数据一致性

redis如何保证数据一致性

时间:2022-09-04 22:52:10

相关推荐

redis如何保证数据一致性

数据库|Redis

redis

数据库-Redis

现在redis在互联中有大量的使用,根据业务的不同,其使用上也有所不同,但一般都有数据存储和缓存的一致性问题,下面就给大家介绍几个比较成熟实用的方案。

户外 源码,如何调vscode字体,ubuntu怎么登录,tomcat的bin目录,sqlite array,软件技术专业网页设计,php连接数据库配置文件,安徽服务器地址,emlog捐赠插件,前端不会框架能找到实习工作吗,母婴爬虫,php 临时文件,seo参数,springboot前端访问,帝国cms万能标签分页,网站快车 cms,中文简易网页模板下载,android app 模板,zen cart 后台,html导航页面模板,旅游管理系统 sql,网立方程序lzw

iotop源码,ubuntu怎么双屏显示,爬虫间隔多少合适,php exec(),seo艺术当当lzw

方式1:

云打包app源码下载,ubuntu镜像快速启动,tomcat怎么连接静态网页,脚爬虫图片,卡密充值余额PHP,武义SEOlzw

数据库保存数据,redis不persist redis启动后,从数据库加载数据 不要求强一致实时性的读请求,都由redis处理 要求强一致实时性的读请求,由数据库处理 写请求有2种处理方式,由数据库处理(推荐学习:Redis视频教学)

应用先写道数据库,然后更新redis

应用先写道数据库,然后其它daemon同步到redis

优点:redis启动不用处理redis数据和数据库不一致

缺点:redis启动给数据库很大的读压力

方式2:

数据库和redis分别处理不同的数据类型,数据库处理要求强一致实时性的数据,例如金融数据、交易数据;Redis处理不要求强一致实时性的数据,例如网站最热贴排行榜

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

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

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

–备注:如果写redis要使用redis的事务:

127.0.0.1:6379> WATCH idOK127.0.0.1:6379> MULTIOK127.0.0.1:6379> INCR idQUEUED127.0.0.1:6379> EXEC1) (integer) 342183127.0.0.1:6379>

方式3:

使用lua脚本:redis在使用lua使用同时只允许一个脚本执行,符合事务的原子性,但一个lua脚本不能执行时间过大,不然会阻塞

EVAL

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

语法:

EVAL script numkeys key [key …] arg [arg …]

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

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

eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 id name 3 mytest

执行上面脚本返回

1) "id"2) "name"3) "2"4) "mytest"

更多Redis相关技术文章,请访问Redis入门教学栏目进行学习!

如果觉得《redis如何保证数据一致性》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。