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

 

安装部署完成可以自行测试


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