亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

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

瀏覽:2日期: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 數據庫
主站蜘蛛池模板: 91高清免费国产自产拍2021 | 在线成人综合色一区 | 国内黄色一级精品 | 在线看黄色片 | 亚洲国产第一区二区香蕉 | 亚洲精品高清视频 | 亚洲欧美久久婷婷爱综合一区天堂 | 91午夜精品亚洲一区二区三区 | 亚洲免费在线观看视频 | 视色4se成人午夜精品 | 三级国产在线 | 欧美日韩国产一区 | 国产 日韩 欧美 亚洲 | 欧美任你躁免费精品一区 | a级片黄色片 | 国产性生活视频 | 尤物视频在线 | 小明看看在线视频 | 男女啪啪抽搐一进一出小 | 精品国产中文字幕 | 成人做爰免费视频免费看 | 国产精品日韩欧美在线第3页 | 亚洲美女色成人综合 | 国产精品一在线观看 | 成人羞羞免费视频 | 国产精品综合色区在线观看 | 国产精品视频免费视频 | 一区二区三区久久精品 | 国产一区二区三区播放 | 婷婷综合亚洲 | 性生活免费视频网站 | 特黄一级片 | 久久只有这才是精品99 | 国产在线精品一区二区高清不卡 | 最新亚洲国产有精品 | 最新国产精品精品视频 | 嫩草视频在线观看 | 亚洲日韩精品欧美一区二区一 | 精品国产欧美一区二区五十路 | 免费一级做a爰片性视频 | 色综合久久手机在线 |