考慮以下場景:我們有一個 AWS 工作實例(基于 SQS),它打開與 RDS 的持久 MySQL 連接。$this->connectRegistry[ $host ][ 'connect' ] = mysqli_connect( "p:" . $host , $this->hostCredentials[ $host ][ 'username' ] , $this->hostCredentials[ $host ][ 'password' ]);現在有時(不是定期)此調用會生成以下警告:PHP 警告:mysqli_connect():MySQL 服務器已消失由于 AWS 工作實例使用 Web 服務器處理請求,因此設置基本上與服務網站的常用實例相同。我們在多個項目中使用相同的類,但在一個網站中,這個錯誤甚至沒有發生過一次。為了了解這些警告的來源,我們嘗試在發生連接錯誤時打印堆棧跟蹤,但是 - 現在尷尬的事情開始出現 - 沒有連接錯誤。請看一下整個connect函數:private function connect ( $host ){ $this->connectRegistry[ $host ][ 'connect' ] = mysqli_connect( "p:" . $host , $this->hostCredentials[ $host ][ 'username' ] , $this->hostCredentials[ $host ][ 'password' ] ); $error = mysqli_connect_error(); if( $error ) { $this->raiseError( "Connect (" . mysqli_connect_errno() . ") " . $error ); return false; } return true;}該方法raiseError使用堆棧跟蹤等構建完整的錯誤消息,然后調用trigger_error. 但是,如果觸發上述警告,則不會調用此方法。我們的第一個目標是了解哪些 cronjobs 會觸發這些警告 - 也許存在一些性能不佳的查詢。
2 回答

藍山帝景
TA貢獻1843條經驗 獲得超7個贊
如果你得到,就不會有任何連接錯誤
mysqli_connect(): MySQL 服務器已經消失
此消息意味著現有連接不再可用。一定發生了什么事情,MySQL 服務器關閉了連接。造成這種情況的原因可能有很多。最常見的一種是mysqli_close()
在代碼中的其他地方調用,但由于您在此處使用持久連接,根本原因可能完全不同。您需要調試導致連接斷開的原因。
但是,我強烈建議完全停止使用持久連接。您不太可能有有效的技術理由來使用它們,并且調試它們可能會很成問題。

浮云間
TA貢獻1829條經驗 獲得超4個贊
我在使用 php 守護程序時遇到了此類問題:當您啟動守護程序時,會建立 php 連接,如果一段時間沒有查詢,則數據庫連接實際上會終止。
過去我找到了兩種解決方案
要保持連接處于活動狀態,請每 n 秒進行一次簡單的快速查詢
在運行時創建連接,而不是在守護程序啟動時,而是在守護程序執行工作時創建。
我建議第二個選擇。
“持久”連接并不意味著連接將永遠存在,它只是在使用相同的用戶名、密碼等時被重用,如果您使用方法2),這會有所幫助
- 2 回答
- 0 關注
- 185 瀏覽
添加回答
舉報
0/150
提交
取消