我将 Django 与 mysql 一起使用,并遇到连接过多的问题。
我从命令行运行 python 脚本,但与 Django 模型集成以检查数据库中的数据。该脚本每 30 秒运行一次,我使用线程来控制它。 My_function 是检查数据库状态的函数。
while True:
now = time.time()
if now < next:
time.sleep(next - now)
t = Thread(target=my_function,)
t.start()# start a thread
next += interval
问题是当我监控 mysql 服务器时。一直有大约 10 个连接,并且所有连接都在休眠。我只是不明白为什么。有 2 个活动的 python 线程不断运行,所有其他线程在完成后都会终止。为什么mysql连接数是10个?
有人可以帮助我吗?非常感谢!
更新1:
现在放上mysql进程列表的截图。连接均处于睡眠模式并且不执行任何操作,并且创建连接的线程已终止。这真的很奇怪。
+------+------+-----------------+----------+---------+-------+-------+------------------+
| Id | User | Host | db | Command | Time | State | Info |
+------+------+-----------------+----------+---------+-------+-------+------------------+
| 411 | root | localhost:47347 | NULL | Sleep | 2 | | NULL |
| 412 | root | localhost:47350 | NULL | Sleep | 3 | | NULL |
| 479 | root | localhost | NULL | Sleep | 27164 | | NULL |
| 918 | root | localhost | EZ_Green | Sleep | 14006 | | NULL |
| 953 | root | localhost | EZ_Green | Sleep | 12956 | | NULL |
| 989 | root | localhost | EZ_Green | Sleep | 11874 | | NULL |
| 1025 | root | localhost | EZ_Green | Sleep | 10796 | | NULL |
| 1061 | root | localhost | EZ_Green | Sleep | 9716 | | NULL |
| 1097 | root | localhost | EZ_Green | Sleep | 8636 | | NULL |
| 1132 | root | localhost | EZ_Green | Sleep | 7586 | | NULL |
| 1168 | root | localhost | EZ_Green | Sleep | 6506 | | NULL |
| 1204 | root | localhost | EZ_Green | Sleep | 5426 | | NULL |
| 1240 | root | localhost | EZ_Green | Sleep | 4346 | | NULL |
| 1276 | root | localhost | EZ_Green | Sleep | 3266 | | NULL |
| 1312 | root | localhost | EZ_Green | Sleep | 2186 | | NULL |
| 1348 | root | localhost | EZ_Green | Sleep | 1106 | | NULL |
| 1384 | root | localhost | EZ_Green | Sleep | 26 | | NULL |
| 1385 | root | localhost | NULL | Query | 0 | NULL | show processlist |
+------+------+-----------------+----------+---------+-------+-------+------------------+
正如尘尘所说,
每个使用 Django ORM 的线程都会创建一个新的数据库连接。
并且 Django 不会自动管理由您自己的线程创建的连接。
所以你应该管理它。
您可以在每个线程退出之前简单地执行此操作:
from django.db import connection
# your work thread method
def my_function():
# do something...
# close the db connection explicitly
connection.close()
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)