天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php垃圾代碼優化操作代碼

公司有幾個網站搭在美國的虛擬主機上,服務器上的mysql服務差不多每一天都會突然不知什么時候掛掉,然后過一會又恢復了,懷疑是超出cpu的使用限制而被自動結束了,但是實際上該服務器上的流量很小。于是早先的時候聯系了服務器提供商的印度阿三客服,想看看是不是其他用戶搞多了害的大家一起死,阿三們查找了之后,信誓旦旦的拍著長毛的胸部保證不是他們的問題,事情沒有解決。懸著不是個事,只好自己查了,好在可以訪問到information_schema庫,看了看,沒話了,user_statistics里面的數據顯示我們的一個mysql用戶在busy_time,cpu_time等指標上都高到不行,自己的事,好在阿三沒有發現。于是趕緊查程序,之前的這個網站程序不是由我做的,但是知道里面問題很多,架構到實現都有問題,但是頁面不是一般的多,代碼夾雜著html,全看過去還不死,(這種時候就尤為的覺著mvc多美妙),平時能湊合著運行就可以了,反正沒有什么訪問量。

既然是mysql的負擔重,那就先找這個,本地上搞一個網站的鏡像運行下,在my.ini里修改添加

復制代碼 代碼如下:
[mysqld]
log="d:/temp/mysql.log"
log_slow_queries="d:/temp/mysql_slow.log"
long_query_time=1


這個目錄是要已經存在的。重啟mysql服務,就可以記錄了。

查看sql記錄后大吃一驚,查詢的數量驚人,隨便一個頁面,sql查詢都在幾十條,多的有上千條!

以論壇來說吧,一個頁面的數據庫查詢次數也就是10次一下,用了緩存的還可以再低。這樣算的話,就相當于原來幾十倍的負擔,能不掛?

誰人也不能那邊有毅力寫下上百條的查詢啊,所以肯定是循環查詢。sql語句也表明這一點。知道原因了就好改了,找到相關頁面,改掉循環查詢,例如,有一個頁面,要顯示所有地區分類和該分類下的文章數,先不考慮數據庫的結構優化,就程序而言,原來的大概是這樣子的
復制代碼 代碼如下:
$sql1="SELECT aid,count(*) as cc FROM pz_content WHERE uid=$uid group by aid";
$rs1=$db->query($sql1);
if(is_array($rs1)){
foreach($rs1 as $r1){
輸出...
echo id2name($r1->aid);
}
}
............
function id2name($aid)
{
$sql="select ename from pz_area_a where aid_a=".$id;
$result=mysql_query($sql);
$row=mysql_fetch_object($result);
return $row->ename;
}

先不管代碼的容錯,看實現就知道,他先讀取了該用戶的相關文章并按地區ID進行了分組和統計個數,然后再每個地區每個地區地輸出地區名字,所以,如果有1w個地區,這里就要查詢1w次。放上一個計時的代碼,看了下,大概耗用內存6M,執行時間16秒,累計查詢1001次

其實,這里是只要用一句sql就可以搞定的事情,并不需要循環。

復制代碼 代碼如下:
$sql1="select pz_area.aid,pz_area.ename,tb1.cc from pz_area right join (SELECT aid,count(*) as cc FROM pz_content WHERE uid=$uid group by aid) as tb1 on pz_area.aid=tb1.aid";
$rs1=$db->query($sql1);
if(is_array($rs1)){
  foreach($rs1 as $r1){
輸出...
   echo $r1->ename;
  }
}

問題就可以解決了。重新運行下,內存耗用差不多,查詢1次,CPU執行時間只有647毫秒,和原來的差了26倍!再看一下,發現這個pz_content的表,記錄還算比較多的,有經常要按地區查詢劃分之類的,但是原來什么索引也沒有。順道在aid上加上一個索引,執行時間縮短到432毫秒。

這個頁面的事情算了了,先到這里,下次繼續。

php技術php垃圾代碼優化操作代碼,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲国产在线精品国自产拍五月 | 秋霞久久久久久一区二区 | 99视频在线精品免费观看18 | 日本69xxxx | 亚洲性夜夜色综合网站 | 亚洲中文无码AV在线观看 | 丰满人妻熟女色情A片 | 国产成人精品亚洲线观看 | 国内精品久久久久影院亚洲 | 亚洲一区二区影院 | 亚洲精品国产自在在线观看 | 久久五月综合婷婷中文云霸高清 | 黑人玩弄极品人妻系列 | 年轻的老师5理伦片 | 亚洲久热无码中文字幕 | 欧美色偷偷亚洲天堂bt | 51国产午夜精品免费视频 | 国内精品不卡一区二区三区 | 最近最新的日本字幕MV | 国产国产乱老熟视频网站 | 久久精品嫩草影院免费看 | 富婆找黑人老外泻火在线播放 | 国产精品久久久久婷婷五月色 | 欧美亚洲另类丝袜自拍动漫 | 久久精品无码人妻无码AV蜜臀 | 免费毛片网站在线观看 | 香蕉 在线播放 | 九九热这里有精品 | 国模精品一区二区三区视频 | 毛片一区二区三区 | 亚洲精品国产一区二区贰佰信息网 | 国产亚洲精品精品国产亚洲综合 | 伊人情人网综合 | 饥渴难耐的浪荡艳妇在线观看 | 樱桃熟了A级毛片 | 在线亚洲精品国产一区麻豆 | 免费人成视频X8X8国产更快乐 | 亚洲精品第一页 | wwww69| 九九在线精品视频 | 嗨嗨快播电影 |