麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Python > 正文

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

2020-02-15 23:07:21
字體:
來源:轉載
供稿:網友

問題

mysql 查詢出現錯誤

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.

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

背景 思考

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

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

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

    父進程和mysql建立的連接A,循環中fork出一個子進程 子進程保持了父進程的變量,也就是擁有mysql連接A 子進程去用連接A查詢mysql,父進程這個時候也并發的使用連接A訪問mysql 這樣很容易出現了上面Mysql提到的情況,結果就報錯了

 

解決

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

在父進程的loop中,創建子進程之前關閉mysql連接,這樣子進程中就會重新連接mysql。

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

其實就是狀態copy的問題,本來多個線程同時并發調用一個connection也不對.

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林站長站。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 91综合在线观看 | 久久艹综合 | 精品视频在线免费看 | 一级黄色影片在线观看 | 免费黄色成人 | 欧美成人一区二区三区电影 | 青青操国产 | 天天透天天狠天天爱综合97 | av电影院在线观看 | 成人免费看视频 | 免费看黄色一级大片 | 国产一区二区三区四区波多野结衣 | 免费看成年人视频在线 | 国产成人精品自拍视频 | 免费视频www在线观看 | 一区二区国产在线 | 极品大长腿啪啪高潮露脸 | 亚洲四播房 | 羞羞的视频在线 | 亚洲精品成人18久久久久 | 久草在线观看福利视频 | 欧美一级做一级爱a做片性 91在线视频观看 | 一级免费观看 | 欧美性色黄大片www 成人免费网站在线观看 | 九一免费在线观看 | 国产精品无码久久久久 | 一级做a爱片性色毛片高清 日本一区二区在线看 | 毛片在哪里看 | 亚洲啊v在线观看 | asian gaysex| 日韩视频区 | 在线91视频 | 色域tv| 久久久久久久亚洲精品 | 国产欧美日韩在线不卡第一页 | 俄罗斯16一20sex牲色另类 | 国产高潮好爽好大受不了了 | 黄色毛片免费看 | 涩涩激情网 | 国产精品成人av片免费看最爱 | 欧美激情区 |