找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 1279|回复: 0

PHP性能优化

[复制链接]

304

主题

42

回帖

1348

积分

管理员

积分
1348
发表于 2021-4-16 18:09:17 | 显示全部楼层 |阅读模式
PHP-FPM进程和线程特点:
1.PHP-FPM是阻塞的单线程模型,PHP-FPM的每个进程只开启一个线程,一个线程同时只能服务一个请求。
2.服务进程内存使用统计:
ps aux |grep php-fpm|awk '{mem+=$6}END{print mem}'

进程池:
[www]

查看进程池:
ps -ef
#可看到www池中进程分配

进程守护者:
user = nginx
group = nginx
#建议与nginx进程守护者保持一致

监听端口:
listen = 127.0.0.1:9000

进程管理器核心优化:
{
        1.动态创建子进程:
        pm = dynamic

        2.最大子进程数:
        pm.max_children = 200 (默认5)
        #每开启一个php-fpm进程要占用近20M左右的内存,假设服务器内存为4G

        3.初始进程数:
        pm.start_servers = 80 (默认2)

        4.最小空闲进程数:
        pm.min_spare_servers = 40 (默认1)

        5.最大空闲进程数:
        pm.max_spare_servers = 120 (默认3)

        6.最大多少次请求后子进程重生:
        pm.max_requests = 10240
        #有效降低内存消耗
}

Nginx进程监控:
location /status {
   stub_status;
}

进程状态监控:
pm.status_path = /phpstatus
{
        1.nginx设置方法:
        location /phpstatus {
            fastcgi_index  index.php;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_param  SCRIPT_FILENAME $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }       

        2.客户端测试:
        http://192.168.2.1/phpstatus

        3.进程状态信息:
        pool: www                               # 进程池名称
        process manager: dynamic        # 进程管理方式
        start time: 22/Jan/2016:15:49:00 +0800 # 启动时间
        start since: 375                    # 运行时长
        accepted conn: 7                    # 当前进程池接受的请求数
        listen queue: 0                            # 请求等待队列,如果不为 0 ,意味着 FPM 进程不足,需要增加
        max listen queue: 0                  # 最大等待队列数量
        listen queue len: 1024                 # SOCKET 等待队列长度
        idle processes: 4                   # 空闲进程数
        active processes: 1                  # 活跃的进程数
        total processes: 5                   # 总进程数
        max active processes: 1                # 最大活跃进程数
        max children reached: 0                # 达到最大进程数的次数,如果不为 0 ,意味着最大进程数不足,需要增加
        slow requests: 0                    # 慢请求数量,需要设置 slow log
}

生成访问日志:
access.log = log/$pool.access.log

日志格式:
access.format = "%R - %u %t \"%m %r%Q%q\" %s %f %{mili}d %{kilo}M %C%%"

增加php-fpm打开文件数的限制:
rlimit_files = 65535

开启慢日志:
request_slowlog_timeout = 5
slowlog = log/$pool.log.slow

每个php-fpm进程的内存限制(php.ini):
memory_limit=128M

进程最大执行时间,与php.ini中max_execution_time作用相同(php.ini):
max_execution_time=30

重载配置文件:
pkill -USR2 php-fpm

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|外汇论坛 ( 粤ICP备16021788号 )

GMT+8, 2024-12-22 21:46 , Processed in 0.074960 second(s), 19 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表