Home >Backend Development >PHP Tutorial >The relationship between fastcgi and php-fpm
First of all, what is CGI for? CGI is to ensure that the data passed by the web server is in a standard format, which is convenient for writers of CGI programs.
The web server (such as nginx) is just a distributor of content. For example, if /index.html is requested, the web server will find this file in the file system and send it to the browser. What is distributed here is static data. Okay, if the request is now for /index.php, according to the configuration file, nginx knows that this is not a static file and needs to be processed by the PHP parser, then it will simply process the request and hand it over to the PHP parser. What data will Nginx pass to the PHP parser? The URL must be present, the query string must be present, the POST data must be present, and the HTTP header must be present. Well, CGI is the protocol that stipulates what data is to be transmitted and in what format to be passed to the backend for processing the request. Think carefully about where the users you use in your PHP code come from.
When the web server receives the request for /index.php, it will start the corresponding CGI program, which is the PHP parser. Next, the PHP parser will parse the php.ini file, initialize the execution environment, process the request, return the processed result in the format specified by CGI, and exit the process. The web server then returns the results to the browser.
Okay, CGI is a protocol and has nothing to do with process or anything. So what is fastcgi? Fastcgi is used to improve the performance of CGI programs.
Improve performance, so what are the performance problems of CGI programs? "The PHP parser will parse the php.ini file and initialize the execution environment", that's it. Standard CGI will perform these steps for each request (don't be tired! Starting the process is very tiring!), so the time to process each time will be relatively long. This is obviously unreasonable! So how does Fastcgi do it? First, Fastcgi will start a master, parse the configuration file, initialize the execution environment, and then start multiple workers. When a request comes in, the master passes it to a worker, which can then immediately accept the next request. This avoids duplication of work and is naturally highly efficient. And when there are not enough workers, the master can pre-start several workers according to the configuration and wait; of course, when there are too many idle workers, some will be stopped, which improves performance and saves resources. This is fastcgi's process management.
So what is PHP-FPM? It is a program that implements Fastcgi and was officially accepted by PHP.
Everyone knows that the interpreter of PHP is php-cgi. php-cgi is just a CGI program. It can only parse requests and return results, but does not know how to manage processes (Your Majesty, I really can’t do that!) So there are some programs that can schedule php-cgi processes. For example, spawn-fcgi is separated from lighthttpd. Well, PHP-FPM is the same thing. After a long period of development, it has gradually been recognized by everyone (you know, in the past few years, everyone complained about the poor stability of PHP-FPM), and it has become more and more popular.
Okay, finally come back to your question.
Some people on the Internet say that fastcgi is a protocol, and php-fpm implements this protocol
Yes.
Some people say that php-fpm is the manager of fastcgi process, which is used to manage fastcgi processYes. The management object of php-fpm is php-cgi. But it cannot be said that php-fpm is the manager of the fastcgi process, because as mentioned earlier, fastcgi is a protocol, and it seems that no such process exists. Even if php-fpm exists, it cannot manage it (at least for now).
Some people say that php-fpm is a patch of php kernel
It was correct before. Because php-fpm was not included in the PHP kernel at the beginning, to use this function, you need to find php-fpm that is the same as the source code version, patch the kernel, and then compile it. Later, it became much more convenient after the PHP kernel integrated PHP-FPM. Just use the --enalbe-fpm compilation parameter.Some people say that after modifying the php.ini configuration file, there is no way to restart smoothly, so php-fpm was born
Yes, after modifying php.ini, the php-cgi process cannot restart smoothly. The processing mechanism of php-fpm is that new workers use new configurations, and existing workers can rest after finishing the work at hand. This mechanism is used to smooth the transition.Some people say that PHP-CGI is the FastCGI manager that comes with PHP. In that case, why create php-fpm? That’s not right. php-cgi is just a program that interprets PHP scripts.
The above has introduced the relationship between fastcgi and php-fpm, including aspects of it. I hope it will be helpful to friends who are interested in PHP tutorials.