PHP中使用sleep造成mysql讀取失敗的案例和解決方法
近日,由于項目需求
需要用到sleep函數(shù)定時從數(shù)據(jù)庫取一堆數(shù)據(jù)出來去執(zhí)行某些操作。
sleep等待的時間至少有一個小時以上
此前做過測試
用sleep函數(shù)去完成數(shù)小時后執(zhí)行的操作是可行的
可邪門的問題出來了
程序用sleep后發(fā)現(xiàn)不能從數(shù)據(jù)庫取到相應(yīng)的信息
把sleep去掉
結(jié)果正常
郁悶中。。。
難道sleep影響讀庫操作?。?!
于是為了方便測試
直接來個sleep(10) 十秒后執(zhí)行
結(jié)果能從數(shù)據(jù)庫讀取信息
可為什么sleep()一個小時后不能讀取信息呢?
為了測試方便我直接在sleep語句前讀庫一次,sleep后再讀一次庫
如:
<?php
require_once('include.php');
// 讀取數(shù)據(jù)庫信息
$data = $db->getList();
print_r($data);
// 定時一個小時以后
sleep(3600);
// 再讀取一次信息
$data = $db->getList();
print_r($data);
?>
結(jié)果發(fā)現(xiàn)
第一次讀庫成功
第二次讀庫為空
于是再把sleep改成十秒鐘后再測試一次
<?php
require_once('include.php');
// 讀取數(shù)據(jù)庫信息
$data = $db->getList();
print_r($data);
// 定時十秒以后
sleep(10);
// 再讀取一次信息
$data = $db->getList();
print_r($data);
?>
以上結(jié)果
兩次讀庫成功
為何一個小時讀庫失敗,十秒鐘卻讀庫成功呢??
我用的是單例數(shù)據(jù)庫操作類
想起一個問題
會不會是數(shù)據(jù)庫連接超時導(dǎo)致讀庫失敗呢?
于是趕緊把此處讀庫操作改成現(xiàn)連
<?php
require_once('include.php');
// 讀取數(shù)據(jù)庫信息
$data = getList();
print_r($data);
// 定時一個小時以后
sleep(3600);
// 再讀取一次信息
$data = getList();
print_r($data);
// 讀取數(shù)據(jù)庫信息
function getList(){
$pdo = new PDO('mysql:host=localhost;dbname=test','root','root');
$result = $pdo->query('select * from tables');
return $result->fetchAll(PDO::FETCH_ASSOC);
}
?>
測試成功?。?br /> 原來sleep會導(dǎo)致單例類超時問題從而出現(xiàn)執(zhí)行時間過長以后數(shù)據(jù)庫連接可能斷開問題,也就不能讀到數(shù)據(jù)庫信息!
相關(guān)文章
Linux系統(tǒng)下使用XHProf和XHGui分析PHP運行性能
這篇文章主要介紹了Linux系統(tǒng)下使用XHProf和XHGui分析PHP運行性能的方法,該方案支持Apache與Nginx服務(wù)器及多種數(shù)據(jù)庫環(huán)境,需要的朋友可以參考下2015-12-12php常用經(jīng)典函數(shù)集錦【數(shù)組、字符串、棧、隊列、排序等】
這篇文章主要介紹了php常用經(jīng)典函數(shù),總結(jié)分析了php數(shù)組、字符串、棧、隊列、排序等相關(guān)函數(shù)功能與使用技巧,需要的朋友可以參考下2019-08-08對squid中refresh_pattern的一些理解和建議
用于確定一個頁面進入cache后,它在cache中停留的時間。refresh_pattern規(guī)則僅僅應(yīng)用到?jīng)]有明確過時期限的響應(yīng)。原始服務(wù)器能使用Expires頭部,或者Cache-Control:max-age指令來指定過時期限。2009-04-04