记录一次外键导致的事务超时问题

背景介绍

上周帮同学排查了一个问题,在一行向数据库中插入一条数据库的记录时会稳定地出现事务超时的问题。ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction。但这个表是新建的,此前也没有任何代码会访问这张表,因此出现等待锁的情况非常奇怪。

问题分析

通过SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;分析,发现是外键导致的等待锁超时。在项目中有任务和子任务的概念,分别存放在任务表和子任务表中。服务A将一条任务的status字段设置为运行中,然后调用服务B创建一个子任务,子任务中的taskId字段为和他关联的任务Id。当服务A更新任务status字段时因为有索引,给一条记录上了X锁,当服务B准备插入子任务记录时,因为数据库有外键约束,会先尝试给任务表加上S锁。因为服务A调用服务B的代码是在事务里的,此时X锁还没有释放,因此服务B事务加S锁的动作会一直等待,直到超过了超时时间。

总结

这个问题实际上是整个项目没有正确处理微服务事务的一个缩影,可以看出,在整个项目没有作出合理的设计,开发团队又没有足够经验的情况下,选用微服务的架构会产生非常多的问题,还是要根据实际情况选择恰当的技术。为了解决这类问题,分布式事务有非常多的资料可以参考,因为还没有实践的经历,就先不展开了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果一个项目完全没有使用外键关联,可能会导致数据一致性问题和性能瓶颈。外键关联可以帮助保证数据的完整性和一致性,避免数据冗余和错误。此外,外键关联还能够提高查询效率和优化数据库性能。因此,建议在设计数据库时,应该合理地设置外键关联,以保证数据的可靠性和高效性。 ### 回答2: 一个项目完全没有使用外键关联的确可能会出现一些问题外键是一种数据库约束,用于维护不同表之间的关系。如果没有正确使用外键关联,可能会导致以下问题: 1. 数据完整性问题:没有外键关联可能导致数据的不一致性。例如,如果一个表中存在一个ID字段用于关联另一个表的某个数据,但没有外键关联约束,那么在更新或删除关联表中的数据时,可能会留下无效的引用在关联表中。 2. 数据一致性问题:如果没有外键关联,可能会导致数据的不一致性。例如,如果一个表中的某个字段应该是另一个表的主键,但没有外键关联,那么在插入数据时可能会出现不一致的情况,可能导致数据冗余或重复。 3. 数据查询和维护问题:没有外键关联可能导致查询和维护数据时的困难。外键关联可以简化关联表的查询和维护,可以方便地通过外键关联进行数据的join操作,提高查询效率。 4. 数据一致性维护问题:没有外键关联可能导致数据的一致性难以维护。外键关联可以通过约束来保证关联表中的数据一致性,当更新或删除主表中的数据时,可以自动更新或删除关联表中的数据,确保数据的一致性。 5. 数据安全性问题:没有外键关联可能导致数据的安全性问题外键关联可以限制对关联表中数据的访问权限,确保数据的安全性。 总之,完全不使用外键关联可能会导致数据的不一致性、查询和维护困难、数据安全性问题等。因此,在设计和开发项目时,应该充分考虑使用合适的外键关联来保证数据的完整性和一致性,并提高项目的稳定性和可维护性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值