- 浏览: 2557767 次
- 性别:
- 来自: 深圳
-
文章分类
- 全部博客 (676)
- linux运维 (157)
- php (65)
- mysql (78)
- nginx (27)
- apche (18)
- framework (6)
- windows (9)
- IDE工具 (23)
- struts2 (7)
- java (13)
- 移动互联网 (14)
- memcache redis (23)
- shell基础/命令/语法 (37)
- shell (50)
- puppet (4)
- C (11)
- python (9)
- 产品经理 (27)
- Sphinx (4)
- svn (12)
- 设计构建 (12)
- 项目管理 (44)
- SEO (1)
- 网站架构 (26)
- 审时度势 (42)
- 网络 (14)
- 激发事业[书&视频] (81)
- 其它 (12)
- 摄影 (8)
- android (21)
最新评论
-
zhongmin2012:
原文的书在哪里
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
renzhengzhi:
你好,请问个问题,从master同步数据到slave的时候,s ...
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
ibc789:
你好,看了你的文章,我想请教个问题, 我在用 redis的时候 ...
redis 的两种持久化方式及原理 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器
http://www.linuxidc.com/Linux/2011-05/35346.htm
-----------------------开启php-fpm慢脚本日志
request_slowlog_timeout = 30s
slowlog = /usr/local/php/var/log/php-fpm.log.slow
典型的日志内容如下:
[15-Apr-2012 20:56:19] [pool www] pid 9748
script_filename = /var/www/html/htdocs/www.xxx.com/xxx.php
[0x00000000090bc270] file_get_contents() /var/www/html/htdocs/www.xxx.com/xxx.php:81
慢脚本文件、具体行数、函数等都很详细的记录了,优化工作相对来说就容易的多。
request_terminate_timeout = 120
#表示等待120秒后,结束那些没有自动结束的php脚本,以释放占用的资源。
当PHP运行在php-fpm模式下,php.ini配置的max_execute_time是无效的,需要在php-fpm.conf中配置另外一个配置项:request_terminate_timeout;以下是官方文档的说明:
request_terminate_timeout – The timeout (in seconds) for serving a single request after which the worker process will be terminated. Should be used when ‘max_execution_time’ ini option does not stop script execution for some reason. Default: “5s”. Note: ’0s’ means ‘off’
注意:set_time_limit()和max_execution_time只影响脚本本身执行的时间。任何发生在诸如使用system()的系统调用,流操作,数据库操作等的脚本执行的最大时间不包括其中.
[global]
pid = /dev/shm/pid/php-fpm.pid
error_log = /usr/local/php/var/log/php-fpm.log
log_level = notice
[www]
listen = 127.0.0.1:9000
;listen.allowed_clients = 192.168.1.17,127.0.0.1,192.168.1.75
user = www
group = www
pm = dynamic
pm.max_children = 2000
pm.start_servers = 10
pm.min_spare_servers = 5
pm.max_spare_servers = 200
pm.max_requests = 12000
pm.process_idle_timeout = 10s
request_terminate_timeout = 120
request_slowlog_timeout = 30s
slowlog = /usr/local/php/var/log/php-fpm.log.slow
这里先说一下涉及到这个的几个参数,他们分别是pm、pm.max_children、pm.start_servers、pm.min_spare_servers和pm.max_spare_servers。
pm表示使用那种方式,有两个值可以选择,就是static(静态)或者dynamic(动态)。在更老一些的版本中,dynamic被称作apache-like。这个要注意看配置文件的说明。
下面4个参数的意思分别为:
pm.max_children:静态方式下开启的php-fpm进程数量。
pm.start_servers:动态方式下的起始php-fpm进程数量。
pm.min_spare_servers:动态方式下的最小php-fpm进程数量。
pm.max_spare_servers:动态方式下的最大php-fpm进程数量。
如果dm设置为static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量的php-fpm进程。
如果dm设置为 dynamic,那么pm.max_children参数失效,后面3个参数生效。
系统会在php-fpm运行开始 的时候启动pm.start_servers个php-fpm进程,
然后根据系统的需求动态在pm.min_spare_servers和 pm.max_spare_servers之间调整php-fpm进程数。
那么,对于我们的服务器,选择哪种执行方式比较好呢?事实上,跟Apache一样,运行的PHP程序在执行完成后,或多或少会有内存泄露的问题。
这也是为什么开始的时候一个php-fpm进程只占用3M左右内存,运行一段时间后就会上升到20-30M的原因了。
对于内存大的服务器(比如8G以上)来说,指定静态的max_children实际上更为妥当,因为这样不需要进行额外的进程数目控制,会提高效 率。
因为频繁开关php-fpm进程也会有时滞,所以内存够大的情况下开静态效果会更好。数量也可以根据 内存/30M 得到,比如8GB内存可以设置为100,
那么php-fpm耗费的内存就能控制在 2G-3G的样子。如果内存稍微小点,比如1G,那么指定静态的进程数量更加有利于服务器的稳定。
这样可以保证php-fpm只获取够用的内存,将不多的 内存分配给其他应用去使用,会使系统的运行更加畅通。
对于小内存的服务器来说,比如256M内存的VPS,即使按照一个20M的内存量来算,10个php-cgi进程就将耗掉200M内存,那系统的崩 溃就应该很正常了。
因此应该尽量地控制php-fpm进程的数量,大体明确其他应用占用的内存后,给它指定一个静态的小数量,会让系统更加平稳一些。或者使用动态方式,
因为动态方式会结束掉多余的进程,可以回收释放一些内存,所以推荐在内存较少的服务器或VPS上使用。具体最大数量根据 内存/20M 得到。
比如说512M的VPS,建议pm.max_spare_servers设置为20。至于pm.min_spare_servers,则建议根据服 务器的负载情况来设置,比较合适的值在5~10之间。
============================= 127.0.0.1监听本机ip
php-fpm.conf
listen = 127.0.0.1:9000
nginx.conf
location ~ ^(.+\.php)(.*)$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fcgi.conf;
}
发表评论
-
设置sudo为不需要密码
2015-04-17 09:04 10546有时候我们只需要执 ... -
nginx access_log 完全关闭
2015-04-14 14:40 31854最近在配置本地nginx开 ... -
haproxy 安装配置和负载实例
2015-03-27 11:49 11557一、环境说明实验环境 OS CentOS5.4 192.1 ... -
/dev/mapper/VolGroup00-LogVol00 100% 如何处理
2015-03-03 10:51 8264服务器磁盘跑满了, 命令查看 如下 [root@lo ... -
nginx 404会执行302跳转
2014-08-29 15:38 6065这个问题是应用中比较常见的一个问题了。尤其是对于静态文件, ... -
Tsar开源:淘宝内部大量使用的系统监控工具
2014-08-07 09:51 1003Tsar是淘宝的一个用来收集服务器系统和应用信息的采集报告 ... -
nginx配备中proxy_redirect的作用
2014-07-21 15:36 0http://www.docin.com/p-2925119 ... -
nginx配备中proxy_redirect的作用
2014-07-21 15:36 2689http://www.docin.com/p-292511 ... -
wamp 升级php apache mysql
2014-02-18 14:30 1226wamp对于日常开发来说会增添非常大的方便 但是对于集成 ... -
Linux运维常用命令 (转载)
2013-01-31 10:23 25581 删除0字节文件find-type f - ... -
linux恢复 rm -rf 删除的文件:extundelete
2013-01-24 15:47 8955http://blog.csdn.net/pang6013 ... -
网站排障分析常用的命令
2013-01-21 18:17 1423------------------------------- ... -
迁移vmware服务器后Device eth0 does not seem to be present
2013-01-21 10:58 2277用VMware 安装 linux 6.0 ... -
LoadRunner如何监控Linux系统资源 : rpc.rstatd
2012-12-17 14:49 10334一 简述:LoadRunner监控Linux资源时弹出如下错误 ... -
僵尸Z进程和D进程
2012-12-10 16:47 13193-------------- 1 关于ZOMBIE进 ... -
Unix操作系统硬链接与符号链接的区别
2012-12-10 16:08 2049Unix操作系统有很多值得 ... -
nagios配置参数详解
2012-12-04 14:12 9480# Nagios return codes#定 ... -
nagios自定义监控nginx php和ip_conn
2012-12-03 17:57 3195自定义ip_conn.sh :http://zhume ... -
【汇总】shell show收藏
2012-11-29 14:03 1315================== shell从文本取对应的 ... -
Kickstart+PXE+DHCP+TFTP+NFS自动安装Centos5
2012-11-29 11:34 1625http://5ydycm.blog.51cto.com/11 ...
相关推荐
为了优化代码,我们常常需要查找执行缓慢的脚本和函数。幸运的是,PHP提供了一些工具来帮助我们跟踪和定位这些性能瓶颈。其中之一就是php-fpm慢执行日志,它类似于MySQL的慢查询日志(slowquerylog)。 php-fpm慢...
在本文中,我们将深入探讨如何在...- PHP常见数据库操作技巧汇总:优化数据库查询以适应多线程环境。 通过以上步骤和相关资源,你应该能成功在CentOS 7上安装和配置PHP pthreads v3,并进一步探索多线程编程的世界。
2. PHP配置优化:如何调整php.ini设置以提高性能,如内存限制、错误报告级别等。 3. PHP CLI与FPM:理解PHP的命令行接口和FastCGI进程管理器的区别与应用场景。 通过这份【韩顺平PHP面试题大全(整理汇总)】,开发者...
- **PHP-FPM监控**:可以借鉴现有的PHP-FPM监控模板和脚本案例,对其进行适当的调整以适应自身业务的具体需求。 - **MySQL监控**:为了监控MySQL服务器的状态,可以考虑建立一个临时数据库来存储各种监控指标,然后...
18. **服务器配置**:基本的Apache或Nginx配置,以及PHP-FPM的使用。 19. **版本控制**:Git的使用,包括分支管理、合并、解决冲突等。 20. **性能监控和分析**:使用工具如New Relic、XHProf进行性能监控和代码...
这份文档可能会讲解如何安装Apache或Nginx服务器,配置PHP解析器(如PHP-FPM),以及设置MySQL数据库,形成LAMP或LNMP环境。此外,它还可能涵盖如何调试PHP代码和优化服务器性能。 "常用类及函数.html"和"常用函数...
在DevOps实践中,监控数据的展示应具备汇总能力,例如,聚合所有Nginx、php-fpm、网络和CPU数据,以及逻辑出口和IDC物理层面的信息。此外,还需要监控调用逻辑(APM)和开放及内部接口的状态,以便全面了解系统健康...