Home > Backend Development > PHP Tutorial > Install and configure PHP 56 + Nginx 18

Install and configure PHP 56 + Nginx 18

WBOY
Release: 2016-07-29 09:15:35
Original
1168 people have browsed it

PHP

Download PHP 5.6 (VC11 x86 Non Thread Safe), unzip it to any directory, copy the file php.ini-development and rename it to php.ini.

I did not modify the contents of the php.ini file, and the subsequent tests passed. If you want to change it in the future, you can refer to http://php.net/manual/zh/install.windows.manual.php

Nginx

to download Nginx 1.80 and unzip it in any directory. Open its configuration file conf/nginx.conf and find the following paragraph:

<code><span>#location ~ \.php$ {</span><span>#</span><span>#}</span></code>
Copy after login

Delete all the # signs in front and replace this line:

<code>fastcgi_param  SCRIPT_FILENAME  /scripts<span>$fastcgi_script_name</span>;</code>
Copy after login

with:

<code>fastcgi_param  SCRIPT_FILENAME  <span>$document_root</span><span>$fastcgi_script_name</span>;</code>
Copy after login

That is, replace /scripts with $document_root

The modified complete configuration block is:

<code><span># pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000</span><span>#</span>
location ~ \.php<span>$ </span>{
    root           html;
    fastcgi_pass   <span>127.0</span>.<span>0</span>.<span>1</span><span>:</span><span>9000</span>;
    fastcgi_index  index.php;
    fastcgi_param  <span>SCRIPT_FILENAME</span><span>$document_root</span><span>$fastcgi_script_name</span>;
    <span>include</span>        fastcgi_params;
}</code>
Copy after login

Or the whole block can be changed to the following:

<code><span># pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000</span><span>#</span>
location ~ \<span>.php</span>$ {
    root           html<span>;</span>
    fastcgi_pass   <span>127.0</span><span>.0</span><span>.1</span>:<span>9000</span><span>;</span>
    fastcgi_index  index<span>.php</span><span>;</span>
    include        fastcgi<span>.conf</span><span>;</span>
}</code>
Copy after login

Run it

Then create info.php in the Nginx Root directory (html directory) The content of the file is as follows:

<code><span><span><?php </span>phpinfo();
</span></span></code>
Copy after login

Start Nginx (if it has already been started, shut it down and restart it).

Start php-cgi (listen to the local port 9000):

<code>cd path<span>-to</span><span>-php</span><span>-home</span>
php<span>-cgi</span><span>-b</span><span>127.0</span><span>.0</span><span>.1</span>:<span>9000</span></code>
Copy after login

If an error is reported, you need to install the VC2012 (VC11) runtime library first: http://www.microsoft.com/en-us/download/details.aspx ?id=30679

Open the browser access address http://127.0.0.1/info.php

Nginx first receives the request, and then forwards it to php-cgi, which parses and executes the PHP code and returns it to Nginx. Finally Return to the browser.

If the link can be opened normally and a lot of PHP-related information is displayed (as shown in the picture below), it means the configuration is successful.

Install and configure PHP 56 + Nginx 18

This is the first time that I (Liigo) have displayed this interface by myself, and it feels quite comfortable.

PHP-FPM or spawn-fcgi or php-cgi?

Looking at online analysis, PHP-FPM is much better than spawn-fcgi, and PHP-FPM has been officially integrated by PHP 5.3.3+, so spawn is eliminated first -fcgi, PHP-FPM preferred.

But, but, to enable PHP-FPM, you have to compile the PHP source code yourself, ./configure --enable-fpm.... This task is still very troublesome in the Windows environment, so I will give it up for now.

What to do next? I didn't know what to do at first. Later, through Internet searches, I found out that the php-cgi program can also be used as a FastCGI server. So I settled for the next best thing and chose php-cgi.

Conclusion, you can temporarily use php-cgi in the development environment, but the deployment environment must be PHP-FPM in the future.

PHP 5 or PHP 7?

PHP 7 is very good and powerful, but it has not been officially released yet, and it will take transition time for various frameworks and codes to support it. So for the time being, let’s stick to PHP 5, otherwise novices will be helpless when faced with subtle compatibility issues.

Copyright Statement: This article is an original article by the blogger and may not be reproduced without the author's authorization.

The above introduces the installation and configuration of PHP 56 + Nginx 18, including all aspects. I hope it will be helpful to friends who are interested in PHP tutorials.

Related labels:
source:php.cn
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template