The three running methods of php are: 1. Implemented through the built-in module of HTTPServer; 2. Implemented through CGI; 3. Implemented through FastCGI.
Recommended: "PHP Video Tutorial"
Three ways of running PHP
Three operating modes: mod_php5, cgi, fast-cgi
1. Implemented through the built-in module of HTTPServer,
For example, Apache's mod_php5, similar Apache's built-in mod_perl can Support for perl;
2. Implementation through CGI
This is just like the previous CGI of perl. The disadvantage of this method is poor performance, because every time the server encounters These scripts require restarting the script parser to execute the script and return the results to the server. On the other hand, it is not very safe.
This method is almost rarely used.
3. The latest one is called FastCGI.
The so-called FastCGI is an improvement on CGI. It generally adopts a C/S structure. Generally, the script processor will start one or more daemon processes. Every time HTTPServer encounters a script, it is directly delivered to the FastCGI process for execution, and then the result (usually HTML) is returned. to the browser.
A small problem with this method is that when encountering frequent requests with large traffic, the daemon process of the script processor may be overloaded and become very slow, or even cause a memory leak;
But the advantage compared to Apache's built-in module method is that the server and script parser are completely separated and responsible for their own responsibilities, so the server is no longer bloated and can concentrate on responding to static files or returning the results of the dynamic script parser. Give the user client.
So compared to Apache's built-in module method, sometimes the performance is much improved.
Some people have tested that it may be 5 to 10 times faster than Apache mod_php.
3.1. FastCGI common modes:
lightppd spawn-fcgi
nginx PHP-FPM
a, both of the above FastCGI is used to support PHP, so HTTPServer is completely liberated and can respond better and handle concurrently.
b. Since spawn-fcgi is part of lighttpd, if lighttpd is installed, spawn-fcgi will generally be used to support PHP. However, some users currently say that lighttpd’s spwan-fcgi will fail during high concurrent access. The memory leak mentioned above may even automatically restart fastcgi.
Unlike lighttpd, nginx comes with fastcgi (spawn-fcgi), so it is completely lightweight. It must use a third-party FastCGI processor to parse PHP, so it actually looks like this nginx is very flexible and can be connected to any third-party parsing processor to parse PHP.
nginx can use spwan-fcgi (lighttpd needs to be installed together, but the port needs to be avoided for nginx. Some older blogs have tutorials on this installation), but since spawn-fcgi has the users mentioned above The defects gradually discovered, now the use of nginx spawn-fcgi combination is gradually reduced.
c. Due to the defects of spawn-fcgi, a new third-party (currently still, I heard that they are working hard to add it to PHP core in the near future) FastCGI processor for PHP has appeared, called PHP-FPM. Compared with spawn-fcgi, it has the following advantages:
Since PHP-FPM is developed as a PHP patch, it needs to be compiled together with the PHP source code during installation, which means that it is compiled into PHP core. Therefore, it is better in terms of performance;
At the same time, it is also better than spawn-fcgi in handling high concurrency, at least it will not automatically restart the fastcgi processor.
Therefore, as mentioned above, due to the lightweight and flexibility of nginx, its current performance is superior, and more and more people are gradually using this combination: nginx PHP/PHP-FPM.
The above is the detailed content of Three ways to run php. For more information, please follow other related articles on the PHP Chinese website!

The article compares ACID and BASE database models, detailing their characteristics and appropriate use cases. ACID prioritizes data integrity and consistency, suitable for financial and e-commerce applications, while BASE focuses on availability and

The article discusses securing PHP file uploads to prevent vulnerabilities like code injection. It focuses on file type validation, secure storage, and error handling to enhance application security.

Article discusses best practices for PHP input validation to enhance security, focusing on techniques like using built-in functions, whitelist approach, and server-side validation.

The article discusses strategies for implementing API rate limiting in PHP, including algorithms like Token Bucket and Leaky Bucket, and using libraries like symfony/rate-limiter. It also covers monitoring, dynamically adjusting rate limits, and hand

The article discusses the benefits of using password_hash and password_verify in PHP for securing passwords. The main argument is that these functions enhance password protection through automatic salt generation, strong hashing algorithms, and secur

The article discusses OWASP Top 10 vulnerabilities in PHP and mitigation strategies. Key issues include injection, broken authentication, and XSS, with recommended tools for monitoring and securing PHP applications.

The article discusses strategies to prevent XSS attacks in PHP, focusing on input sanitization, output encoding, and using security-enhancing libraries and frameworks.

The article discusses the use of interfaces and abstract classes in PHP, focusing on when to use each. Interfaces define a contract without implementation, suitable for unrelated classes and multiple inheritance. Abstract classes provide common funct


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment