天天看點

建構LNMP平台

建構LNMP平台

1 問題

沿用上篇,通過調整Nginx服務端配置,實作以下目标:

配置Fast-CGI支援PHP網頁

建立PHP測試頁面,測試使用PHP連接配接資料庫的效果

2 方案

使用2台RHEL7虛拟機,其中一台作為LNMP伺服器(192.168.4.5)、另外一台作為測試用的Linux客戶機(192.168.4.100

Nginx結合FastCGI技術即可支援PHP頁面架構,是以本案例,需要延續上篇的實驗内容,通過修改Nginx及php-fpm配置檔案實作對PHP頁面的支援。

php-fpm需要修改的常見配置如下:

listen = 127.0.0.1:9000 //PHP端口号

pm.max_children = 32 //最大程序數量

pm.start_servers = 15 //最小程序數量

pm.min_spare_servers = 5 //最少需要幾個空閑着的程序

pm.max_spare_servers = 32 //最多允許幾個程序處于空閑狀态

3 步驟

實作此案例需要按照如下步驟進行。

步驟一:建立并修改php-fpm配置檔案

1)檢視php-fpm配置檔案

[root@Proxy ~]# vim /etc/php-fpm.d/www.conf

[www]

listen = 127.0.0.1:9000

listen.allowed_clients = 127.0.0.1

user = apache

group = apache

pm = dynamic

pm.max_children = 50

pm.start_servers = 5

pm.min_spare_servers = 5

pm.max_spare_servers = 35

2)确認php-fpm服務已經啟動

[root@Proxy ~]# systemctl restart php-fpm

步驟二:修改Nginx配置檔案并啟動服務

[root@Proxy ~]# vim /usr/local/nginx/conf/nginx.conf

location / {

            root   html;

            index  index.php  index.html   index.htm;

        }

 location  ~  \.php$  {

            root           html;

            fastcgi_pass   127.0.0.1:9000;

            fastcgi_index  index.php;

            #fastcgi_param   SCRIPT_FILENAME  $document_root$fastcgi_script_name;

            include        fastcgi.conf;

[root@Proxy ~]# /usr/local/nginx/sbin/nginx -s reload

步驟三:建立PHP頁面,測試LNMP架構能否解析PHP頁面

1)建立PHP測試頁面1:

[root@Proxy ~]# vim /usr/local/nginx/html/test1.php

<?php

$i="This is a test Page";

echo $i;

?>

2)建立PHP測試頁面,連接配接MariaDB資料庫:

 [root@Proxy ~]# vim /usr/local/nginx/html/test2.php

$links=mysql_connect("localhost","root","密碼");        

//注意:root為mysql賬戶名稱,密碼需要修改為實際mysql密碼,無密碼則留白即可

if($links){

        echo "link db ok!!!";

}

else{

        echo "link db no!!!";

3)建立PHP測試頁面,連接配接并查詢MariaDB資料庫:

[root@Proxy ~]# vim /usr/local/nginx/html/test3.php

$mysqli = new mysqli('localhost','root','','mysql');

if (mysqli_connect_errno()){

    die('Unable to connect!'). mysqli_connect_error();

$sql = "select * from user";

$result = $mysqli->query($sql);

while($row = $result->fetch_array()){

    printf("Host:%s",$row[0]);

    printf("</br>");

    printf("Name:%s",$row[1]);

4)用戶端使用浏覽器通路伺服器PHP首頁文檔,檢驗是否成功:

[root@client ~]# firefox http://192.168.4.5/test1.php

[root@client ~]# firefox http://192.168.4.5/test2.php

[root@client ~]# firefox http://192.168.4.5/test3.php

繼續閱讀