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

沈阳商城网站建设百度推广找谁做靠谱

沈阳商城网站建设,百度推广找谁做靠谱,移动网站怎么做,购物网站建设目标一、场景概述 想象一个用户注册流程: 保存用户基本信息(核心操作)初始化用户账户(重要但可独立失败)发送欢迎邮件(非关键操作) 二、代码事务传播分析 1. 主事务:用户注册&#xf…

一、场景概述

想象一个用户注册流程:

  1. 保存用户基本信息(核心操作)
  2. 初始化用户账户(重要但可独立失败)
  3. 发送欢迎邮件(非关键操作)

二、代码事务传播分析

1. 主事务:用户注册(REQUIRED)

 

@Transactional(propagation = Propagation.REQUIRED)
public void register(User user) {// 保存用户(主事务操作)userDao.save(user);// 初始化账户(嵌套事务)accountService.initAccount(user.getId());// 发送邮件(非事务操作)emailService.sendWelcomeEmail(user.getEmail());
}

2. 子事务:账户初始化(NESTED)

@Transactional(propagation = Propagation.NESTED)
public void initAccount(Long userId) {// 初始化账户操作
}

三、事务传播机制详解

1. REQUIRED(主事务)

  • 行为:有则加入,无则新建
  • 当前场景:当register()被调用时
    • 没有现有事务 → 创建新事务(事务A)
    • 所有操作都在事务A中执行

2. NESTED(嵌套事务)

  • 行为:在现有事务中创建"嵌套事务"
  • 关键特性
    • 设置数据库保存点(savepoint)
    • 可独立回滚不影响主事务
    • 主事务回滚会连带回滚嵌套事务

四、场景执行分析

场景1:完美流程(全部成功)

  1. 保存用户 → 成功
  2. 初始化账户 → 成功
  3. 发送邮件 → 成功
  4. 提交主事务 → 所有操作生效

结果:用户创建成功,账户初始化完成,邮件已发送

场景2:账户初始化失败

  1. 保存用户 → 成功
  2. 初始化账户 → 失败(抛出异常)
  3. 捕获异常 → 记录日志
  4. 发送邮件 → 成功
  5. 提交主事务 → 仅保存用户操作生效

结果

  • ✅ 用户创建成功
  • ❌ 账户初始化失败(但被捕获)
  • ✅ 邮件已发送

场景3:主事务失败

  1. 保存用户 → 成功
  2. 初始化账户 → 成功
  3. 发送邮件前系统崩溃 → 主事务回滚

结果

  • ❌ 用户创建回滚
  • ❌ 账户初始化回滚(连带回滚)
  • ❌ 邮件未发送

五、嵌套事务的本质

1. 数据库保存点(Savepoint)

START TRANSACTION; -- 主事务开始-- 主操作
INSERT INTO users (...) VALUES (...);SAVEPOINT sp1; -- 设置保存点-- 嵌套操作
INSERT INTO accounts (...) VALUES (...);-- 如果嵌套操作失败
ROLLBACK TO sp1; -- 回滚到保存点-- 继续其他操作...COMMIT; -- 提交主事务

2. 嵌套事务特性

特性说明示例
独立回滚嵌套事务可单独回滚账户初始化失败不影响用户保存
依赖提交嵌套操作随主事务提交主事务成功才真正生效
连带回滚主事务回滚导致嵌套回滚用户保存失败导致账户初始化回滚

六、为什么这样设计?

1. 业务需求分析

操作重要性事务要求
保存用户关键必须成功
初始化账户重要但可重试可独立失败
发送邮件非关键无需事务

2. 事务选择依据

  • REQUIRED:主操作必须保证原子性
  • NESTED:重要但可失败的操作
  • 无事务:非关键操作

 

七、对比其他传播行为

1. 如果使用REQUIRES_NEW

// 账户服务
@Transactional(propagation = Propagation.REQUIRES_NEW)
public void initAccount(Long userId) { ... }

问题

  • 账户初始化完全独立事务
  • 即使主事务回滚,账户操作仍可能提交
  • 导致数据不一致(用户不存在但账户存在)

2. 如果使用SUPPORTS

// 账户服务
@Transactional(propagation = Propagation.SUPPORTS)
public void initAccount(Long userId) { ... }

问题

  • 没有独立事务控制
  • 账户失败会导致主事务回滚
  • 用户保存也会被回滚

八、最佳实践总结

1. 事务传播选择指南

场景推荐传播行为
核心操作(必须成功)REQUIRED
重要但可失败的操作NESTED
非关键操作无事务或NOT_SUPPORTED
完全独立操作REQUIRES_NEW

2. 嵌套事务使用要点

  1. 数据库支持:MySQL InnoDB等支持保存点的引擎
  2. 异常处理:必须捕获嵌套事务异常
  3. 性能考虑:不宜嵌套过深
  4. 业务对齐:嵌套事务必须属于同一业务单元

九、扩展思考

1. 如果邮件服务需要事务?

// 邮件服务
@Transactional(propagation = Propagation.NOT_SUPPORTED)
public void sendWelcomeEmail(String email) {// 记录邮件发送日志(需要事务)emailLogDao.save(new EmailLog(email));// 实际发送邮件emailClient.send(email);
}

解决方案

@Service
public class EmailService {// 邮件日志服务(使用REQUIRES_NEW)@Transactional(propagation = Propagation.REQUIRES_NEW)public void logEmail(String email) {emailLogDao.save(new EmailLog(email));}// 发送服务(无事务)public void sendWelcomeEmail(String email) {logEmail(email); // 独立事务记录日志emailClient.send(email); // 非事务操作}
}

2. 多服务嵌套场景

public void register(User user) {userDao.save(user); // 主事务accountService.initAccount(user.getId()); // 嵌套事务profileService.initProfile(user.getId()); // 另一个嵌套事务
}

处理原则

  1. 每个嵌套事务设置独立保存点
  2. 分别捕获处理异常
  3. 确保主事务不受影响

十、总结

在这个用户注册场景中,我们通过合理的事务传播机制设计:

  1. REQUIRED 保证核心操作(用户保存)的原子性
  2. NESTED 处理重要但可失败的操作(账户初始化)
  3. 无事务 执行非关键操作(邮件发送)

这种设计实现了:

  • 核心业务100%可靠
  • 重要业务可独立失败不影响主流程
  • 非关键业务不阻塞主事务

事务传播机制的本质是:根据业务重要性,为不同操作匹配合适的事务保证级别

http://www.hkea.cn/news/869922/

相关文章:

  • 池州做网站公司游戏搜索风云榜
  • 东丽区做网站网站查询平台
  • wordpress什么主题好用seo优化范畴
  • 局域网端口映射做网站西安竞价托管代运营
  • 重庆网站建设设计公司信息ip网站查询服务器
  • 网站积分的作用seo搜索引擎优化就业前景
  • 珠海网站品牌设计公司简介最新国内新闻重大事件
  • 广东专业网站客服软件定制站长统计app下载大全
  • 广东网站建设公司排名磁力帝
  • 胶南网站建设哪家好成都电脑培训班零基础
  • 集团网站建设哪家好网上推广怎么弄?
  • dz网站建设器最近有新病毒出现吗
  • 个人网站制作说明香港旺道旺国际集团
  • 监控做直播网站免费网站seo
  • 网站建设洪塔网站搜索优化排名
  • 专业做设计师品牌网站深圳百度总部
  • 网站兼容工具seo关键词排名优化教程
  • O2O网站制作需要多少钱美区下载的app怎么更新
  • 上海做网站 公司做电商必备的几个软件
  • caozi.com网站建设中百度指数如何分析数据
  • 互联网舆情处置公司武汉seo外包平台
  • 消防器材网站建设背景seo工作职位
  • 专业网站制作公司名称seo咨询茂名
  • 做b2c网站建网站seo
  • 代理注册香港公司seo技术交流论坛
  • 想要提高网站排名应该怎么做seo网站推广费用
  • 专业做食材网站seo链接优化建议
  • 做画册的网站附近哪里有计算机培训班
  • 大兴建站推广google登录
  • 长春个人做网站哪家好百度指数热度榜