网站模板库
  • 首页
  • web前端工具
    • HTML/JS转换工具
    • JS/HTML格式化工具
    • 字母/英文大小写转换工具
    • robots.txt文件生成工具
    • Js压缩/格式化工具
    • Css在线压缩工具_代码格式化
  • 关于我们
    • 免责声明
    • 联系我们
    • 广告服务
    • 服务项目
    • 关于我们
    • 网站轮播
    • 公告
    • 成都优优科技专用
    • 按行业分类
  • web学院
    • 服务器教程
    • 学习资料
      • 基础书籍
      • 交互书籍
      • 入门教程
      • 特效分类
    • 案例分享
    • web资讯
  • 网页特效
    • 图片特效
    • 导航特效
    • 滑动按钮
    • 表单特效
    • 文字特效
    • 弹窗特效
    • 其他特效
  • 织梦模板
    • 科技/电子/数码/通信
    • 文化/艺术/广告/传媒
    • 装修/设计/家居/家具
    • 基建/施工/地产/物业
    • 餐饮/酒店/旅游/票务
    • 食品/果蔬/饮料/日用
    • 服饰/珠宝/礼品/玩具
    • 摄影/婚庆/家政/生活
    • 运动/健身/体育/器材
    • 学校/教育/培训/科研
    • 美容/保健/医院/医疗
    • 金融/财税/咨询/法律
    • 政府/组织/集团/协会
    • 汽车/物流/交通/搬运
    • 机械/设备/制造/仪器
    • 化工/环保/能源/材料
    • 农业/畜牧/养殖/宠物
    • 其他模版
    • IT/软件/信息/互联网
  • 手机模板
    • 手机APP模板
    • 微信小程序模板
    • wap
  • 网站模板
    • joomla模板
    • Drupal模板
    • z-blog模板
    • EyouCms模板
    • Bootstrap模板
    • 帝国cms模板
    • CmsEasy模板
    • MetInfo模板
    • 购物商城模板
      • Shopify主题
      • PrestaShop主题
    • 后台模板
    • 纯HTML模板
    • ecshop模板
    • phpwind模板
    • pbootcms模板
    • phpcms模板
    • wordpress模板
    • discuz模板
  • 教程
    • 织梦教程
    • Discuz教程
    • WordPress教程
    • Phpcms教程
    • Phpwind教程
    • ECShop教程
    • Joomla教程
    • Drupal教程
    • zblog教程
    • EyouCMS教程
    • 帝国cms教程
    • MetInfo教程
    • CmsEasy教程
登录
当前位置:网站模板库 > web学院 > 案例分享 > SpringBoot 架构下如何保证对 redis 的操作是在事务提交之后?
admin 案例分享 2023-06-24 16:01:53

SpringBoot 架构下如何保证对 redis 的操作是在事务提交之后?

SpringBoot 架构下如何保证对 redis 的操作是在事务提交之后?,第1张

SpringBoot 架构下如何保证对 redis 的操作是在事务提交之后?,第2张

前提: 1.目前我们的项目内是配置了全局事务,通过方法的命名前缀来控制,如 insert/update 开头的都是 required 方式传播这样。

2.对 Redis 的操作是将 jedis 封装了一层 Util 工具类。

3.目前的写法都是把 redis 操作放在方法的最后执行来尽量规避报错导致事务回滚,缓存插入脏数据。

伪代码:

public void foo() {
	
    this.doSomething();
    
    redisUtil.set(key, val);
    
    throw new RuntimeException();
}

PS: 今天试着把 redis 的操作放在监听器里,但是发现对 list 类型的操作无法生效,求解大家的处理方案。

补充几点:
1. 我们项目内对事务的控制是类似这个文章里的 [三、使用 AOP 全局处理事务] ,正文里描述的全局事务控制可能理解有偏差。https://www.cnblogs.com/wjqhuaxia/p/12148865.html

2. 其实整体的项目是 SpringCloudAlibaba 那一套,所以下一阶段会引入 seata 做分布式事务控制,不知道到时候对 redis 的操作要如何优化?

3. 直接用 jedis 属于偷懒了,之前项目有封装好的 redisUtil 就搬运过来了。 ----------------------- 以下是精选回复-----------------------

答:TransactionSynchronizationManager 可以.
答:你百度一下的话肯定会有的.
答:我个人建议好好去读一下 Java EE 官方教程的有关 Transaction,Open XA 等文档,再回过头来看看 Spring 文档中的 Transaction 那一篇。

从 V 的站一些帖子看,很多人用了很多年的 Spring, 根本就不理解 Spring 中的事务。默认情况下,Spring 的事务只启用 Local Transaction 。如果要同时管理 Redis 和数据库,必须启用 JTA ( Global transaction ),目前我记得 Spring 中的 Redis,Mongo(启用 Cluster 时) 仅支持 JTA (部分标准,Spring 中仅仅将它们支持事务是作了一种转换和映射,底层和 Java EE 世界的 Transaction 不能同等),关系型数据库可以用 JTA 和 Local Transaction 。在使用 Local transaction 时,Spring 做很多扩展。但是使用 JTA,一般依赖第三方 JTA Manager (比如 atomikos, bitronix, JBoss narayana ),Spring transaction Manager 都是 Delegate 到相应的 JTA Manager 上去。
答:那么问题来了,你说的全局事务是指 Global transaction 吗?你配置那个 JTA 方案?
答:不客气, 建议你们用 spring data redis 哈, 直接用 jedis 有点危险.
答:跨多个资源建立一个事务的,需要你做补偿。例如买了机票,酒店订不上,只能退机票。你要写代码来做反向的补偿操作,达到最终的一致性。XA 这种东西只是个理论,很多场景下建立不了这样的应用。
答:你们不用事务管理器的么?
答:redis 事务?闻所未闻
分布式事务一般有三种方式:消息、tcc 、XA,实用性依次递减
答:经典双写一致性。
这是参考方案之一。
1.写请求只删除缓存,不更新缓存。写请求先删除缓存,再更新数据。无论成功与否,写请求只会导致缓存失效,永不导致脏数据。

2.读请求更新缓存。读写请求高并发时,有可能导致写请求删除缓存,读请求紧接着更新了旧数据缓存,写请求再完成了数据更新,产生双写不一致。

3.读写串行化,适用于读多写少的场景。缓存有效时,读请求按一般流程处理。写请求发生时,缓存失效,同一 id 的并发的写请求和读请求进入同一队列(或同一加锁处理逻辑),保证双写一致性。串行化时,可能会导致大量并发的读请求超时,所以要在数据实时性(准确)还是系统可用性做下取舍。

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » SpringBoot 架构下如何保证对 redis 的操作是在事务提交之后?

admin 钻石

分享到:
上一篇
作为公司 Java 开发岗,交接服务器,有什么要叮嘱的么..
下一篇
问个奇葩的问题,越南的服务器怎么样?带宽如何?

相关推荐

The Humble Book Bundle: Java by O'Reilly

The Humble Book Bundle: Java by O'Reilly

卡住了,问大家一个Python的算法问题吧

卡住了,问大家一个Python的算法问题吧

根据电影某一帧,匹配到某个电影。

根据电影某一帧,匹配到某个电影。

win7&64下setuptools安装失败怎么解决

win7&64下setuptools安装失败怎么解决

0条评论

发表评论 取消回复

要发表评论,您必须先登录。

提供最优质的资源集合

立即查看 了解详情
网站模板库

主题/付费下载/查看/余额管理/自定义积分,集成支付,卡密,推广奖励等。

本站导航
  • 链接标题
友情链接
  • 链接标题
快速搜索
本站由钛宇宙强力驱动
友情链接:
    商业源码网蜀ICP备2023005044号
    网站模板库
    • 登录
    • 注册
    网站模板库
    • 首页
    • web前端工具►
      • HTML/JS转换工具
      • JS/HTML格式化工具
      • 字母/英文大小写转换工具
      • robots.txt文件生成工具
      • Js压缩/格式化工具
      • Css在线压缩工具_代码格式化
    • 关于我们►
      • 免责声明
      • 联系我们
      • 广告服务
      • 服务项目
      • 关于我们
      • 网站轮播
      • 公告
      • 成都优优科技专用
      • 按行业分类
    • web学院►
      • 服务器教程
      • 学习资料►
        • 基础书籍
        • 交互书籍
        • 入门教程
        • 特效分类
      • 案例分享
      • web资讯
    • 网页特效►
      • 图片特效
      • 导航特效
      • 滑动按钮
      • 表单特效
      • 文字特效
      • 弹窗特效
      • 其他特效
    • 织梦模板►
      • 科技/电子/数码/通信
      • 文化/艺术/广告/传媒
      • 装修/设计/家居/家具
      • 基建/施工/地产/物业
      • 餐饮/酒店/旅游/票务
      • 食品/果蔬/饮料/日用
      • 服饰/珠宝/礼品/玩具
      • 摄影/婚庆/家政/生活
      • 运动/健身/体育/器材
      • 学校/教育/培训/科研
      • 美容/保健/医院/医疗
      • 金融/财税/咨询/法律
      • 政府/组织/集团/协会
      • 汽车/物流/交通/搬运
      • 机械/设备/制造/仪器
      • 化工/环保/能源/材料
      • 农业/畜牧/养殖/宠物
      • 其他模版
      • IT/软件/信息/互联网
    • 手机模板►
      • 手机APP模板
      • 微信小程序模板
      • wap
    • 网站模板►
      • joomla模板
      • Drupal模板
      • z-blog模板
      • EyouCms模板
      • Bootstrap模板
      • 帝国cms模板
      • CmsEasy模板
      • MetInfo模板
      • 购物商城模板►
        • Shopify主题
        • PrestaShop主题
      • 后台模板
      • 纯HTML模板
      • ecshop模板
      • phpwind模板
      • pbootcms模板
      • phpcms模板
      • wordpress模板
      • discuz模板
    • 教程►
      • 织梦教程
      • Discuz教程
      • WordPress教程
      • Phpcms教程
      • Phpwind教程
      • ECShop教程
      • Joomla教程
      • Drupal教程
      • zblog教程
      • EyouCMS教程
      • 帝国cms教程
      • MetInfo教程
      • CmsEasy教程

      弹窗标题

      这是一条网站公告,可在后台开启或关闭,可自定义背景颜色,标题,内容,用户首次打开关闭后不再重复弹出,此处可使用html标签...