Home Backend Development PHP Tutorial Detailed explanation of php-fpm configuration file

Detailed explanation of php-fpm configuration file

Jul 25, 2016 am 08:54 AM

This article introduces some contents of the php-fpm configuration file and configuration options. Friends in need can refer to it.

This section introduces the php-fpm file that comes with php5.3, as follows: /usr/local/php/etc/php-fpm.conf

php-fpm configuration options: pid = run/php-fpm.pid pid setting, the default is var/run/php-fpm.pid in the installation directory, it is recommended to turn it on error_log = log/php-fpm.log Error log, var/log/php-fpm.log in the installation directory by default log_level = notice Error level. Available levels are: alert (must be handled immediately), error (error condition), warning (warning condition), notice (general important information), debug (debugging information). Default: notice. emergency_restart_threshold = 60 emergency_restart_interval = 60s Indicates that if the number of php-cgi processes that have SIGSEGV or SIGBUS errors within the value set by emergency_restart_interval exceeds emergency_restart_threshold, php-fpm will restart gracefully. These two options generally remain at their default values. process_control_timeout = 0 Set the timeout for the child process to accept multiplexed signals from the main process. Available units: s (seconds), m (minutes), h (hours), or d (days) Default unit: s (seconds). Default value: 0. daemonize=yes Execute fpm in the background. The default value is yes, which can be changed to no for debugging. In FPM, it is possible to run multiple process pools with different settings. These settings can be set individually for each process pool. listen = 127.0.0.1:9000 The fpm listening port is the address processed by PHP in nginx. Generally, the default value is sufficient. Available formats are: ‘ip:port’, ‘port’, ‘/path/to/unix/socket’. Each process pool needs to be set. listen.backlog = -1 The number of backlogs, -1 means unlimited, is determined by the operating system, just comment out this line. listen.allowed_clients = 127.0.0.1 Allow access to the IP of the FastCGI process. Set any to unrestricted IP. If you want to set nginx on other hosts to also access this FPM process, set the listen address to a local IP that can be accessed. The default value is any. Each address is separated by a comma. If not set or empty, any server requesting a connection is allowed listen.owner = www listen.group = www listen.mode = 0666 Unix socket setting options, if you use tcp mode to access, just comment here. user=www group=www Account and group to start the process

pm = dynamic How to control the child process, the options are static and dynamic. If static is selected, a fixed number of child processes is specified by pm.max_children. If dynamic is selected, it is determined by the opening parameters: pm.max_children, the maximum number of child processes pm.start_servers, the number of processes at startup pm.min_spare_servers, guarantees the minimum number of idle processes. If the idle processes are less than this value, a new child process will be created. pm.max_spare_servers ensures the maximum number of idle processes. If the idle processes are greater than this value, they will be cleaned up. For dedicated servers, pm can be set to static. 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 will always be accepted. Equivalent to the PHP_FCGI_MAX_REQUESTS environment variable. Default: 0. pm.status_path = /status The URL of the FPM status page. If not set, the status page cannot be accessed. Default: none. ping.path = /ping The ping URL of the FPM monitoring page. If not set, the ping page cannot be accessed. This page is used to externally detect whether the FPM is alive and can respond to requests. Please note that it must start with a slash (/). ping.response = pong Used to define the return response for ping requests. Returned as HTTP 200 text/plain format text. Default value: pong. request_terminate_timeout = 0 Sets the timeout for a single request. This option may be useful if the 'max_execution_time' setting in php.ini does not abort a running script for some special reason. Set to '0' for 'Off'. You can try changing this option when 502 errors occur frequently. request_slowlog_timeout = 10s When a request expires after the set timeout, the corresponding PHP call stack information will be completely written to the slow log. Setting it to '0' means 'Off' slowlog = log/$pool.log.slow Slow request logging, used in conjunction with request_slowlog_timeout rlimit_files = 1024 Set the rlimit limit for file open descriptors. Default value: system-defined value The system default openable handle is 1024, which can be viewed using ulimit -n and modified with ulimit -n 2048. rlimit_core = 0 Set the maximum limit value of core rlimit. Available values: 'unlimited', 0 or positive integer. Default value: system-defined value. chroot = Chroot directory at startup. The defined directory needs to be an absolute path. If not set, chroot will not be used. chdir = Set the startup directory, which will be automatically Chdired to during startup. The defined directory needs to be an absolute path. Default value: current directory, or / directory (when chrooting) catch_workers_output = yes Redirect stdout and stderr during the running process to the main error log file. If not set, stdout and stderr will be redirected to /dev/null according to FastCGI rules. Default value: empty.



Statement of this Website
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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP Logging: Best Practices for PHP Log Analysis PHP Logging: Best Practices for PHP Log Analysis Mar 10, 2025 pm 02:32 PM

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot

Working with Flash Session Data in Laravel Working with Flash Session Data in Laravel Mar 12, 2025 pm 05:08 PM

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

cURL in PHP: How to Use the PHP cURL Extension in REST APIs cURL in PHP: How to Use the PHP cURL Extension in REST APIs Mar 14, 2025 am 11:42 AM

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Simplified HTTP Response Mocking in Laravel Tests Simplified HTTP Response Mocking in Laravel Tests Mar 12, 2025 pm 05:09 PM

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

12 Best PHP Chat Scripts on CodeCanyon 12 Best PHP Chat Scripts on CodeCanyon Mar 13, 2025 pm 12:08 PM

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

Explain the concept of late static binding in PHP. Explain the concept of late static binding in PHP. Mar 21, 2025 pm 01:33 PM

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

Customizing/Extending Frameworks: How to add custom functionality. Customizing/Extending Frameworks: How to add custom functionality. Mar 28, 2025 pm 05:12 PM

The article discusses adding custom functionality to frameworks, focusing on understanding architecture, identifying extension points, and best practices for integration and debugging.

See all articles