栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

Django-读操作的事务占用导致 Mysql 锁表

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Django-读操作的事务占用导致 Mysql 锁表

问题描述:

有一个后台脚本,使用的 django 的 orm,轮询读表,发现表被锁无法进行 alert 或者 drop 等操作

环境:python2.7 django 1.4.22

步骤如下:
      • 一.复现
      • 二.原因
      • 三.解决办法
        • 1.使用 commit_on_success
        • 2.使用 commit_manually作为装饰器
        • 3.使用 autocommit 作为装饰器

一.复现

尝试只在本地运行该脚本,问题依旧。
查看事务
select * from information_schema.innodb_trx;
有 RUNNING 状态的事务一直不提交,其中 trx_mysql_thread_id 字段就是在 mysql 中的进程 id
查看 mysql 进程(show processlist)
查找上边的进程id 对应的主机信息,是本机的ip

二.原因

在 django 1.6 之前,事务默认 autocommit 。在读写数据库时,都会对表产生一个 RUNNING 状态的事务。对于写操作,在save 的时候会触发 autocommit,结束事务;但是读操作不会触发 autocommit,导致该事务一直处于 RUNNING 状态,这也就导致不能对表结构进行修改操作

在 django 1.6 版本之前的 autocommit 只对写操作有效,对读操作无效。

三.解决办法 1.使用 commit_on_success
  • 使用 with 关键词

  • 直接使用装饰器–方便

@transaction.commit_on_success
2.使用 commit_manually作为装饰器

必须手动执行 transaction.commit(),不然报错:

3.使用 autocommit 作为装饰器

代码能正常运行,但是事务仍然没有 commit,所以也需要手动执行 transaction.commit()

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/339655.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号