Httpd+PHP+Mariadb

Httpd+PHP+Mariadb

httpd-2.4+php-5.4.16+mariadb-5.5.41之modules模式(prefork)

1、安裝所需軟件

[root@magedu ~]# yum install httpd php php-mysql mariadb

2、php軟件包所生成的文件

[root@magedu ~]# rpm -ql php

/etc/httpd/conf.d/php.conf     

/etc/httpd/conf.modules.d/10-php.conf

/usr/lib64/httpd/modules/libphp5.so      #此模塊是httpd(prefork模型)所需的php模塊,Event和worker模型使用的php模塊應該爲libphp5-zts.so文件,但此文件需要編譯安裝生成

 

3、php.conf文件配置httpd能識別php的資源類型

[root@magedu ~]# cat /etc/httpd/conf.d/php.conf | grep '^[^#]'

<FilesMatch \.php$>

  SetHandler application/x-httpd-php

</FilesMatch>

AddType text/html .php

DirectoryIndex index.php

php_value session.save_handler "files"

php_value session.save_path    "/var/lib/php/session"

 

####10-php.conf配置httpd加載Php所需的模塊

[root@magedu ~] cat /etc/httpd/conf.modules.d/10-php.conf  | grep '^[^#]'

<IfModule prefork.c>

LoadModule php5_module modules/libphp5.so   #加載指定的模塊

</IfModule>

 

4、php-mysql

php連接Mysql的工具

啓動相關服務

[root@magedu ~]systemctl start httpd.service

[root@magedu ~]systemctl start mariadb

建立測試頁面,測試php及mariadb

[root@magedu ~]vim/var/www/html/index.php

[root@magedu ~]# cat/var/www/html/index.php

<?php

    $conn = mysql_connect('172.16.36.73','wpuser','wppass');

    if ($conn)

        echo "oK.";

    else

        echo "Failure..";

    phpinfo();

?>

 

<?php

phpinfo();

?>

 

#####

    1 phpinfo() 是php內置的一個函數,可以查看php的相關信息

    2 mysql_connect是php連接mysql的一個內置函數

 

    打開瀏覽器輸入IP地址如果能正常顯示ok,或者能正常顯示php的狀態信息, 即說明Php模塊運行正常

 

實現httpd(Event)+php(modules)+mariadb+xcache

二、實現httpd(Event)+php(modules)+mariadb+xcache

1、安裝httpd

[root@magedu ~]# yum install httpd

修改httpd的工作模型

[root@magedu conf.modules.d]#vim /etc/httpd/conf.modules.d/00-mpm.conf

# Select the MPM module which should be used by uncommenting exactly

# one of the following LoadModule lines:

 

# prefork MPM: Implements a non-threaded, pre-forking web server

# See: http://httpd.apache.org/docs/2.4/mod/prefork.html

#LoadModule mpm_prefork_module modules/mod_mpm_prefork.so

 

# worker MPM: Multi-Processing Module implementing a hybrid

# multi-threaded multi-process web server

# See: http://httpd.apache.org/docs/2.4/mod/worker.html

#

#LoadModule mpm_worker_module modules/mod_mpm_worker.so

 

# event MPM: A variant of the worker MPM with the goal of consuming

# threads only for connections with active processing

# See: http://httpd.apache.org/docs/2.4/mod/event.html

#

LoadModule mpm_event_module modules/mod_mpm_event.so 開啓這行

2、Yum安裝mariadb

[root@magedu ~]#yum install mariadb-server

3、編譯安裝php

獲取php軟件包

解壓:

[root@magedu ~]# tar xf php-5.4.26.tar.bz2

[root@magedu ~]# cd php-5.4.26/

安裝依賴的包

[root@magedu php-5.4.26]#  yum install libxml2-devel

[root@magedu php-5.4.26]# yum install bzip2-devel

[root@magedu php-5.4.26]# yum insall libmcrypt

[root@magedu php-5.4.26]#yum insall libmcrypt-devel

[root@magedu php-5.4.26]# yum install libmcrypt-devel

開始配置編譯

[root@magedu php-5.4.26]# ./configure --prefix=/usr/local/php --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-openssl --with-mysqli=mysqlnd --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --with-apxs2=/usr/bin/apxs --with-mcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2 --enable-maintainer-zts

 

注意事項

--with-apxs2=/usr/bin/apxs : 利用httpd下的apxs工具,將php編譯爲httpd的模塊, 需要在httpd的配置文件中確認是否加載此模塊 : LoadModule php5_module        /usr/lib64/httpd/modules/libphp5.so

 

說明:

1、這裏爲了支持apache的worker或event這兩個MPM,編譯時使用了--enable-maintainer-zts選項。

2、如果使用PHP5.3以上版本,爲了鏈接MySQL數據庫,可以指定mysqlnd,這樣在本機就不需要先安裝MySQL或MySQL開發包了。mysqlnd從php 5.3開始可用,可以編譯時綁定到它(而不用和具體的MySQL客戶端庫綁定形成依賴),但從PHP 5.4開始它就是默認設置了。

# ./configure --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd

開始安裝編譯:

[root@magedu php-5.4.26]#  make && make install

4、配置php

[root@magedu  php-5.4.40]# cp php.ini-production /etc/php.ini

5、配置httpd.conf文件

[root@magedu ~]vim /etchttpd/conf/httpd.conf

ADDType application/x-httpd-php .php

ADDType application/x-httpd-phps .phps

DirectoryIndex index.php index.html

6、重啓httpd服務

systemctl restart httpd

測試php的工作狀態

[root@magedu ~]# vim /var/www/html/index.php

<?php

    $conn = mysql_connect('127.0.0.1','wpuser','wppass');

    if ($conn)

        echo "YES";

    else

        echo "Failure";

    mysql_close();

?>

 

7、配置使用xcache

獲取xcache-3.2.0軟件

配置並編譯xcache

[[root@magedu  xcache-3.2.0]# mkdir /etc/php.d

[[root@magedu  xcache-3.2.0]# cp xcache.ini /etc/php.d

接下來編輯/etc/php.d/xcache.ini,找到extension開頭的行,修改爲如下行:

zend_extension = /usr/local/php/lib/php/extensions/no-debug-zts-20100525/xcache.so

注意: 如果php.ini文件中有多條extension指令行,要確保此新增的行排在第一位

 

啓用服務器狀態

mod_status模塊可以讓管理員查看服務器的執行狀態,它通過一個HTML頁面展示了當前服務器的統計數據。這些數據通常包括但不限於:

(1) 處於工作狀態的worker進程數;

(2) 空閒狀態的worker進程數;

(3) 每個worker的狀態,包括此worker已經響應的請求數,及由此worker發送的內容的字節數;

(4) 當前服務器總共發送的字節數;

(5) 服務器自上次啓動或重啓以來至當前的時長;

(6) 平均每秒鐘響應的請求數、平均每秒鐘發送的字節數、平均每個請求所請求內容的字節數;

啓用狀態頁面的方法很簡單,只需要在主配置文件中添加如下內容即可:

[root@magedu ~]# vim /etc/httpd/conf/httpd.conf

 <Location /server-status>

SetHandler server-status

Require all granted

</Location>

需要提醒的是,這裏的狀態信息不應該被所有人隨意訪問,因此,應該限制僅允許某些特定地址的客戶端查看。比如使用Require ip 172.16.0.0/16來限制僅允許指定網段的主機查看此頁面。

 

httpd(prefork)+php(fpm)+mariadb(三層架構)

三、使用三臺服務器,httpd 及php, mariadb都獨立運行於一臺服務器之上

1httpd服務器

安裝httpd

[root@magedu ~] #yum install httpd

配置httpd

1 確認proxy的模塊有沒有被裝載

cat /etc/httpd/conf.modules.d/00-proxy.conf

LoadModule proxy_module modules/mod_proxy.so

LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so

以上的兩個模塊確認需要被裝載

 

編輯httpd.conf並配置,添加如下:

DirectoryIndex index.html index.php

proxyrequests off   #關閉正向代理

proxypassmatch ^/(.*\.php)$ fcgi://172.16.36.71:9000/var/www/html/$1   #將所有php結尾的文件請求通過fcgi轉發到指定的服務器中

2php服務器

安裝php(fpm)

####獲取php軟件包

[root@magedu ~]# tar xf php-5.4.26.tar.bz2

[root@magedu ~]# cd php-5.4.26/

[root@magedu php-5.4.26]# yum install libxml2-devel

[root@magedu php-5.4.26]#yum install openssl-devel

[root@magedu php-5.4.26]#yum install bzip2-devel

[root@magedu php-5.4.26]#yum install libmcrypt-devel

[root@magedu php-5.4.26]# ./configure --prefix=/usr/local/php --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-openssl --with-mysqli=mysqlnd --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets  --with-mcrypt --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-bz2 --enable-fpm

make -j 4 && make install

 

配置php服務

[root@magedu php-5.4.26]# cp php.ini-production /etc/php.ini

 

配置Php-fpm服務

[root@magedu php-5.4.26]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm

[root@magedu php-5.4.26]# chmod +x /etc/init.d/php-fpm

[root@magedu php-5.4.26]# chkconfig --add php-fpm

[root@magedu php-5.4.26]# chkconfig php-fpm on

[root@magedu php-5.4.26]# cp php-fpm.conf.default php-fpm.conf

 

修改php-fpm的運行配置文件

[root@magedu php-5.4.26]# vim /usr/local/php/etc/php-fpm.conf

pm.max_children = 50

pm.start_servers = 5

pm.min_spare_servers = 2

pm.max_spare_servers = 8

pid = /usr/local/php5/var/run/php-fpm.pi

接下來就可以啓動php-fpm了:

[root@magedu php-5.4.26]# systemctl startphp-fpm

使用如下命令來驗正(如果此命令輸出有中幾個php-fpm進程就說明啓動成功了):

[root@magedu php-5.4.26]# ps aux | grep php-fpm

默認情況下,fpm監聽在127.0.0.1的9000端口,也可以使用如下命令驗正其是否已經監聽在相應的套接字。

[root@magedu php-5.4.26]# netstat -tnlp | grep php-fpm

tcp        0      0 172.16.36.71:9000              0.0.0.0:*                   LISTEN      689/php-fpm

php提供測試頁面

php服務器上/var/www/html,建立index.php文件,

[root@magedu php-5.4.26]# cat /var/www/html/index.php

<?php

    phpinfo();

?>

 

3mysql服務器:

安裝mariadb

[root@magedu ~]# yum install mairadb-server

[root@magedu ~]# systemctl start mariadb

建立php連接所需的用戶名和密碼

[root@magedu ~]# mysql

Welcome to the MariaDB monitor.  Commands end with ; or \g.

Your MariaDB connection id is 2

Server version: 5.5.44-MariaDB MariaDB Server

Copyright (c) 2000, 2015, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

 

MariaDB [(none)]> GRANT ALL ON wpdb.* TO 'wpuser'@'172.16.%.%' IDENTIFIED BY 'wppass';

Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> GREATE DATABASE wpdb;

MariaDB [(none)]> exit

 

安裝部署完成可以自行測試


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