構建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

<?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

<?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]);

    printf("</br>");

}

?>

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


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章