PHP连接Nginx服务器并解析Nginx日志的方法

图片 8

php与nginx整合

Nginx本身不能处理PHP,它只是个web服务器,当接收到请求后,如果是php请求,则发给php解释器处理,并把结果返回给客户端。

PHP-FPM也是一个第三方的FastCGI进程管理器,它是作为PHP的一个补丁来开发的,在安装的时候也需要和PHP源码一起编译,也就是说PHP-FPM被编译到PHP内核中,因此在处理性能方面更加优秀;同时它在处理高并发方面也比spawn-fcgi引擎好很多,因此,推荐Nginx+PHP/PHP-FPM这个组合对PHP进行解析。FastCGI
的主要优点是把动态语言和HTTP
Server分离开来,所以Nginx与PHP/PHP-FPM经常被部署在不同的服务器上,以分担前端Nginx服务器的压力,使Nginx专一处理静态请求和转发动态请求,而PHP/PHP-FPM服务器专一解析PHP动态请求

Nginx一般是把请求发fastcgi管理进程处理,fascgi管理进程选择cgi子进程处理结果并返回被nginx

#fastcgi FastCGI是一个可伸缩地、高速地在HTTP
server和动态脚本语言间通信的接口。多数流行的HTTP
server都支持FastCGI,包括Apache、Nginx和lig等,同时,FastCGI也被许多脚本语言所支持,其中就有PHP。FastCGI是从CGI发展改进而来的。传统CGI接口方式的主要缺点是性能很差,因为每次HTTP服务器遇到动态程序时都需要重新启动脚本解析器来执行解析,然后结果被返回给HTTP服务器。这在处理高并发访问时,几乎是不可用的。另外传统的CGI接口方式安全性也很差,现在已经很少被使用了。FastCGI接口方式采用C/S结构,可以将HTTP服务器和脚本解析服务器分开,同时在脚本解析服务器上启动一个或者多个脚本解析守护进程。当HTTP服务器每次遇到动态程序时,可以将其直接交付给FastCGI进程来执行,然后将得到的结果返回给浏览器。这种方式可以让HTTP服务器专一地处理静态请求或者将动态脚本服务器的结果返回给客户端,这在很大程度上提高了整个应用系统的性能。Nginx+FastCGI运行原理Nginx不支持对外部程序的直接调用或者解析,所有的外部程序必须通过FastCGI接口来调用。FastCGI接口在Linux下是socket,。为了调用CGI程序,还需要一个FastCGI的wrapper,这个wrapper绑定在某个固定socket上,如端口或者文件socket。当Nginx将CGI请求发送给这个socket的时候,通过FastCGI接口,wrapper接纳到请求,然后派生出一个新的线程,这个线程调用解释器或者外部程序处理脚本并读取返回数据;接着,wrapper再将返回的数据通过FastCGI接口,沿着固定的socket传递给Nginx;最后,Nginx将返回的数据发送给客户端,这就是Nginx+FastCGI的整个运作过程。

一、首先我们先初步认识下FastCGI和Ngnix+FastCGI的运行原理

php与nginx整合php.ini:php的主配置文件

1、apache+PHP和ngnix+php的区别

apache一般是把php当做自己的一个模块来启动;而ngnix则是把http请求变量转发给php进程,即php独立进程,与ngnix通信,这种方式叫做FastCGI运行方式。

所以,apache所编译的php不能用于ngnix。

先看一个简单的图:

图片 1

以下这段我认为是在网络上找到的最通俗易懂的解释,我将它复制进来方便大家理解:

[root@server79 php-5.4.12]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini

2、什么是FastCGI呢?

FastCGI是一个可伸缩地、高速地在HTTP
server和动态脚本语言间通信的接口。多数流行的HTTP
server都支持FastCGI,包括Apache、Nginx和lighttpd等。同时,FastCGI也被许多脚本语言支持,其中就有PHP。

FastCGI是从CGI发展改进而来的。传统CGI接口方式的主要缺点是性能很差,因为每次HTTP服务器遇到动态程序时都需要重新启动脚本解析器来执行解析,然后将结果返回给HTTP服务器。这在处理高并发访问时几乎是不可用的。另外传统的CGI接口方式安全性也很差,现在已经很少使用了。

FastCGI接口方式采用C/S结构,可以将HTTP服务器和脚本解析服务器分开,同时在脚本解析服务器上启动一个或者多个脚本解析守护进程。当HTTP服务器每次遇到动态程序时,可以将其直接交付给FastCGI进程来执行,然后将得到的结果返回给浏览器。这种方式可以让HTTP服务器专一地处理静态请求或者将动态脚本服务器的结果返回给客户端,这在很大程度上提高了整个应用系统的性能。

拷贝php的启动脚本

3、Nginx+FastCGI运行原理

Nginx不支持对外部程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用。FastCGI接口在Linux下是socket(这个socket可以是文件socket,也可以是ip
socket)。

wrapper: 为了调用CGI程序,还需要一个FastCGI的wrapper(wrapper可以理解为用于启动另一个程序的程序),这个wrapper绑定在某个固定socket上,如端口或者文件socket。当Nginx将CGI请求发送给这个socket的时候,通过FastCGI接口,wrapper接收到请求,然后Fork(派生)出一个新的线程,这个线程调用解释器或者外部程序处理脚本并读取返回数据;接着,wrapper再将返回的数据通过FastCGI接口,沿着固定的socket传递给Nginx;最后,Nginx将返回的数据(html页面或者图片)发送给客户端。这就是Nginx+FastCGI的整个运作过程,

图片 2

所以,我们首先需要一个wrapper,这个wrapper需要完成的工作:

  1. 通过调用fastcgi(库)的函数通过socket和ningx通信(读写socket是fastcgi内部实现的功能,对wrapper是非透明的)
  2. 调度thread,进行fork和kill
  3. 和application(php)进行通信
[root@server79 fpm]# pwd/root/php-5.4.12/sapi/fpm[root@server79 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm

二、编译PHP

首先我们先认识一个概念:php-fpm

(1)PHP-FPM是一个PHP FastCGI管理器,是只用于PHP的,可以在

(2)PHP-FPM其实是PHP源代码的一个补丁,旨在将FastCGI进程管理整合进PHP包中。必须将它patch到你的PHP源代码中,在编译安装PHP后才可以使用

(3)新版的PHP已经集成了php-fpm,在./configure的时候带
–enable-fpm参数即可开启PHP-FPM

接下来我们开始安装编译PHP

1、编译前我们需要先安装一些php需要用到的库(我用的是centos版本的linux系统)

yum -y install gcc automake autoconf libtool make
yum -y install gcc gcc-c++ glibc
yum -y install libmcrypt-devel mhash-devel libxslt-devel 
libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel 
zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel 
ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel 
krb5 krb5-devel libidn libidn-devel openssl openssl-devel

2、获取php源码包

wget http://cn2.php.net/distributions/php-5.4.7.tar.gz

3、解压并进入php目录

tar zvxf php-5.4.7.tar.gz
cd php-5.4.7

图片 3

4、编译并安装

./configure --prefix=/usr/local/fastphp --enable-fpm --with-mcrypt 
--enable-mbstring --disable-pdo --with-curl --disable-debug --disable-rpath 
--enable-inline-optimization --with-bz2 --with-zlib --enable-sockets 
--enable-sysvsem --enable-sysvshm --enable-pcntl --enable-mbregex 
--with-mhash --enable-zip --with-pcre-regex --with-mysql --with-mysqli 
--with-gd --with-jpeg-dir
make all install

5、将php-fpm复制一份

图片 4

6、将php配置文件复制一份

图片 5

7、修改nginx配置文件以支持php-fpm

首先打开ngnix配置文件

vim /usr/local/ngnix/conf/ngnix.conf

在server段里加入以下代码

图片 6

保存

8、启动php-fpm和ngnix

/usr/local/ngnix
/usr/local/ngnix/sbin/php-fpm

9、在根目录下创建测试文件test.php做个简单的测试

图片 7

10、测试成功

图片 8

php-fpm的关闭和重启需要使用信号控制,其实就跟ngnix的关闭重启一样

php-fpm 关闭:kill -INT `cat /usr/local/fastphp/var/run/php-fpm.pid`

php-fpm 重启:kill -USR2 `cat /usr/local/fastphp/var/run/php-fpm.pid`

查看php-fpm进程数:ps aux | grep -c php-fpm

给启动脚本加可执行权限

[root@server79 fpm]# chmod +x /etc/init.d/php-fpm[root@server79 ~]# vim /usr/local/lnmp/php/etc/php.inicgi.fix_pathinfo=0date.timezone = /Asia/Shanghai[root@server79 ~]# cp /usr/local/lnmp/php/etc/php-fpm.conf.default /usr/local/lnmp/php/etc/php-fpm.conf[root@server79 etc]# vim php-fpm.conf

打开注释pid = run/php-fpm.pid

php-fpm.conf文件参数解析PHP的全局配置文件是php.ini,在上面的步骤中,已经将此文件复制到了/usr/local/lnmp/php/etc/php.ini下。可以根据每个应用需求的不同,对php.ini进行相应的配置。下面重点介绍PHP-FPM引擎的配置文件。根据上面指定的安装路径,PHP-FPM的默认配置文件为/usr/local/lnmp/php/etc/php-fpm.conf。php-fpm.conf是一个XML格式的纯文本文件,其内容很容易看明白。这里重点介绍几个重要的配置标签:标签listen_address是配置fastcgi进程监听的IP地址以及端口,默认是127.0.0.1:9000。

listen = 127.0.0.1:9000

标签user和group用于设置运行FastCGI进程的用户和用户组。需要注意的是,这里指定的用户和用户组要和Nginx配置文件中指定的用户和用户组一致。

user = nginxgroup = nginx

标签max_children用于设置FastCGI的进程数。根据官方建议,小于2GB内存的服务器,可以只开启64个进程,4GB以上内存的服务器可以开启200个进程。

value name="max_children"5/value

标签request_terminate_timeout用于设置FastCGI执行脚本的时间。默认是0s,也就是无限执行下去,可以根据情况对其进行修改。

value name="request_terminate_timeout"0s/value

标签rlimit_files用于设置PHP-FPM对打开文件描述符的限制,默认值为1024。这个标签的值必须和Linux内核打开文件数关联起来,例如要将此值设置为65535,就必须在Linux命令行执行’ulimit
-HSn 65536’。

value name="rlimit_files"1024/value

标签max_requests指明了每个children最多处理多少个请求后便会被关闭,默认的设置是500。

pm.max_requests = 500

标签allowed_clients用于设置允许访问FastCGI进程解析器的IP地址。如果不在这里指定IP地址,Nginx转发过来的PHP解析请求将无法被接受。

value name="allowed_clients"127.0.0.1/value

5.管理FastCGI进程在配置完php-fpm后,就可以启动FastCGI进程了。启动fastcgi进程有两种方式:

/usr/local/php/bin/php-cgi --fpm 

或者

/usr/local/php/sbin/php-fpm start 

建议采用第二种方式启动FastCGI进程。/usr/local/php/sbin/php-fpm还有其他参数,具体为start|stop|quit|restart|reload|logrotate。每个启动参数的含义如下:

q start,启动PHP的FastCGI进程。 q stop,强制终止PHP的FastCGI进程。 q
quit,平滑终止PHP的FastCGI进程。 q restart,重启PHP的FastCGI进程。 q
reload,重新加载PHP的php.ini。 q logrotate,重新启用log文件。
reload是个很重要的参数,它可以在PHP的FastCGI进程不中断的情况下重新加载改动过的php.ini,因此通过php-fpm可以平滑变更FastCGI模式下的PHP设置。

[root@server79 etc]# /etc/init.d/php-fpm start

配置nginx的主配置文件,打开与php的接口

[root@server79 conf]# pwd/usr/local/lnmp/nginx/conf[root@server79 conf]# vim nginx.confuser nginx;#location ~ /.php$ {root html; fastcgi_pass 127.0.0.1:9000; //本地9000端口fastcgi_index index.php;# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;include fastcgi.conf;}[root@server79 conf]# nginx -t^C[root@server79 conf]# nginx -s reload^C[root@server79 html]# pwd/usr/local/lnmp/nginx/html[root@server79 html]# cat index.phpphpphpinfo()

测试:浏览器中输入192.168.0.179/index.php,出现php页面

PHP解析Nginx日志nginx日志格式

access_log日志格式

 log_format main '$server_name$remote_addr$remote_user[$time_local]"$request"' '$status$body_bytes_sent"$http_referer"' '"$http_user_agent""$http_x_forwarded_for"'; 

日志参数

server_name : 虚拟主机的主机名称 remote_addr : 远程客户端的ip地址
remote_user : 远程客户端用户名称 time_local : 访问的时间与时区 status
: 记录请求返回的http状态码 body_bytes_sent :
发送给客户端的文件主体内容的大小 http_referer : 从哪个页面链接访问过来
http_user_agent : 客户端浏览器信息 http_x_forwarded_for :
客户端的真实ip

日志分割符使用特殊的不可打印字符^A(ctrl+v,ctrl+a)作为日志分割符

根据关键字过滤文件内容

需求根据http的请求里是否有“weibo”这个关键字提取文件的内容

php代码

 /** * Description:按行读取文件内容进行过滤匹配 * * @return array */ function readFileContent ($filename) { $weibo_content = array(); $fh = @fopen($filename, 'r'); if ($fh) { while (! feof($fh)) { $row = fgets($fh, 4096); $row_arr = explode("", $row); if (isset($row_arr[3]) && preg_match('/weibo/', $row_arr[3])) { $weibo_content[] = $row_arr; } } } fclose($fh); return $weibo_content; } 
You can leave a response, or trackback from your own site.

Leave a Reply

网站地图xml地图