记一次php优化案例

                                        记一次php优化案例

网站架构简介:

现在很多的企业都是使用lnmp或者lamp来做企业的网站服务器架构,这两种网站的服务架构,我们都是比较熟悉的;基于nginx的性能优于Apache,现阶段的很多公司,都是逐渐把Apache替换成nginx,毕竟nginx的自带的高可用配置,反向代理等等功能相当突出。

Lnmp网站服务器架构,其实就是linx+nginx+mysql+php架构体系,架构安装我就不多说了。接下来我们来谈谈,我遇到案例吧

 

案例:

有一天,后台的同事,说后台访问很慢,而且有时候出现502错误。然后反馈给技术上级,接着又找到我处理一下(那时在喝着茶),然后我知道又有事干了。

分析:

然后我直接找到那个同事,问问是不是网络原因啊,我也叫其他的同事,访问一下,还是出现访问忙的问题。这时我就知道事情没那么简单了。公司应用的是lnmp网站服务器架构,以前没有做太多的优化,接下来我们需要优化网站的服务架构了

一、案例分析。

我们可以想到,既然是访问缓慢,有时候直接访问不了,以前是没问题的,到现在就突然出现了问题,那必定是我们的nginx与php响应不过来导致的,原因可能是其他域名网站的用户连接数巨增导致的。那我们找到问题的根源解决并优化就可以了。接着凭着自己的经验与百度,去解决问题。

二、问题解决与过程分析

1Nginx优化:  

 1、查看nginx的日志,找出错误

$ cat /usr/local/nginx/logs/error.log | grep error

没发现错误,正常

查看后台域名的access.logs

$ cat /var/log/access_nging.log | grep error

(这里没及时截到图,日志是被刷了,本地做了日志切割,并定时删除了)

发现日志日志里面可以找到error错误信息,并且有十几个502错误。找到出现的问题了。

2、问题分析以及nginx优化

1、nginx打开文件数限制导致的。

1)、首先我们想到可能的原因nginx的打开文件书的问题,增加nginx的打开文件数

进入nginx配置文件,发现打开文件数为4096,果不其然,打开文件数没有调到最佳,可能是这个原因导致的。我们需要把4096改为51200;保存重新加载nginx

# vim /usr/local/nginx/conf/nginx.conf

worker_rlimit_nofile 51200;

events {

worker_connections 51200;

}

#service nginx relaod

2)、Linux系统文件限制

我们改了nginx的打开文件配置,不一定有用,我们需要看一下系统的限制的打开文件数

# ulimit –n

我们可以看到系统的文件打开数量也是4096,接下来,我们更改一下系统的打开文件数,并配置永久生效。

进入配置文件

# vim /etc/security/limits.conf

更改参数:

* soft nofile 65535

* hard nofile 65535

* soft nproc 65535

* hard nproc 65535

注:系统限制可以随便改,我只要比nginx的打开文件数大就好。

3nginxfastcgi连接时间太短导致的。

一般nginx响应php,都是通过FastCGI接口来调用,所以fastcgi参数配置很重要,当HTTP服务器每次遇到动态程序时,可以将其直接交付给FastCGI进程来执行,然后将得到的结果返回给浏览器,而很多php的网页都是采用动态程序。所以fastcgi的配置,也起的至关重要的作用。所以这是一个优化不可缺少的一部分。

进入nginx.conf配置文件

# vim /usr/local/nginx/conf/nginx.conf

把fastcgi的connect、send、read的参数的时间改成300,配置如下:

重新加载nginx

#service nginx reload

4、访问域名测试。

重新访问域名,发现网页已经加载出来了,持续访问了几次,发现访问还是有点慢,虽然访问稳定了。到这里,我们就可以把问题指向到php里面了,继续下一步的php优化。

2、Php优化:

 1、查看php日志

首先,我们需要跟nginx的操作一样,需要先查看一下日志。

#tail -n 100 /usr/local/php/var/log/php-fpm.log

在日志里面我们可以发现,php日志出现警告

WARNING: [pool www] seems busy (you may need to increase pm.start_servers, or pm.min/max_spare_servers)

从告警的意思,我们知道php出现告警了,而且是叫我们增加php的,pm.start_servers, or pm.min/max_spare_servers的值。

2、原因分析

首先我们,看到日志只是出现这个警告,证明还不是很严重,至于为什么出现这个警告,接下来我们一起分析一下。

首先我们很明确的知道,pm.start_servers,、pm.min/max_spare_servers在php里面是起着啥作用先,为什么会出现这个警告。我先把的以前的配置参数贴一下。

接下来我们分析一下这几个参数的作用:

参数分析:

  • pm= dynamic  表示php启用的动态模式  注: php有动态和静态(static)两种工作模式,默认是动态模式。
  • pm.max_children      表示静态下最大线程数
  • pm.start_servers      表示动态下启动时的线程数,该参数大于pm.min_spare_servers,小于pm.max_spare_servers
  • pm.min_spare_servers      表示动态下最小空闲线程数
  • pm.max_spare_servers      表示动态下最大空闲线程数

工作模式:

Static模式

当工作模式设置为静态后,就只有pm.max_children项有效,即表示php-fpm工作时一直保持的线程数。

Dynamic 模式

动态模式下,与他相关的参数有pm.start_servers、pm.min_spare_servers 、pm.max_spare_servers,分别表示开启的php进程数,最小的进程数、与最大的进程数。

模式比较:

静态模式的话,比较适合一些内存比较大一点的服务器,8G及以上的,因为对于比较大内存的服务器来说,设置为静态的话会提高效率。

动态模式适合小内存机器,灵活分配进程,省内存。可以让php自动增加和减少进程数,不过动态创建回收进程对服务器也是一种消耗。

 3、php参数优化

    

首先我们需要考虑一下问题,如何去调试参数,达到优化的目的呢,一般来说开始的时候一个php-fpm进程只占用3M左右内存,但是运行一段时间后就会上升到20-40M,这是因为PHP程序在执行完成后,或多或少会产生内存的泄露。

所以按理来说php的最大的进程数,大概是本地内存/40,因为也要考虑系统占用内存的的这种情况,我们不能直接把除处理的结果,当成的最大进程数,不然你会死翘翘的。

我的服务器是8G内存的,所以按理来说是,最大的php进程数是200左右,所以按这个参数我做了一下调整:

采用静态模式,最大进程数设为125-150之间,搞定。

重新加载php

#service php-fpm relod

查看进程数:

# netstat -anpo | grep php-fpm | wc -l
128

效果达到了

4、结果

重新访问,发现访问php页面快了很多,查看日志,没出现告警了,后台访问也好了。

 3、压测

一个网站的性能好不好,承受量有多高,这个我们可以通过压测去,去获取数据,我这里简单介绍ab工具来做压测,用法如下

ab -n 1000000   -c 10000  http://域名/test.php (一个php文件)

-n参数表示 你压力测试 总量

-c参数表示 你的模拟的并发用户数

Ab压力测试工具,是apache自带的,用起来也方便,只要本地有,就可以远程测你的服务器的性能了。个人觉得还是可以了,下面是模拟一千个用户访问100000次的结果,但然你自己压测的时候,慢慢的提升参数,测试你的网站的瓶颈。

还有分享一下,下面是一个网站性能工具分析网址,你可以贴一下你的域名,进行评分

http://www.mmtrix.com/evaluate/result?popup=true

三、总结

  问题并不难解决,难的是你没有思考过,一次个人php优化经历,互相学习。

原文地址:http://blog.51cto.com/xiaozhagn/2136667

时间: 2024-07-28 23:18:12

记一次php优化案例的相关文章

记一次mysql多表查询(left jion)优化案例

一次mysql多表查询(left jion)优化案例 在新上线的供需模块中,发现某一个查询按钮点击后,出不来结果,找到该按钮对应sql手动执行,发现需要20-30秒才能出结果,所以服务端程序判断超时,故先不显示结果 以下是对这条查询的优化记录 1 数据库配置 数据库配置:4C8G 主表数据:3W+ 2 sql语句 提取sql语句,简化如下 SELECT taba.id, taba.title, taba.type, taba.end_time, tabb.username, tabc.orgna

大型电商互联网性能优化案例

大型电商互联网性能优化案例 理论基础 The Theory 平台设计 Platform Design 业务结果 Business Impact 双11优化 架构思考 Architecture Takeaways   ----------------------------------------------------------------------------------------------------------------------------------------------

Adwords 账户优化案例

案例一:目前账户展示系列的简单调整. 目前账户展示系列存在的问题:关键字定位不准确. 可以考虑上下游相关的产品关键字添加到账户,如产品主要用于哪里,添加的关键字要跟你的定位的主题相对应,比如你定位的是电子电机,添加的关键字就可以是winding wire transformer,magnet wire generator等,相应的广告语也要更改,更改成winding wire for transformer,magnet wire for generator等. 要记得展示广告匹配展示位的规则:

[Oracle] enq: TX - row lock contention 优化案例

根据开发反馈,最近每天早上7:30应用会报警,应用的日志显示数据库连接池满了,新的连接被拒绝. 首先,我做了ASH报告(报告区间:7:25 ~ 7:35),从ASH的等待事件发现enq: TX - row lock contention居然高达76.54%,如下所示: Top User Events Event Event Class % Event Avg Active Sessions enq: TX - row lock contention Application 76.54 0.81

基于Web应用的性能分析及优化案例

一. 基于动态内容为主的网站优化案例 1.网站运行环境说明硬件环境:1台IBM x3850服务器, 单个双核Xeon 3.0G CPU,2GB内存,3块72GB SCSI磁盘.操作系统:CentOS5.4.网站架构:Web应用是基于LAMP架构,所有服务都在一台服务器上部署.2.性能问题现象及处理措施   现象描述网站在上午10点左右和下午3点左右访问高峰时,网页无法打开,重启服务后,网站能在一段时间内能正常服务,但过一会又变得响应缓慢,最后网页彻底无法打开.   检查配置首先检查系统资源状态,

清算/报表/日终跑批程序之性能优化案例(一)

前言 不知不觉,技术人生系列·我和数据中心的故事来到了第五期.小y又和大家见面了! 前几期主要发了一些TroubleShooting的案例分享,其实小y最擅长的是性能优化,所以从这期开始,小y会陆续的分享更多的数据库性能优化案例. 进入正题,如果您的日终跑批/清算/报表等程序时快时慢,或者从某一天以后就一直变慢,作为运维DBA或开发的您,会怎么下手?还有,除了解决问题外,你要如何解答领导最关心的一个问题,"为什么现在有问题,但是以前没有问题呢"! 小y今天要和大家分享的就是这样一个性能

mysql优化案例

MySQL优化案例 Mysql5.1大表分区效率测试 Mysql5.1大表分区效率测试MySQL | add at 2009-03-27 12:29:31 by PConline | view:60, comment:0 mysql5.1开始支持数据表分区了,原来的分表可以不用了,分表的不足在于多表查询不方便.呵呵,下面来简单测试下表分区的查询效率. 1.用来测试的数据为discuz论坛的数据库,表为cdb_posts表,数据量为1500多万条mysql> select count(*) fro

第十天内容《基础交换十》STP优化案例

STP优化案例   案例1:配置 access PortFast 特性   实验名称:STP PortFast 实验拓扑: 实验需求:       1.交换机1.2.3互联,配置互联链路为 Trunk :         2.配置 SW1 为 根交换机 :         3.连接 PC-2 到 SW2 的 Fas0/1         4.配置 PortFast特性,确保 PC-2 可以快速与交换机互通:         实验步骤:       1.配置交换机之间的互联链路为 Trunk  

数据库优化案例——————某知名零售企业ERP系统

写在前面 记得在自己学习数据库知识的时候特别喜欢看案例,因为优化的手段是容易掌握的,但是整体的优化思想是很难学会的.这也是为什么自己特别喜欢看案例,今天也分享自己做的优化案例. 之前分享过OA系统.HIS系统,今天我们来一个最常见的ERP,ERP系统各行各业都在用,不同行业也有不同的特点,博主在做研发的时候还自己写过ERP也算是比较熟悉了. 不管是本文分享的零售类,还是鞋服门店.家居.汽车.地产等等,也不管是某友.某碟,ERP有一个共同的特点,单据流程长,业务复杂,热点表明显,数据量大,涉及众多