亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

MySQL 服務器已消失 - 但沒有連接錯誤

MySQL 服務器已消失 - 但沒有連接錯誤

PHP
慕娘9325324 2023-11-03 10:52:36
考慮以下場景:我們有一個 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()在代碼中的其他地方調用,但由于您在此處使用持久連接,根本原因可能完全不同。您需要調試導致連接斷開的原因。

但是,我強烈建議完全停止使用持久連接。您不太可能有有效的技術理由來使用它們,并且調試它們可能會很成問題。


查看完整回答
反對 回復 2023-11-03
?
浮云間

TA貢獻1829條經驗 獲得超4個贊

我在使用 php 守護程序時遇到了此類問題:當您啟動守護程序時,會建立 php 連接,如果一段時間沒有查詢,則數據庫連接實際上會終止。

過去我找到了兩種解決方案

  1. 要保持連接處于活動狀態,請每 n 秒進行一次簡單的快速查詢

  2. 在運行時創建連接,而不是在守護程序啟動時,而是在守護程序執行工作時創建。

我建議第二個選擇。

“持久”連接并不意味著連接將永遠存在,它只是在使用相同的用戶名、密碼等時被重用,如果您使用方法2),這會有所幫助


查看完整回答
反對 回復 2023-11-03
  • 2 回答
  • 0 關注
  • 185 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號