一个人炫耀什么,说明内心缺少什么 [登录·注册]

吕滔博客

首页 开发 运维 工具 摄影

nginx+php-fpm性能参数优化原则

环境配置 memory 发布于May 9, 2014 标签: PHP, Nginx
1.worker_processes 越大越好(一定数量后性能增加不明显)
2.worker_cpu_affinity 所有cpu平分worker_processes 要比每个worker_processes 都跨cpu分配性能要好;不考虑php的执行,测试结果worker_processes数量是cpu核数的2倍性能最优
3.unix domain socket(共享内存的方式)要比tcp网络端口配置性能要好
不考虑backlog,请求速度有量级的飞跃,但错误率超过50%
加上backlog,性能有10%左右提升
4.
调整nginx、php-fpm和内核的backlog(积压),connect() to unix:/tmp/php-fpm.socket
failed (11: Resource temporarily unavailable) while connecting to
upstream错误的返回会减少
nginx:
配置文件的server块
listen 80 default backlog=1024;
php-fpm:
配置文件的
listen.backlog = 2048
kernel参数:
/etc/sysctl.conf,不能低于上面的配置
net.ipv4.tcp_max_syn_backlog = 4096
net.core.netdev_max_backlog = 4096
5.增加单台服务器上的php-fpm的master实例,会增加fpm的处理能力,也能减少报错返回的几率
多实例启动方法,使用多个配置文件:
/usr/local/php/sbin/php-fpm -y /usr/local/php/etc/php-fpm.conf &
/usr/local/php/sbin/php-fpm -y /usr/local/php/etc/php-fpm1.conf &
nginx的fastcgi配置
   upstream phpbackend {
#    server  127.0.0.1:9000 weight=100 max_fails=10 fail_timeout=30;
#    server  127.0.0.1:9001 weight=100 max_fails=10 fail_timeout=30;
#    server  127.0.0.1:9002 weight=100 max_fails=10 fail_timeout=30;
#    server  127.0.0.1:9003 weight=100 max_fails=10 fail_timeout=30;
    server  unix:/var/www/php-fpm.sock weight=100 max_fails=10 fail_timeout=30;
    server  unix:/var/www/php-fpm1.sock weight=100 max_fails=10 fail_timeout=30;
    server  unix:/var/www/php-fpm2.sock weight=100 max_fails=10 fail_timeout=30;
    server  unix:/var/www/php-fpm3.sock weight=100 max_fails=10 fail_timeout=30;
#    server  unix:/var/www/php-fpm4.sock weight=100 max_fails=10 fail_timeout=30;
#    server  unix:/var/www/php-fpm5.sock weight=100 max_fails=10 fail_timeout=30;
#    server  unix:/var/www/php-fpm6.sock weight=100 max_fails=10 fail_timeout=30;
#    server  unix:/var/www/php-fpm7.sock weight=100 max_fails=10 fail_timeout=30;
   }
     location ~ \.php* {
       fastcgi_pass  phpbackend;
#      fastcgi_pass  unix:/var/www/php-fpm.sock;
       fastcgi_index index.php;
    ..........
    }
6.测试环境和结果
内存2G
swap2G
cpu 2核 Intel(R) Xeon(R) CPU E5405  @ 2.00GHz
采用ab远程访问测试,测试程序为php的字符串处理程序
1)
在开4个php-fpm实例,nginx 8个worker_processes 每个cpu4个worker_processes
,backlog为1024,php的backlog为2048,内核backlog为4096,采用unix domain
socket连接的情况下,其他保持参数不变
性能和错误率较为平衡,可接受,超过4个fpm实例,性能开始下降,错误率并没有明显下降
结论是fpm实例数,worker_processes数和cpu保持倍数关系,性能较高
影响性能和报错的参数为
php-fpm实例,nginx worker_processes数量,fpm的max_request,php的backlog,unix domain socket
10W请求,500并发无报错,1000并发报错率为0.9%
500并发:
Time taken for tests:  25 seconds avg.
Complete requests:    100000
Failed requests:     0
Write errors:      0
Requests per second:   4000 [#/sec] (mean) avg.
Time per request:    122.313 [ms] (mean)
Time per request:    0.245 [ms] (mean, across all concurrent requests)
Transfer rate:      800 [Kbytes/sec] received avg.
1000并发:
Time taken for tests:  25 seconds avg.
Complete requests:    100000
Failed requests:     524
  (Connect: 0, Length: 524, Exceptions: 0)
Write errors:      0
Non-2xx responses:    524
Requests per second:   3903.25 [#/sec] (mean)
Time per request:    256.197 [ms] (mean)
Time per request:    0.256 [ms] (mean, across all concurrent requests)
Transfer rate:      772.37 [Kbytes/sec] received
2)在其他参数不变,unix domain socket换为tcp网络端口连接,结果如下
500并发:
Concurrency Level:    500
Time taken for tests:  26.934431 seconds
Complete requests:    100000
Failed requests:     0
Write errors:      0
Requests per second:   3712.72 [#/sec] (mean)
Time per request:    134.672 [ms] (mean)
Time per request:    0.269 [ms] (mean, across all concurrent requests)
Transfer rate:      732.37 [Kbytes/sec] received
1000并发:
Concurrency Level:    1000
Time taken for tests:  28.385349 seconds
Complete requests:    100000
Failed requests:     0
Write errors:      0
Requests per second:   3522.94 [#/sec] (mean)
Time per request:    283.853 [ms] (mean)
Time per request:    0.284 [ms] (mean, across all concurrent requests)
Transfer rate:      694.94 [Kbytes/sec] received
与1)比较,有大约10%的性能下降
7. 5.16调整fpm的max_request参数为1000,并发1000报错返回降到200个以下,
Transfer rate在800左右

相关推荐

添加新评论

全部评论:暂无评论

  1. onepx

    那么多并发用的什么工具呢?apache这边的ab只能用到cpu的一个核心,并发多了,ab占cpu为一个单核的100%,这时候不管服务器参数怎么调,ab这边的机器不行了啊...

    1. Memory

      @onepx:webbench http://www.lvtao.net/tool/webbench.html

  2. Memory

    可以继续调!max_request 主要是为了防止内存泄露用的,500很保守,因为并发访问量大是,每次进程回收都会导致很多的502,这是一个重要来源。fpm将max_request参数调整为2000, 报错率在0.2%以内,速度有所提升

网站状态

  • 栏目分类:49个
  • 发布文章:1541篇
  • 用户评论:787条
  • 开博至今:4192天

正则速查

[abc] 匹配中括号中的单个字符,如a或b或c
[^abc] 匹配除了a、b、c等字符的其他单个字符
[a-z] 匹配一个字符范围,如a到z
[a-zA-Z] 匹配一个字符范围,如a-z 或 A-Z
^ 匹配行的开始
$ 匹配行的结束
\A 匹配一个字符串的开始
\z 匹配一个字符串的结束
. 匹配任意单个字符
\s 匹配空白字符,如空格,TAB
\S 匹配非空白字符
\d 匹配一个数字
\D 匹配非数字
\w 匹配一个字母
\W 匹配非字母
\b 匹配字符边界
(...) 引用所有括号中的内容
(a|b) a或者b
a? 零个或1个a
a* 零个或多个a
a+ 1个或多个a
a{3} 3次重复的a
a{3,} 3次或3次以上重复的a
a{3,6} 3到6次重复的a

修正符

/g 查找所有可能的匹配
/i 不区分大小写
/m 多行匹配
/s 单行匹配
/x 忽略空白模式
/e 可执行模式,PHP专有
/A 强制从目标字符串开头匹配
/D 使用$限制结尾字符,则不允许结尾有换行
/U 只匹配最近的一个字符串;不重复匹配

最新回复

  • memory: 这是测试,不建议正式环境这样使。
  • 广州网站建设: 构建redis集群时候,不要使用生产环境
  • memory: 照着大差不着的改一下就成了rewrite ^/sort/([0-...
  • mage: 按照上面设置的伪静态url是类似这种形式的 /listinfo-...
  • mage: 比如这种URL:帝国7.5伪静态如何可以做到这种形式(拼音或者英...
  • memory: 额,难住我了,哈哈。我项目中没有用过这么复杂的。
  • 马哥: 请问如何设置目录名是拼音,然后文章页在目录下面的伪静态
  • memory: conf文件中location段加上规则就可以了呀。然后relo...
  • mage: 后台系统设置,设置好了。规则应该怎么处理,nginx的服务器
  • 葛一速: 这个函数很实用,谢谢分享
  • memory: 这个是layui1.x中的,我项目中就是这样用的。如果你没理解,...
  • 李帅: 你会不会的 发这个糊弄人
  • memory: 升级完之后,测试无误后再删旧的~~~
  • 广州网站建设: 升级之前用不用先删了内核
  • memory: 没测试过...
  • 欧文斯: 对于多个 IP 段呢?比如超过 1000 个 IP 段,匹配速度...
  • 广州网站建设: 了解了,博客的通配符HTTPS证书