聊聊数据库事务内嵌TCP连接

最近再看项目代码,发现很多的service里面,喜欢在事务内部再去调用HTTP请求,简单分析下此种方式的利弊与解决策略。

概述

在数据库内部嵌套TCP连接(一般是HTTP调用或是RPC远程调用)。

java 复制代码
@Transactional(rollbackFor = Exception.class)
public Boolean inviteUser(..){
    // service 调用
    userService.add(..);
	// HTTP调用
    httpClient.post(..,20)
}

优点:

  1. 保障两个操作间的原子性、隔离性。
  2. 事务控制: 建立TCP连接可以使数据库管理系统更好地控制和监视事务。它可以跟踪连接的状态和事务的执行进度,从而更容易实现事务管理和恢复。
  3. 性能优化: 内部TCP连接可以针对特定的事务进行性能优化。例如,可以为事务分配更多的系统资源,以提高其执行速度。
  4. 安全性: 内部TCP连接可以通过加密和认证来增强安全性,确保只有授权的用户或应用程序能够访问数据库

弊端:

  1. TCP连接可能会超时,导致事务变成长事务。
  2. 网络抖动出现异常,可能会导致前一个正常的操作回滚。
  3. 资源消耗: 每个TCP连接都需要消耗系统资源,包括内存和处理能力。在高负载情况下,内部建立TCP连接可能导致资源耗尽,影响其他事务的执行。
  4. 连接维护开销: 维护大量的TCP连接可能会增加数据库管理系统的开销。每个连接都需要管理、维护和监视,这可能会导致性能下降。
  5. 复杂性: 内部TCP连接引入了更复杂的架构,需要更多的管理和维护工作。这可能需要更多的开发和管理工作,并增加了系统的复杂性。
  6. 连接延迟: 建立和维护TCP连接需要时间,这可能会导致事务的启动延迟。对于需要快速响应的事务,这可能是一个不利因素。

解决方案

评估审视多个操作调用之间是否有强一致性。

  1. 有强一致性

必须手动开启事务,根据HTTP调用的返回码进行手动事务提交或回滚。事务传播级别,尽量使用当前事务。

  1. 无强一致性

手动开启事务,或是使用自动事务注解,但最后可以通过事件监听器回调事务接口的afterCommit方法,再进行HTTP调用。事务传播级别,尽量使用当前事务。

相关推荐
问老大1 个月前
MySQL学习2之事务ACID特性以及实现机制
数据库·学习·mysql·事务·acid
马剑威(威哥爱编程)1 个月前
分布式事务Seata的4种模式详解
java·分布式·spring cloud·事务·seata·威哥爱编程
相忘于江湖-mfc1 个月前
SQLite批量INSERT
数据库·sqlite·事务·批量插入
装不满的克莱因瓶1 个月前
Spring @Transactional事务传播行为详解
java·后端·spring·系统架构·springboot·事务·事务传播行为
_错错错2 个月前
MySQL 事务
数据库·mysql·事务
jupiter_8883 个月前
spring tx @Transactional 详解 `Advisor`、`Target`、`ProxyFactory
spring·事务·aop
零叁三3 个月前
[Django学习]如何在Django中声明“事务”(包括事务回滚)
数据库·后端·django·事务
hello_zzw4 个月前
Spring事务失效场景
数据库·spring·事务
xiaomifeng10104 个月前
Apache ShardingSphere知识点表格总结及配置示例
数据库·事务·shardingsphere·读写分离·分布式事务·分表分库
coder!mq5 个月前
Spring中的声明式事务详解
数据库·spring·oracle·事务