6月13日任务

12.21 php-fpm的pool
12.22 php-fpm慢执行日志
12.23 open_basedir
12.24 php-fpm进程管理

12.21 php-fpm的pool

php-fpm可以支持定义多个pool,分别监听不同的sock或IP和端口,比如Nginx有好几个站点,每一个站点都可以去使用一个pool,这样的好处是当其中一个php页面502了,这很有可能是资源不够了,如果所有的网站都使用了一个pool,其中一个网站发了一些故障,例如程序员写的程序有问题,就会把php资源耗尽,那么其他的站点也会502,所以有必要把每一个站点隔离开,每一个站点使用单独的pool。

添加多个pool的方法:

1、进入指定目录,编辑php-fpm.conf文件。

[root@jimmylinux- ~]# cd /usr/local/php-fpm/etc/  进入指定目录

[root@jimmylinux- etc]# ls
pear.conf php-fpm.conf php-fpm.conf.default php.ini [root@jimmylinux- etc]# vim php-fpm.conf 编辑配置文件 添加以下内容 [jimmy]
listen = /tmp/jimmy.sock
#listen = 127.0.0.1:
listen.mode =
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children =
pm.start_servers =
pm.min_spare_servers =
pm.max_spare_servers =
pm.max_requests =
rlimit_files =

2、-t检查语法是否正确,然后重启php-fpm或者重新加载。

[root@jimmylinux- etc]# /usr/local/nginx/sbin/nginx -t  检查语法是否正确
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful [root@jimmylinux- etc]# /etc/init.d/php-fpm reload 重新加载php-fpm
Reload service php-fpm done [root@jimmylinux- etc]# ps aux |grep php-fpm 查看pool信息

3、如何去使用自定义的pool

[root@jimmylinux- etc]# cd /usr/local/nginx/conf/vhost/

[root@jimmylinux- vhost]# ls
aaa.com.conf ld.conf proxy.conf ssl.conf test.com.conf [root@jimmylinux- vhost]# vim test.com.conf 可以把test.com.conf定义成php-fcgi.sock [root@jimmylinux- vhost]# vim aaa.com.conf 再把aaa.com.conf定义成jimmy.sock

假如现在test.com.conf请求量很大,最终把php-fpm(www的pool进程耗尽了)最多可以启动50个,当50个启动完后所有的都在忙,又有新的请求来的时候就会把502,因为没有多的php-fpm进程提供服务了,而另外的站点不受影响,因为使用的是另外的pool,这就是为什么要定义多个pool的原因。

在Nginx.conf里面加了一条include,那php-fpm也是同样支持加include的。

[root@jimmylinux- vhost]# cd /usr/local/php-fpm/etc/

[root@jimmylinux- etc]# ls
pear.conf php-fpm.conf php-fpm.conf.default php.ini [root@jimmylinux- etc]# vim php-fpm.conf 在php-fpm.conf 主配置文件中也同样支持添加include

在global里面加入include,其他的内容都删除掉。

创建目录,然后新建配置文件。

[root@jimmylinux- etc]# mkdir php-fpm.d  创建目录

[root@jimmylinux- etc]# cd php-fpm.d

[root@jimmylinux- php-fpm.d]# vim www.conf  新建配置文件

添加以下内容

[www]
listen = /tmp/php-fcgi.sock
#listen = 127.0.0.1:
listen.mode =
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children =
pm.start_servers =
pm.min_spare_servers =
pm.max_spare_servers =
pm.max_requests =
rlimit_files = 1024
[root@jimmylinux-001 php-fpm.d]# vim jimmy.conf  重新创建另一个配置文件

添加以下内容

[jimmy]
listen = /tmp/jimmy.sock
#listen = 127.0.0.1:9000
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
 

-t检查语法是否正确,然后重启php-fpm。

[root@jimmylinux- php-fpm.d]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful [root@jimmylinux- php-fpm.d]# /etc/init.d/php-fpm restart
Gracefully shutting down php-fpm . done
Starting php-fpm done

12.22 php-fpm慢执行日志

做PHP网站,建议使用LNMP,其中有一个原因就是可以去分析php-fpm慢执行日志,比如网站访问慢,具体什么原因到底慢在什么地方,所以慢执行日志是非常有用的。

1、进入指定目录,编辑www.conf配置文件。

[root@jimmylinux- ~]# cd /usr/local/php-fpm/etc/php-fpm.d/

[root@jimmylinux- php-fpm.d]# vim www.conf

在配置文件最后加入以下2行内容

request_slowlog_timeout =   表示时间只要超过1秒的都记录
slowlog = /usr/local/php-fpm/var/log/www-slow.log 记录日志存放路径

2、重新加载php-fpm,然后查看日志文件路径。

3、模拟一个慢执行的php

如果遇到500报错,可以把php.ini配置文件中display_errors报告设置成on显示错误信息。

[root@jimmylinux- php-fpm.d]# vi /usr/local/php-fpm/etc/php.ini

把sleep.php配置文件中的标点符号全部改成半角的英文状态符合就可以了

[root@jimmylinux- php-fpm.d]# vim /data/wwwroot/test.com/sleep.php

<?php
echo "test slow log";
sleep();
echo "done";
?>

4、重新执行curl就会看见执行过程中会有停顿

12.23 open_basedir

在php-fpm里面也可以定义open_basedir,之前讲过在php.ini定义open_basedir,如果服务器上有多个网站,在php.ini里面定义就不合适了,要么在Apache虚拟主机配置文件里面定义,要么就在php-fpm配置文件里面定义,我们可以针对每一个pool去定义不同的open_basedir。

1、编辑www.conf配置文件

[root@jimmylinux- php-fpm.d]# vim www.conf

在最后一行加入以下内容

php_admin_value[open_basedir]=/data/wwwroot/jimmy.com:/tmp/

2、重启php-fpm,然后curl访问,如果出现如下报错,可以分析并解决。

[root@jimmylinux- php-fpm.d]# ls /data/wwwroot/test.com/
.gif .js .php admin index.html sleep.php upload [root@jimmylinux- php-fpm.d]# curl -x127.0.0.: test.com/.php
No input file specified. 主要是因为open_basedir做了限制,所以会报错。
[root@jimmylinux- php-fpm.d]# vim www.conf  重新编辑配置文件

修改最后一行为正确的路径test.com

php_admin_value[open_basedir]=/data/wwwroot/test.com:/tmp/

3、再次重启php-fpm,然后访问就正常了。

[root@jimmylinux- php-fpm.d]# /etc/init.d/php-fpm restart

如上操作,如果open_basedir定义不对,就会出问题。

生成环境中的服务器,php.ini的display_errors一定要设置成Off,不能够把错误信息显示到网站上来,而是把错误信息记录到日志存放到服务器指定的路径。

还要定义错误级别

在重启php-fpm之前,我们再故意改成一个错的路径。

[root@jimmylinux- php-fpm.d]# vim www.conf

php_admin_value[open_basedir]=/data/wwwroot/11test.com:/tmp/  故意把路径写错

[root@jimmylinux- php-fpm.d]# touch /usr/local/php-fpm/var/log/php_errors.log  创建一个错误日志文件

[root@jimmylinux- php-fpm.d]# chmod  /usr/local/php-fpm/var/log/php_errors.log  设置成777权限

重启php-fpm,再访问看看结果。

查看日志

[root@jimmylinux- php-fpm.d]# vim www.conf

php_admin_value[open_basedir]=/data/wwwroot/test.com:/tmp/  修改成正确路径

这个时候重启php-fpm,再访问就正常了。

12.24 php-fpm进程管理

php-fpm的pool、php-fpm慢执行日志、open_basedir、php-fpm进程管理的更多相关文章

  1. Linux centosVMware php-fpm的pool、php-fpm慢执行日志、open_basedir

    一.php-fpm的pool vim /usr/local/php/etc/php-fpm.conf//在[global]部分增加 include = etc/php-fpm.d/*.conf mkd ...

  2. php-fpm的pool php-fpm慢执行日志 open_basedir php-fpm进程管理

    php-fpm的pool • vim /usr/local/php/etc/php-fpm.conf//在[global]部分增加 • include = etc/php-fpm.d/*.conf • ...

  3. Linux centosVMware LAMP php-fpm的pool、php-fpm慢执行日志、open_basedir、php-fpm进程管理

    一.php-fpm的pool vim /usr/local/php/etc/php-fpm.conf//在[global]部分增加 include = etc/php-fpm.d/*.conf mkd ...

  4. php-fpm的pool池子、php慢日志记录、open_basedir、php-fpm进程管理

    1.php-fpm的poo池子:目的:可以让不同的网站,对于不同的php解析,可以把不同的网站解析区分开.编辑:vim /usr/local/php5-fpm/etc/php-fpm.conf加入: ...

  5. FastCGI 进程管理器(FPM)

    FPM(FastCGI 进程管理器)用于替换 PHP FastCGI 的大部分附加功能,对于高负载网站是非常有用的. 它的功能包括: 支持平滑停止/启动的高级进程管理功能: 可以工作于不同的 uid/ ...

  6. php-fpm 记录慢执行日志

    有时候我们访问一个 php 的网站很慢,要想知道慢的原因,需要配置 php-fpm.conf,记录执行慢的日志: [root@localhost ~]$ cat /usr/local/php/etc/ ...

  7. 【PHP】善用php-fpm的慢执行日志slow log,分析php性能问题

    (转)善用php-fpm的慢执行日志slow log,分析php性能问题  众所周知,mysql有slow query log,根据慢查询日志,我们可以知道那些sql语句有性能问题.作为mysql的好 ...

  8. .Net写txt文件-简单的记录执行日志信息代码

    在执行一些批量操作时,想记录一些执行日志信息,越简单方便越好啊.提供一个常用的简单方法,将信息记录在txt文件里: public static void log(string content, str ...

  9. composer 安装依赖缓慢,查看 composer 的详细执行日志

    在 windows WSL 上安装 composer 依赖 composer install 发现执行异常缓慢,怀疑没有走国内的镜像,而是直接访问的 github. 需要能看到 composer 的执 ...

随机推荐

  1. 关于ReentrantLock 中的lockInterruptibly方法的简单探究

    今天在看Lock,都知道相比于synchronized,多了公平锁,可中断等优秀性能. 但是说到可中断这个特点,看到很多博客是这么描述的: “与synchronized关键字不同,获取到锁的线程能够响 ...

  2. 学习笔记23_AspMVC项目

    *创建AspMVC项目 (1)会自动创建App_Data文件夹,是用户不能访问和下载的.一般用户能访问那些文件夹,可以在IIS中配置. (2)App_Start文件夹,用于放置与程序有关的配置文件. ...

  3. [LLL邀请赛]参观路线(图论+dfs)

    emmmm....学校的oj被查水表了,扒不到原题面,所以.... 但是我还是扒到了题面... 题目大意:给定一个完全图,删掉其中一些边,然后求其字典序最小的遍历顺序 有点像去年day2T1啊.... ...

  4. 因为 GitHub Actions 我发现了 Jake Wharton 的一个仓库

    本文微信公众号「AndroidTraveler」首发. 背景 昨天(2019-11-14)上去 GitHub 上面一看,结果来了个下面的提示: 点进去一看: 看来是自动化构建相关的. 那就试一下,选了 ...

  5. Linux基于webRTC的二次开发(二) 实现远程桌面共享

    webRTC中的desktop_capture模块提供了捕获桌面和捕获窗口的相关功能,而实现远程桌面共享功能需要将desktop_capture捕获的画面作为peerconnection的视频源,下面 ...

  6. linux redhat系列后缀为el5,el6,el7软件包的区别

    - EL6软件包用于在Red Hat 6.x, CentOS 6.x, and CloudLinux 6.x进行安装 - EL5软件包用于在Red Hat 5.x, CentOS 5.x, Cloud ...

  7. nyoj 47-过河问题 (贪心)

    47-过河问题 内存限制:64MB 时间限制:1000ms Special Judge: No accepted:2 submit:5 题目描述: 在漆黑的夜里,N位旅行者来到了一座狭窄而且没有护栏的 ...

  8. suseoj 1209: 独立任务最优调度问题(动态规划)

    1209: 独立任务最优调度问题 时间限制: 1 Sec  内存限制: 128 MB提交: 3  解决: 2[提交][状态][讨论版][命题人:liyuansong] 题目描述 用2台处理机A和B处理 ...

  9. ZeroC Ice发送大数据

    继上文,我们使用ZeroC Ice传递大块数据时,通常有两种做法,一种是一次请求,另一种就是分多次请求(,这种做法在官方文档有例子).选哪一种根据需要而定. 当分多次请求来完成一大块数据,到底选择每次 ...

  10. F#周报2019年第47期

    新闻 相遇WebWindow,.NET Core上的跨平台webview类库 使用Bolero在WebAssembly中运行F# 用于你团队代码库的AI辅助IntelliSense Jupyter N ...