詳解多線程Django程序耗盡數(shù)據(jù)庫連接的問題
Django的ORM是非常好用的,哪怕不是做Web項目也值得一用,所以網(wǎng)上也可以找到不少使用 Django 開發(fā)非Web項目的資料,因為除了ORM之個,命令行、配置文件等組件也非常好用。
最近用這種方式開發(fā)了一個非Web項目,而且是多線程的。有N個工作線程從DB中獲取jobs,并把結(jié)果寫回DB。簡單來說就是這樣。
項目運行一段時間后,發(fā)現(xiàn)數(shù)據(jù)庫連接耗盡了,幸好內(nèi)存大,然后一直往上調(diào),最后連接數(shù)都上九千多一萬了。耗盡連接數(shù)的時候,PostgreSQL 會出現(xiàn)類似這樣的錯誤:
FATAL: remaining connection slots are reserved for non-replication superuser connections
然后就各種看文檔、代碼,找問題,其中艱難略下不表,最后大概是這么些個知識點:
- Django里的數(shù)據(jù)庫連接是放在線程的 local() 實例中的。
- 任何時候,需要一個數(shù)據(jù)庫連接的話,Django就會創(chuàng)建一條出來,或者用本線程已有的那條。
- 如果是Web項目,在請求結(jié)束的時候,Django會去關(guān)閉掉連接。是的,沒有連接池。
- 因為我們是非Web項目,所以不存在請求結(jié)束事件,所以一直沒的關(guān)閉連接。但本來這個應(yīng)該也不會造成問題的,因為沒關(guān)閉就一直用唄,但不知道哪里出了問題,會出現(xiàn)連接泄漏,所以連接數(shù)據(jù)會一直增長。
最后的解決方案是找時機(jī)主動關(guān)閉數(shù)據(jù)庫連接,具體到我們項目,就是每次工作線程完成一個任務(wù)后,就把它相關(guān)的連接關(guān)掉,因為我們用的是 ThreadPoolExecutor
,所以Django很容易做到這一點。
重點代碼如下:
from django.db import connections def on_done(future): # 因為每一個線程都有一個 connections,所以這里可以調(diào)用 close_all(),把本線程名下的所有連接關(guān)閉。 connections.close_all() def main(): # ... with ThreadPoolExecutor() as executor: while True: future = executor.submit(do, get_a_job()) future.add_done_callback(on_done)
主動關(guān)閉后,數(shù)據(jù)庫連接數(shù)降到與工作線程數(shù)相近,并保持穩(wěn)定。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python?異步之在?Asyncio中如何運行阻塞任務(wù)詳解
這篇文章主要為大家介紹了Python?異步之在?Asyncio?中運行阻塞任務(wù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03把大數(shù)據(jù)數(shù)字口語化(python與js)兩種實現(xiàn)
當(dāng)出現(xiàn)萬以上的整型數(shù)字時,經(jīng)常要把它們口語化比較直觀。下面分享兩段代碼,python與js的2013-02-02Python3使用xml.dom.minidom和xml.etree模塊兒解析xml文件封裝函數(shù)的方法
這篇文章主要介紹了Python3使用xml.dom.minidom和xml.etree模塊兒解析xml文件,封裝函數(shù)的方法,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09Python?for循環(huán)詳細(xì)講解(附代碼實例)
這篇文章主要給大家介紹了關(guān)于Python?for循環(huán)詳細(xì)講解的相關(guān)資料,在Python中,for循環(huán)是一種常用的控制結(jié)構(gòu),用于遍歷序列(如列表、元組、字符串等)中的元素,需要的朋友可以參考下2024-03-03python代碼如何調(diào)出cmd命令行窗口并在cmd窗口中執(zhí)行指定的命令
這篇文章主要介紹了python代碼如何調(diào)出cmd命令行窗口并在cmd窗口中執(zhí)行指定的命令問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02python中學(xué)習(xí)K-Means和圖片壓縮
大家在python中會遇到關(guān)于K-Means和圖片壓縮的問題,我先通過本次文章學(xué)習(xí)一下基本原理吧。2017-11-11