php垃圾代码优化操作代码


Posted in PHP onAugust 05, 2010

公司有几个网站搭在美国的虚拟主机上,服务器上的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制作静态网站的模板框架(四)
Oct 09 PHP
PHP4在Windows2000下的安装
Oct 09 PHP
我用php+mysql写的留言本
Oct 09 PHP
PHP笔记之:基于面向对象设计的详解
May 14 PHP
浅析PHP Socket技术
Aug 02 PHP
PHP迭代器实现斐波纳契数列的函数
Nov 12 PHP
php获取域名的google收录示例
Mar 24 PHP
CodeIgniter 完美解决URL含有中文字符串
May 13 PHP
PHP+Ajax 检测网络是否正常实例详解
Dec 16 PHP
彻底搞懂PHP 变量结构体
Oct 11 PHP
PHP asXML()函数讲解
Feb 03 PHP
php伪静态验证码不显示的解决方案
Sep 26 PHP
PHP MemCached 高级缓存应用代码
Aug 05 #PHP
phpMyAdmin 链接表的附加功能尚未激活的问题
Aug 01 #PHP
PHP合并数组+与array_merge的区别分析
Aug 01 #PHP
PHP自定义函数收代码
Aug 01 #PHP
无法在发生错误时创建会话,请检查 PHP 或网站服务器日志,并正确配置 PHP 安装最快的解决办法
Aug 01 #PHP
PHP5中使用PDO连接数据库的方法
Aug 01 #PHP
PHP网站安装程序制作的原理、步骤、注意事项和示例代码
Aug 01 #PHP
You might like
Syphon 虹吸式咖啡壶冲煮–拨动法
2021/03/03 冲泡冲煮
Yii学习总结之数据访问对象 (DAO)
2015/02/22 PHP
PHP 实现类似js中alert() 提示框
2015/03/18 PHP
简单谈谈php浮点数精确运算
2016/03/10 PHP
PHP编程文件处理类SplFileObject和SplFileInfo用法实例分析
2017/07/22 PHP
Thinkphp 在api开发中异常返回依然是html的解决方式
2019/10/16 PHP
JavaScript 基于原型的对象(创建、调用)
2009/10/16 Javascript
node.js中的console用法总结
2014/12/15 Javascript
jquery图片播放浏览插件prettyPhoto使用详解
2014/12/19 Javascript
JavaScript插件化开发教程 (三)
2015/01/27 Javascript
Bootstrap导航中表单简单实现代码
2017/03/06 Javascript
微信小程序手机号码验证功能的实例代码
2018/08/28 Javascript
微信小程序之swiper滑动面板用法示例
2018/12/04 Javascript
微信小程序身份证验证方法实现详解
2019/06/28 Javascript
详解Vue3.0 + TypeScript + Vite初体验
2021/02/22 Vue.js
[49:05]OG vs Newbee 2019DOTA2国际邀请赛淘汰赛 胜者组 BO3 第二场 8.21.mp4
2020/07/19 DOTA
Python设计模式之代理模式实例
2014/04/26 Python
Python3 正在毁灭 Python的原因分析
2014/11/28 Python
python简单判断序列是否为空的方法
2015/06/30 Python
python模块之re正则表达式详解
2017/02/03 Python
python和flask中返回JSON数据的方法
2018/03/26 Python
Python实现ping指定IP的示例
2018/06/04 Python
Python3之不使用第三方变量,实现交换两个变量的值
2019/06/26 Python
python requests使用socks5的例子
2019/07/25 Python
python中web框架的自定义创建
2019/09/08 Python
pytorch三层全连接层实现手写字母识别方式
2020/01/14 Python
PyTorch之nn.ReLU与F.ReLU的区别介绍
2020/06/27 Python
让IE可以变相支持CSS3选择器
2010/01/21 HTML / CSS
HTML5页面嵌入小程序没有返回按钮及返回页面空白的问题
2020/05/28 HTML / CSS
Hunkemöller瑞士网上商店:欧洲最大的内衣品牌之一
2018/12/03 全球购物
学校采购员岗位职责
2014/01/02 职场文书
七一表彰活动方案
2014/01/18 职场文书
社团招新策划书
2014/02/04 职场文书
环保建议书500字
2014/05/14 职场文书
应收账款管理制度
2015/08/06 职场文书
高一语文教学反思
2016/02/16 职场文书