この記事では、Linux で php-fpm プロセスが多すぎることによって引き起こされるメモリ不足の問題を解決する方法を主に紹介します。php-fpm について詳しく知りたい場合は、この記事を参照して解決方法を学ぶことができます。 php-fpmプロセスのオーバーフローの問題 メモリ不足の原因はたくさんあります。
最近、個人ブログの Linux サーバーとデータベース サービスが頻繁にハングアップし、通常のアクセスの前に再起動が必要になることがわかりました。それは非常に不快だったので、問題の解決を開始して時間とエネルギーを解放することにしました。頻繁に問題が発生することは避けたいので、手動で再起動する必要がありますが、手間と時間がかかります)。
問題を分析する
問題を発見したら、まず free -m
コマンドを使用して現在のサーバーの実行ステータスを確認します: free -m
指令查看当前服务器执行状况:
可以看到我的服务器内存是2G的,但是目前可用内存只剩下70M,内存使用率高达92%,很有可能是内存使用率过高导致数据库服务挂断。
继续看详细情况,使用 top
指令:
然后再看指令输出结果中详细列出的进程情况,重点关注第10列内存使用占比:
发现CPU使用率不算高,也排除了CPU的问题,另外可以看到数据库服务占用15.2%的内存,内存使用过高时将会挤掉数据库进程(占用内存最高的进程),导致服务挂断,所以我们需要查看详细内存使用情况,是哪些进程耗费了这么多的内存呢?
使用指令:
ps auxw|head -1;ps auxw|sort -rn -k4|head -40
查看消耗内存最多的前40个进程:
查看第四列内存使用占比,发现除了mysql数据库服务之外,php-fpm服务池开启了太多子进程,占用超过大半内存,问题找到了,我们开始解决问题:设置控制php-fpm进程池进程数量。
解决问题
通过各种搜索手段,发现可以通过配置 pm.max_children
属性,控制php-fpm子进程数量,首先,打开php-fpm配置文件,执行指令:
vi /etc/php-fpm.d/www.conf
找到 pm.max_children
字段,发现其值过大:
如图, pm.max_children
值为50,每一个进程占用1%-2.5%的内存,加起来就耗费大半内存了,所以我们需要将其值调小,博主这里将其设置为25,同时,检查以下两个属性:
pm.max_spare_servers
: 该值表示保证空闲进程数最大值,如果空闲进程大于此值,此进行清理 pm.min_spare_servers
: 保证空闲进程数最小值,如果空闲进程小于此值,则创建新的子进程;
这两个值均不能不能大于 pm.max_children
值,通常设置 pm.max_spare_servers
值为 pm.max_children
引き続き詳細を確認するには、top
コマンドを使用します:
CPU 使用率は高くないことがわかり、CPU の問題は除外されます。また、データベース サービスは、メモリの 15.2% を占有していることがわかります。メモリ使用量が高すぎると、データベース プロセス (最も多くのメモリを消費するプロセス) が混雑してサービスがハングアップするため、詳細を確認する必要があります。どのプロセスが多くのメモリを消費しますか?
使用コマンド:
systemctl restart php-fpm
最も多くのメモリを消費する上位 40 のプロセスを表示:
問題を解決する
さまざまな検索手段を通じて、次のことを見つけることができますpm.max_children
属性 を設定して PHP を制御できること-fpm 子プロセスの数量を指定するには、まず php-fpm設定ファイルを開き、次のコマンドを実行します。
pm.max_children
フィールドを見つけて、その値が大きすぎることがわかりました:
pm.max_children
の値は 50 です。各プロセスは 1% ~ 2.5 を占めます。合計するとメモリの半分以上になるので、このブロガーはこれを 25 に設定します。同時に、次の 2 つのプロパティを確認します:
pm .max_spare_servers
: この値は、アイドル プロセスの保証される最大数を示します。アイドル プロセスがこの値より大きい場合は、クリーンアップします。 pm.min_spare_servers
: アイドル プロセスの最小数を保証します。アイドル プロセスがこの値より小さい場合は、新しい子プロセスを作成します。 🎜🎜 これら 2 つの値はいずれも使用できません。通常、pm.max_children
値より大きくすることはできません。 pm.max_spare_servers
の値は、pm.max_children
の値の 60% ~ 80% に設定されます。 🎜🎜最後に、php-fpmを再起動します🎜🎜🎜🎜ps -fe |grep "php-fpm"|grep "pool"|wc -l🎜🎜🎜🎜再度メモリ使用量を確認すると、メモリ使用量が大幅に減少しています:🎜🎜🎜🎜🎜 何度もメモリ使用量を観察した結果、この後改善により、サーバーのメモリ リソースの消費が大幅に軽減されます。 🎜🎜🎜🎜 ps: php-fpm によって開始されたプロセスの数と各プロセスのメモリ制限を確認します🎜🎜🎜🎜1. コマンドを使用して、サーバー上で開かれている php-cgi プロセスの数を確認します🎜🎜🎜🎜
netstat -anp|grep "php-fpm"|grep "tcp"|grep "pool"|wc -l🎜🎜🎜🎜 2. TCP リクエストの処理に使用される php-cgi プロセスの数を確認します🎜🎜🎜🎜🎜rrreee🎜🎜🎜🎜 3. linux+nginx+php 環境で、各 php-fpm プロセスのメモリ制限を設定します。 🎜🎜🎜🎜 方法: 🎜🎜🎜🎜 php-fpm.conf 設定ファイルを編集します🎜
php_admin_value[memory_limit] = 128M (サーバー上の設定ファイルは /etc/php5/fpm/pool.d/www.conf にあります。このファイルは php-fpm.conf に含まれています) 以下の数値は任意に変更できます: 32M、64M、128M、256M、512M、この設定はサーバーのメモリサイズとニーズに応じて書き込むことができます。変更後、php-fpm サービスをロードする必要があります。
概要
上記は、Linux での php-fpm プロセスが多すぎることによって引き起こされるメモリ枯渇の問題を解決するために編集者が紹介したものです。皆様のお役に立てれば幸いです。関連する推奨事項:php-fpmのステータス統計をオンにする方法php-fpm
introducingソリューションで説明されているコード共有Php-fpmメモリ使用量を減らす
以上がLinux_php の例で php-fpm プロセスが多すぎることによって引き起こされるメモリ枯渇の問題を解決するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。