FCGI模式LAMP跨三主机搭建详解
前述:本次搭建用到三台CentOS 7虚拟机,第一台配置为httpd服务器,接收请求;第二台以FCGI的模式将php配置为单独的服务器主机,其有独立的服务进程和空闲进程,等待httpd服务器发来动态资源调用请求,执行php脚本,动态响应;第三台配置为MariaDB(Mysql)数据库服务器,用来存储关系型数据。
每台虚拟主机的IP信息如下:
httpd主机
172.16.49.2,CentOS 7
RPM:httpd-2.4.6-31.el7.centos.x86_64
FCGI主机
172.16.49.3, CentOS 7
RPM:php-fpm-5.4.16-23.el7_0.3.x86_64
MariaDB主机
172.16.49.4,CentOS 7
RPM:mariadb-5.5.41-2.el7_0.x86_64
一、基于FCGI模式安装包组
1.CentOS 6系列
PHP-5.3.2及以前版本:默认不支持fpm机制;需要自行打补丁并编译安装;
httpd-2.2:默认不支持fcgi协议,需要自行编译fcgi模块;
解决方案:编译安装httpd-2.4, php-5.3.3及以上版本;
2.CentOS 7系列
172.16.49.2:# yum install -y httpd
172.16.49.3:# yum install -y php-fpm php-mmysql
172.16.49.4:# yum install -y mariadb-server
二、php-fpm服务器配置
1.php配置文件
服务进程配置文件:/etc/php-fpm.conf、/etc/php-fpm.d/*.conf
环境配置配置文件(php-common提供):/etc/php.ini、/etc/php.d/*.ini
2.FPM Configuration配置:
(1)采用默认即可,#cat/etc/php-fpm.conf
include=/etc/php-fpm.d/*.conf
包含/etc/php-fpm.d/*.conf的配置信息
pid =/run/php-fpm/php-fpm.pid
进程的PID文件位置
error_log =/var/log/php-fpm/error.log
错误日志位置
log_level = notice
日志级别,默认notice级别
;emergency_restart_threshold= 0
紧急重启的临界值
;emergency_restart_interval= 0
紧急重启的间隔
;process_control_timeout= 0
进程控制超时时长
daemonize = no
是否运行在后台,运行在前台可方便查看
(2)连接池配置,#cat /etc/php-fpm.d/www.conf
连接池能接受httpd服务器Web端代理发来的动态请求 需要修改如下参数,其余默认即可:
listen =172.16.49.3:9000 listen.allowed_clients = 172.16.49.2
;
表示注释该行信息
listen= 127.0.0.1:9000
监听端口,0.0.0.0表示本机所有地址。
支持远程调用应该监听在本机的远程通信端口
;listen.backlog =-1
后援等待队列的长度,-1表示无限制
listen.allowed_clients = 127.0.0.1
授权允许可请求主机,基于IP的控制机制,注释表示允许所
;listen.owner =nobody
监听服务进程的主机默认以什么用户身份运行,nobody表示普通用户
;listen.group =nobody
监听服务进程的主机默认以什么用户组身份运行
;listen.mode =0666
监听服务进程的主机默认以什么权限运行
user = apache
用户,RPM包制作者修改,编译安装非此结果
group = apache
用户组,RPM包制作者修改,编译安装非此结果
pm= static|dynamic
进程控制器生成子进程方式
;pm.status_path =/status
状态机制
;ping.path = /ping
ping机制,一般用于提供监控机制
php_admin_value=
连接池错误日志位置
php_admin_flag= on
是否在错误日志中将于管理相关的标志打开
php_value= files
php的session记录存放形式:文件
php_value=
php的session记录存放路径,集群是关键
注意:pm连接池模式有两种,pm = static|dynamic
static:固定数量的子进程;pm.max_children; dynamic:子进程数据以动态模式管理;选择该项需呀启用以下配置
pm.start_servers=
开始启用进程数
pm.min_spare_servers=
最小空闲进程数
pm.max_spare_servers=
最大空闲进程数
;pm.max_requests =
每个子进程自多允许响应多少请求,超过就kill
3.启动服务&&查看状态
# systemctl start php-fpm.service
# systemctl status php-fpm.service
三、Web服务器配置和测试
1.确保httpd服务中已经装载fcgi模块
# httpd -M | grep fcgi
2.确保httpd配置文件加载fcgi模块选项
#cat /etc/httpd/conf.modules.d/00-proxy.conf
其中有LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so则配置可以加载模块
2.以虚拟主机配置方式配置站点(亦可使用中心主机)
(1)删除测试页面:# mv /etc/httpd/conf.d/welcome.conf/etc/httpd/conf.d/welcome.conf.bck
(2)注释主配置文件中心主机段:# Document "/var/www/html"
(3)创建站点根目录位置:# mkdir /www/fcgi-test -pv
(4)创建虚拟主机配置:# vim /etc/httpd/conf.d/vritual.conf
ServerNamelocalhost:80<VirtualHost172.16.49.2:80>ServerNamewww.fcgi.comDocumentRoot"/www/fcgi-test"<Directory"/www/fcgi-test">OptionsNoneAllowoverrideNoneRequireall granted</Directory></VirtualHost> (5)检测httpd配置文件语法:# httpd -t
3..转发配置文件
# vim /etc/httpd/conf.d/fcgi.conf
ProxyRequestsOffProxyPassMatch ^/(.*\.php)$ fcgi://127.16.49.3:9000/www/fcgi-test/$1 注意:
1)第二条语句定义将访问172.16.49.2Web服务器的所有.php请求映射到php服务器查询执行2)在php服务器上创建映射查找目录,此目录可以和Web服务器的站点根目录不同,此处设置为相同# mkdir -pv /www/fcgi-test/4.启动服务
# systemctl start httpd.service
# systemctl status httpd.service
5.测试
(1)172.16.49.2/www/fcgi-test/index.html,并定义it is apache测试,在浏览器输入172.16.49.2/index.html
(2)172.16.49.3的映射代理目录下创建index.php,定义phpinfo()测试语句,在浏览器输入172.16.49.2/index.php
<?php phpinfo(); ?> (3)在172.16.49.2下同上放置index.php,在浏览器输入172.16.49.2/index.php
此时服务器会将.php请求发往php服务器查找,未找到index.php文件 (4)在172.16.49.3映射目录下同上放置index.html,在浏览器输入172.16.49.2/index.html
在172.16.49.2上找不到静态文件index.html报错
四、MariaDB数据库配置测试
1.禁止反解主机名
# vim/etc/my.cnf
在段添加语句:skip_name_resolve = ON
2.启动服务
# systemctl start mariadb.server
3.授权可远程登录用户
# mysql Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 2 Server version: 5.5.41-MariaDB MariaDB Server Copyright (c) 2000, 2014, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current inputstatement.MariaDB [(none)]>Grant ALL ON *.* TO 'root'@'172.16.%.%'IDENTIFIED BY 'xuding' 4.mariadb数据库远程连接
172.16.49.3上:# mysql -uroot -h172.16.49.4 -pxuding
5.php和mariadb服务连接测试
在172.16.49.3php主机上创建index.php测试页,写入如下代码:
<?php$conn = mysql_connect('172.16.49.4','root','xuding');if($conn)echo"OK";elseecho"Failure";?> 在浏览器输入172.16.49.2/index.php测试,若显示为okz则php和mysql可以连接
页:
[1]