当前位置: 首页 > news >正文

黑龙江省建设安全协会网站建站系统推荐

黑龙江省建设安全协会网站,建站系统推荐,vultr 做网站空间,建设网站需要做哪些工作内容1、事务概要 Redis事务是一个单独的隔离操作: 事务中的所有命令都会序列化、按顺序地执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。 Redis事务的主要作用 串联多个命令,防止别的命令插队。 事务的3个命令 MultiExe…

1、事务概要

Redis事务是一个单独的隔离操作:

  • 事务中的所有命令都会序列化、按顺序地执行。
  • 事务在执行的过程中,不会被其他客户端发送来的命令请求所打断。

Redis事务的主要作用

        串联多个命令,防止别的命令插队。

事务的3个命令

  1. Multi
  2. Exec
  3. discard

从输入Multi命令开始,输入的命令都会一次进入命令队列中,但不会执行,直到输入Exec后,Redis会将之前的命令队列中的命令依次执行(组队过程)。

组队的过程中,可以通过discard命令来放弃组队。

其实,这里类似于"二阶事务(2PC)",但是本质是不同的!:

  • 输入Multi命令进入队列排队 类似于2PC中的事务准备阶段
  • 输入Exec命令 类似于2PC中的事务提交阶段
  • discard命令类似于事务的回滚阶段

如图:

 案例1

        开启事务到执行队列:

案例2

        开启事务到放弃组队 

以上是事务正常执行的案例,下面演示出问题的案例:

1>当在组队过程中的命令出现错误,直接执行队列,那么执行阶段会提示"transaction discard" 

理解为:“队伍中,一人坑,全队输”

如下:

 2>当组队过程中的命令正常,执行队列时,其中的命令存在异常。

结果:哪个命令存在错误,哪个命令就不会执行,并提示错误信息

 

总结

        Redis事务其实就是把一个客户端的多个命令串联起来,防止其他客户端插队。并分为命令排队阶段和执行队列阶段,提供队列中的回滚操作(discard),当排队过程中,出现错误,那么队列不会执行;当组队成功后,执行队列时,某个命令出现错误,那么该命令会执行失败,并提示错误信息,其他正常的命令正常执行。 

2、事务冲突

这里用下面案例来描述:

一个淘宝账号被3个人同时登录,且同一时间购买不同的商品,账号只有1w的余额:

甲:购买8000元的商品

乙:购买5000元的商品

丙:购买1000元的商品

假设购买时,redis是按甲、乙、丙的顺序依次执行"减少余额"的命令,最终,余额出现负数

解决方案有2种:

悲观锁

        悲观锁(Pessimistic Lock):顾名思义,就是很悲观,每次去拿数据的时候都认为别人会修改,所有每次在拿数据的时候都会上锁,这样别人想拿这个数据就会block,直到它拿到锁。

        传统的关系型数据库里边就会用到很多这种锁机制,比如行锁、表锁等,读锁、写锁等,都是在做操作之前先上锁。

 如下:

步骤详解:

  1. 甲获取到锁,在甲没有释放锁之前,别人没办法去操作余额
  2. 当甲购买完释放锁(余额-8000=2000)
  3. 锁被释放后,乙才能获取锁
  4. 这时乙去购买商品,判断此时"2000-5000"为负数,固不执行购买操作,余额不变
  5. 乙释放锁。

乐观锁

        乐观锁(Optimistic Lock)顾名思义,就是很乐观,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下再此期间别人有没有去更新这个数据,可以使用版本号等机制实现。

        乐观锁适用于多读的应用类型,这样可以提高吞吐量。Redis就是利用这种check-and-set机制实现事务的。 

​​​​​​​

步骤详解:

  1. 甲乙丙在购买商品时,给数据(余额)添加一个版本号v1.0
  2. 甲乙先进行购买,都获取到了余额(1w)及版本号
  3. 对数据进行更新前,会判断当前版本号是否与拿到的版本号相同,相同则对数据进行操作,不同则终止命令。会更新这个版本号
  4. 假设此时甲获取到余额版本为v1.0,与数据的版本号相同,则购买商品,余额减去8000,并把余额版本号更新为v1.1
  5. 乙比甲稍微慢点,拿到的版本号也是v1.0,但是在处理数据时,发现当前的版本号为v1.1,与拿到的版本不一致,固终止命令
  6. 丙后面获取到余额版本号为v1.1,处理数据时,与当前版本号v1.1一致,再余额-1000,更新版本号为v1.2

3、watch命令

语法:

        watch  key1  key2  key3 ...

在执行multi之前,先执行watch  key1  ...,可以监视一个(或多个)key,如果在事务执行之前这个(或这些)key被其他命令所改动,那么事务将被打断,返回nil(空)

案例:

http://www.hrbkazy.com/news/23351.html

相关文章:

  • 织梦资源网模板seo 优化是什么
  • 哪些网站可以用来做百科参考百度网页
  • 网页设计站点网站搜索引擎优化
  • 创建一个网站需要做哪些工作浙江疫情最新消息
  • 做百度竞价网站修改影响排名吗电商运营数据六大指标
  • 做响应式网站多少钱合肥搜索引擎推广
  • 网络科技网站竞价托管怎么做
  • 成品网站w灬 源码1688网页什么是网络营销策略
  • 网站被重定向跳转学历提升
  • 在线网站制作淘大象关键词排名查询
  • 利用网站做蜘蛛池关键词排名优化技巧
  • 松原建设小学网站宁波网站建设团队
  • 网站生成app 免费工具最佳bt磁力狗
  • 网站如何做ssl认证凡科建站登录官网
  • 网站怎么设置二级域名市场调研报告范文模板word
  • 怎么做网站注册推广百度一下浏览器
  • 小程序模板图片网站性能优化
  • 企业网站怎么建企业网站的在线推广方法有
  • express做静态网站新东方在线koolearn
  • 最火爆的国际贸易网站西安今日头条新闻
  • 网站流量和带宽网络营销所学课程
  • 网站做跳转的要求今日国内重大新闻
  • 攀枝花网站建设兼职网页开发工具
  • 做图哪个网站素材多石家庄网站建设seo
  • 南昌做兼职的网站设计精准营销的概念
  • 优化推广seo广东seo价格是多少钱
  • 云开发壁纸小程序关键词优化包年推广
  • 昆山建设工程安监站网站搜索引擎推广渠道
  • 网站ftp根目录b站推广网站2024下载
  • 中国建设银行网站首页怎么销户免费crm网站不用下载的软件