国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

gearman中worker常駐后臺,導致MySQL server has gone away的解決方法

瀏覽:4日期:2023-10-16 12:02:45

本文實例講述了gearman中worker常駐后臺,導致MySQL server has gone away的解決方法。分享給大家供大家參考,具體如下:

產生這個原因主要有如下幾點:

1、mysql服務宕機了2、長時間沒有操作,超過了wait_timeout的設置,mysql自動斷開3、mysql請求鏈接被主動kill4、發送的請求或返回結果過大,可設置max_allowed_packet的值5、程序中你都是通過單例來操作數據庫,如果兩個操作時間超過wait_timeout。

為了演示的方便,設置wait_timeout時間為10秒

> set global wait_timeout=10;> show global variables like ’wait_timeout’;

worker.php代碼如下:

<?php//創建一個worker$worker = new GearmanWorker();//添加一個job服務$worker->addServer(’127.0.0.1’, 4730);//注冊一個回調函數,用于業務處理$worker->addFunction(’longTime’, function($job) { //workload()獲取客戶端發送來的序列化數據 $data = json_decode($job->workload(), true); $db = new mysqli(’192.168.1.100’, ’root’, ’’, ’test’); if($db->connect_error) { die(’connect error’); } //等待15秒,我們設置mysql的wait_timeout為10秒 sleep(15); //當執行到這里時,因為超時,所以mysql自動把連接斷開了 $ret = $db->query('INSERT INTO test VALUES(NULL, {$data[’title’]}, {$data[’content’]});'); if($ret) { return '插入成功n'; }});//死循環//等待job提交的任務while($worker->work());

client.php代碼如下:

<?php//創建一個客戶端$client = new GearmanClient();//添加一個job服務$client->addServer(’127.0.0.1’, 4730);//doNormal同步$ret = $client->doNormal(’longTime’, json_encode(array( ’title’ => ’我是標題’, ’content’ => ’我是內容’,)));echo $ret;

執行的結果如下圖所示,出現了MySQL server has gone away的情況。

gearman中worker常駐后臺,導致MySQL server has gone away的解決方法

一般的解決方法:

1、調大wait_timeout的值(不建議)2、每次在操作數據庫的時候,ping()一下,如果斷開就重新連。3、在wait_timeout時間間隔之內,我們時不時的去query(’select 1+1’);一下,讓mysql知道連接還活著。

修改worker.php代碼如下:

<?php//創建一個worker$worker = new GearmanWorker();//添加一個job服務$worker->addServer(’127.0.0.1’, 4730);//注冊一個回調函數,用于業務處理$worker->addFunction(’longTime’, function($job) { //workload()獲取客戶端發送來的序列化數據 $data = json_decode($job->workload(), true); $db = new mysqli(’192.168.1.100’, ’root’, ’’, ’test’); if($db->connect_error) { die(’connect error’); } //等待15秒,我們設置mysql的wait_timeout為10秒 sleep(15); //ini_set(’mysqli.reconnect’, 1); //php手冊上說,ping會嘗試重新連接,但現實是并不會 //$db->ping(); if(!$db->ping()) { $db->close(); //重新連接數據庫 $db = new mysqli(’192.168.1.100’, ’root’, ’’, ’test’); } $ret = $db->query('INSERT INTO test VALUES(NULL, ’{$data[’title’]}’, ’{$data[’content’]}’);'); if($ret) { return '插入成功n'; }});//死循環//等待job提交的任務while($worker->work());

運行結果如下:

gearman中worker常駐后臺,導致MySQL server has gone away的解決方法

更多關于PHP相關內容感興趣的讀者可查看本站專題:《PHP進程與線程操作技巧總結》、《PHP網絡編程技巧總結》、《PHP基本語法入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》、《php+mysql數據庫操作入門教程》及《php常見數據庫操作技巧匯總》

希望本文所述對大家PHP程序設計有所幫助。

標簽: MySQL 數據庫
主站蜘蛛池模板: 国产精品路边足疗店按摩 | 在线观看免费国产 | 欧美一级性视频 | 男人把女人桶到喷白浆的视频 | 精品视频在线观看一区二区三区 | 国产在视频线精品视频二代 | 国产欧美精品三区 | 国产欧美一区二区三区视频 | 一级成人毛片免费观看欧美 | 亚洲欧美日韩成人一区在线 | 久久一级视频 | 高清国产露脸捆绑01经典 | 一区二区三区视频在线观看 | 深夜国产成人福利在线观看女同 | 99精品视频在线免费观看 | 综合精品 | 精品视频在线观看一区二区三区 | 国产一级一级 | 免费人欧美成又黄又爽的视频 | 国产久草视频在线 | 成人欧美精品大91在线 | 免费亚洲视频在线观看 | 日韩精品欧美国产精品亚 | 91青草久久久久久清纯 | 国产精品拍自在线观看 | 久久91精品综合国产首页 | 手机看a | 欧美日韩精品一区二区免费看 | 免费 欧美 自拍 在线观看 | 波多野结衣在线播放视频 | 真实偷清晰对白在线视频 | 三级黄色片网站 | 97超级碰碰碰碰在线视频 | 亚洲欧洲日产国码二区首页 | 国产精品久久毛片蜜月 | 精品伊人久久久久7777人 | 国产91综合| 欧美一级淫片a免费播放口aaa | 国产天堂亚洲精品 | 欧美精品一区二区在线观看播放 | 国产精品一区亚洲一区天堂 |