Home >Backend Development >PHP Tutorial >Detailed explanation of php-fpm startup parameter configuration

Detailed explanation of php-fpm startup parameter configuration

WBOY
WBOYOriginal
2016-07-25 09:13:051020browse

You need to agree on several directories

  1. #Test php-fpm configuration
  2. /usr/local/php/sbin/php-fpm -t
  3. /usr/local/php/sbin/php-fpm -c /usr/local/php/etc /php.ini -y /usr/local/php/etc/php-fpm.conf -t
  4. #Start php-fpm
  5. /usr/local/php/sbin/php-fpm
  6. /usr/local/php/ sbin/php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf
  7. #Close php-fpm
  8. kill -int `cat /usr /local/php/var/run/php-fpm.pid`
  9. #Restart php-fpm
  10. kill -usr2 `cat /usr/local/php/var/run/php-fpm.pid`
Copy code

Second, detailed explanation of important parameters of php-fpm.conf

  1. $ctx = stream_context_create(array(
  2. 'http' => array(
  3. 'timeout' => 10 //Set a timeout in seconds
  4. )
  5. ));
  6. file_get_contents( $str, 0, $ctx);
Copy code

2, improper configuration of the max_requests parameter may cause intermittent 502 errors: pm.max_requests = 1000 Sets the number of requests served before each child process is reborn. Useful for third-party modules that may have memory leaks. If set to '0', requests are always accepted. Equivalent to the php_fcgi_max_requests environment variable. Default: 0. The meaning of this configuration is that when the number of requests processed by a php-cgi process accumulates to 500, the process will be automatically restarted.

But why restart the process?

Generally in projects, we will use some third-party libraries of PHP to some extent. These third-party libraries often have memory leak problems. If the php-cgi process is not restarted regularly, the memory usage will inevitably increase. Therefore, php-fpm, as the manager of php-cgi, provides such a monitoring function to restart the php-cgi process that has requested a specified number of times to ensure that the memory usage does not increase.

It is precisely because of this mechanism that 502 errors are often caused in high-concurrency sites. I guess the reason is that php-fpm does not handle the request queue from nginx well. However, I am still using php 5.3.2. I don’t know if this problem still exists in php 5.3.3.

Our current solution is to set this value as large as possible to reduce the number of re-spawns of php-cgi as much as possible, and at the same time improve the overall performance. In our own actual production environment, we found that the memory leak was not obvious, so we set this value very large (204800). Everyone should set this value according to their actual situation and cannot blindly increase it.

Having said that, the purpose of this mechanism is only to ensure that php-cgi does not occupy excessive memory. Why not deal with it by detecting memory? I very much agree with what Gao Chunhui said, restarting the php-cgi process by setting the peak internal usage of the process would be a better solution.

3, php-fpm’s slow log, debug and exception troubleshooting tool: request_slowlog_timeout sets a timeout parameter, and slowlog sets the storage location of the slow log. tail -f /var/log/www.slow.log The above command can see the php process that is executing too slowly.

You can see the common problems of excessive network reading and slow mysql query. If you follow the prompt information to troubleshoot the problem, you will have a clear direction.



Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn