登录
首页 >  Golang >  Go问答

Golang 程序在数据库事务中终止时,是否能够执行回滚操作?

来源:stackoverflow

时间:2024-02-28 10:18:21 214浏览 收藏

本篇文章给大家分享《Golang 程序在数据库事务中终止时,是否能够执行回滚操作?》,覆盖了Golang的常见基础知识,其实一个语言的全部知识点一篇文章是不可能说完的,但希望通过这些问题,让读者对自己的掌握程度有一定的认识(B 数),从而弥补自己的不足,更好的掌握它。

问题内容

假设具有默认设置(包括启用自动提交)的 mariadb 兼容数据库 (aws aurora rds),如果 lambda 函数在三秒执行事务后终止,该事务需要超过五秒,例如

tx, err := h.db.Begin()
  if err != nil {
      log.WithError(err).Error("failed to start transaction")
  }
  res, execErr := tx.Exec(fmt.Sprintf("UPDATE testtable SET val = %d WHERE id = 1; SELECT SLEEP(5.5);", time.Now().Unix()))
  if execErr != nil {
      log.WithError(err).Error("rolling back")
      err = tx.Rollback()
      if err != nil {
          log.WithError(err).Error("failed to roll back")
      }
  }
  if err := tx.Commit(); err != nil {
      log.WithError(err).Error("failed to commit")
  }

人们会假设结果是什么?交易将不会被提交?

顺便说一句,我正在使用 go mysql 驱动程序 v1.3.0-84-g6be42e0。我还制作了一个视频来显示我的结果,但我想知道它是否正确,因为我不明白驱动程序如何执行回滚。


解决方案


事务 SQL 未提交。我相信 <= 5 秒超时会发生什么:

  1. 开始交易
  2. 同步执行 SQL
  3. MySQLd 检测到客户端通过 TCP FIN 断开连接
  4. MySQLd 会自动回滚,因为它没有看到提交

来自 Golang MySQL driver 维护者之一的推文回复:

当Go客户端终止时,mysqld收到TCP FIN数据包。
即使Go客户端不正常退出,操作系统(Linux内核等)也会发送TCP FIN或TCP RST。因此 mysqld 可以知道客户端已经消失。— INADA Naoki (@macet) December 4, 2018

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>