欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python django使用多進程連接mysql錯誤的解決方法

 更新時間:2018年10月08日 08:59:51   作者:orangleliu  
這篇文章主要介紹了Python django使用多進程連接mysql錯誤的解決方法,詳細的介紹了解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

問題

mysql 查詢出現(xiàn)錯誤

error: (2014, "Commands out of sync; you can't run this command now")1

查詢

mysql文檔中的解釋

  If you get Commands out of sync; you can't run this command now in your client code, you are calling client functions in the wrong order.
  This can happen, for example, if you are using mysql_use_result() and try to execute a new query before you have called mysql_free_result(). It can also happen if you try to execute two queries that return data without calling mysql_use_result() or mysql_store_result() in between.

調(diào)用順序錯誤,同一個連接,發(fā)出2個查詢請求,第一個請求發(fā)出之后沒有等到mysql返回就發(fā)出第二個請求

背景 思考

我這里的程序是這樣的,在django框架中起了一個定時任務(wù),這個任務(wù)中有個循環(huán),主線程循環(huán)查詢mysql然后在循環(huán)體中生成了子進程,子進程中也有mysql查詢。

我測試了下不實用多進程的情況沒有問題,使用多進程就會出現(xiàn)這個問題。

對照上面的文檔,其實不難想到,錯誤應(yīng)該是這樣的

  1. 父進程和mysql建立的連接A,循環(huán)中fork出一個子進程
  2. 子進程保持了父進程的變量,也就是擁有mysql連接A
  3. 子進程去用連接A查詢mysql,父進程這個時候也并發(fā)的使用連接A訪問mysql
  4. 這樣很容易出現(xiàn)了上面Mysql提到的情況,結(jié)果就報錯了

 

解決

解決的方案其實很容易想到,就是當(dāng)我們fork一個進程之后,讓他從新獲取一個和mysql的連接C或者D就好了嘛,
結(jié)果幾個測試,得到如下的方案。

在父進程的loop中,創(chuàng)建子進程之前關(guān)閉mysql連接,這樣子進程中就會重新連接mysql。

  from django import db
  db.close_connection()
  p = Process(target=ap5mintes_scan, args=(ac, details, mtime))
  p.start()

其實就是狀態(tài)copy的問題,本來多個線程同時并發(fā)調(diào)用一個connection也不對.

后面做了個測試 ,多進程的情況下查看mysql processlist,的確使用建立多個mysql 連接。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python基礎(chǔ)教程之正則表達式基本語法以及re模塊

    Python基礎(chǔ)教程之正則表達式基本語法以及re模塊

    正則表達式是可以匹配文本片段的模式,今天的Python就跟大家一起討論一下python中的re模塊,python re模塊感興趣的朋友一起學(xué)習(xí)吧
    2016-03-03
  • 詳解Python獲取線程返回值的三種方式

    詳解Python獲取線程返回值的三種方式

    提到線程,你的大腦應(yīng)該有這樣的印象:我們可以控制它何時開始,卻無法控制它何時結(jié)束,那么如何獲取線程的返回值呢?今天就和大家分享一下一些做法
    2022-07-07
  • 詳解python3實現(xiàn)的web端json通信協(xié)議

    詳解python3實現(xiàn)的web端json通信協(xié)議

    本篇文章主要介紹了python3實現(xiàn)的web端json通信協(xié)議,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-12-12
  • 如何利用pandas工具輸出每行的索引值、及其對應(yīng)的行數(shù)據(jù)

    如何利用pandas工具輸出每行的索引值、及其對應(yīng)的行數(shù)據(jù)

    這篇文章主要介紹了如何利用pandas工具輸出每行的索引值、及其對應(yīng)的行數(shù)據(jù),本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • pandas中merge函數(shù)的用法

    pandas中merge函數(shù)的用法

    merge()函數(shù)是Pandas中用于合并兩個DataFrame的函數(shù),本文主要介紹了pandas中merge函數(shù)的用法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-06-06
  • Python 條件,循環(huán)語句詳解

    Python 條件,循環(huán)語句詳解

    這篇文章主要介紹了詳解Python中的條件,循環(huán)語句,循環(huán)語句是學(xué)習(xí)各個編程語言的最基本的基礎(chǔ)知識,需要的朋友可以參考下
    2021-09-09
  • Python3 ID3決策樹判斷申請貸款是否成功的實現(xiàn)代碼

    Python3 ID3決策樹判斷申請貸款是否成功的實現(xiàn)代碼

    這篇文章主要介紹了Python3 ID3決策樹判斷申請貸款是否成功的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-05-05
  • pyqt5的QComboBox 使用模板的具體方法

    pyqt5的QComboBox 使用模板的具體方法

    這篇文章主要介紹了pyqt5的QComboBox 使用模板的具體方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-09-09
  • Python中os和shutil模塊實用方法集錦

    Python中os和shutil模塊實用方法集錦

    這篇文章主要介紹了Python中os和shutil模塊實用方法集錦,需要的朋友可以參考下
    2014-05-05
  • python抓取多種類型的頁面方法實例

    python抓取多種類型的頁面方法實例

    在本篇文章里小編給大家整理的是關(guān)于python抓取多種類型的頁面方法實例內(nèi)容,有需要的朋友們可以學(xué)習(xí)下。
    2019-11-11

最新評論