第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

MySQL 服務(wù)器已消失 - 但沒有連接錯(cuò)誤

MySQL 服務(wù)器已消失 - 但沒有連接錯(cuò)誤

PHP
慕娘9325324 2023-11-03 10:52:36
考慮以下場(chǎng)景:我們有一個(gè) AWS 工作實(shí)例(基于 SQS),它打開與 RDS 的持久 MySQL 連接。$this->connectRegistry[ $host ][ 'connect' ] = mysqli_connect(    "p:" . $host ,    $this->hostCredentials[ $host ][ 'username' ] ,    $this->hostCredentials[ $host ][ 'password' ]);現(xiàn)在有時(shí)(不是定期)此調(diào)用會(huì)生成以下警告:PHP 警告:mysqli_connect():MySQL 服務(wù)器已消失由于 AWS 工作實(shí)例使用 Web 服務(wù)器處理請(qǐng)求,因此設(shè)置基本上與服務(wù)網(wǎng)站的常用實(shí)例相同。我們?cè)诙鄠€(gè)項(xiàng)目中使用相同的類,但在一個(gè)網(wǎng)站中,這個(gè)錯(cuò)誤甚至沒有發(fā)生過(guò)一次。為了了解這些警告的來(lái)源,我們嘗試在發(fā)生連接錯(cuò)誤時(shí)打印堆棧跟蹤,但是 - 現(xiàn)在尷尬的事情開始出現(xiàn) - 沒有連接錯(cuò)誤。請(qǐng)看一下整個(gè)connect函數(shù):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使用堆棧跟蹤等構(gòu)建完整的錯(cuò)誤消息,然后調(diào)用trigger_error. 但是,如果觸發(fā)上述警告,則不會(huì)調(diào)用此方法。我們的第一個(gè)目標(biāo)是了解哪些 cronjobs 會(huì)觸發(fā)這些警告 - 也許存在一些性能不佳的查詢。
查看完整描述

2 回答

?
藍(lán)山帝景

TA貢獻(xiàn)1843條經(jīng)驗(yàn) 獲得超7個(gè)贊

如果你得到,就不會(huì)有任何連接錯(cuò)誤

mysqli_connect(): MySQL 服務(wù)器已經(jīng)消失

此消息意味著現(xiàn)有連接不再可用。一定發(fā)生了什么事情,MySQL 服務(wù)器關(guān)閉了連接。造成這種情況的原因可能有很多。最常見的一種是mysqli_close()在代碼中的其他地方調(diào)用,但由于您在此處使用持久連接,根本原因可能完全不同。您需要調(diào)試導(dǎo)致連接斷開的原因。

但是,我強(qiáng)烈建議完全停止使用持久連接。您不太可能有有效的技術(shù)理由來(lái)使用它們,并且調(diào)試它們可能會(huì)很成問題。


查看完整回答
反對(duì) 回復(fù) 2023-11-03
?
浮云間

TA貢獻(xiàn)1829條經(jīng)驗(yàn) 獲得超4個(gè)贊

我在使用 php 守護(hù)程序時(shí)遇到了此類問題:當(dāng)您啟動(dòng)守護(hù)程序時(shí),會(huì)建立 php 連接,如果一段時(shí)間沒有查詢,則數(shù)據(jù)庫(kù)連接實(shí)際上會(huì)終止。

過(guò)去我找到了兩種解決方案

  1. 要保持連接處于活動(dòng)狀態(tài),請(qǐng)每 n 秒進(jìn)行一次簡(jiǎn)單的快速查詢

  2. 在運(yùn)行時(shí)創(chuàng)建連接,而不是在守護(hù)程序啟動(dòng)時(shí),而是在守護(hù)程序執(zhí)行工作時(shí)創(chuàng)建。

我建議第二個(gè)選擇。

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


查看完整回答
反對(duì) 回復(fù) 2023-11-03
  • 2 回答
  • 0 關(guān)注
  • 199 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)