在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
关于信号处理
参数调优进程数
max_children
start_servers
最大请求数max_requests
最长执行时间request_terminate_timeoutmax_execution_time和request_terminate_timeout
内存|CPU排查方法top命令格式: <code class="language-liunx hljs scss has-numbering"><span class="hljs-attribute">top</span> <span class="hljs-attr_selector">[-]</span> <span class="hljs-attr_selector">[d]</span> <span class="hljs-attr_selector">[p]</span> <span class="hljs-attr_selector">[q]</span> <span class="hljs-attr_selector">[c]</span> <span class="hljs-attr_selector">[C]</span> <span class="hljs-attr_selector">[S]</span> <span class="hljs-attr_selector">[n]</span> </code><ul style="" class="pre-numbering"><li>1</li></ul> 参数说明: sar执行sar -P ALL 1 100。-P ALL表示监控所有核心,1表示每1秒采集,100表示采集100次。 开启慢日志配置输出php-fpm慢日志,阀值为2秒: <code class="language-php-fpm hljs perl has-numbering">request_slowlog_timeout = <span class="hljs-number">2</span> slowlog = <span class="hljs-keyword">log</span>/<span class="hljs-variable">$pool</span>.<span class="hljs-keyword">log</span>.slow</code><ul style="" class="pre-numbering"><li>1</li><li>2</li></ul> 利用sort/uniq命令分析汇总php-fpm慢日志:
参数解释: 用strace跟踪进程
PHP-fpm配置文件注释<code class="language-php-fpm hljs vala has-numbering">pid = run/php-fpm.pid <span class="hljs-preprocessor">#pid设置,默认在安装目录中的var/run/php-fpm.pid,建议开启</span> error_log = log/php-fpm.log <span class="hljs-preprocessor">#错误日志,默认在安装目录中的var/log/php-fpm.log</span> log_level = notice <span class="hljs-preprocessor">#错误级别. 可用级别为: alert(必须立即处理), error(错误情况), warning(警告情况), notice(一般重要信息), debug(调试信息). 默认: notice.</span> emergency_restart_threshold = <span class="hljs-number">60</span> emergency_restart_interval = <span class="hljs-number">60</span>s <span class="hljs-preprocessor">#表示在emergency_restart_interval所设值内出现SIGSEGV或者SIGBUS错误的php-cgi进程数如果超过 emergency_restart_threshold个,php-fpm就会优雅重启。这两个选项一般保持默认值。</span> process_control_timeout = <span class="hljs-number">0</span> <span class="hljs-preprocessor">#设置子进程接受主进程复用信号的超时时间. 可用单位: s(秒), m(分), h(小时), 或者 d(天) 默认单位: s(秒). 默认值: 0.</span> daemonize = yes <span class="hljs-preprocessor">#后台执行fpm,默认值为yes,如果为了调试可以改为no。在FPM中,可以使用不同的设置来运行多个进程池。 这些设置可以针对每个进程池单独设置。</span> listen = <span class="hljs-number">127.0</span><span class="hljs-number">.0</span><span class="hljs-number">.1</span>:<span class="hljs-number">9000</span> <span class="hljs-preprocessor">#fpm监听端口,即nginx中php处理的地址,一般默认值即可。可用格式为: 'ip:port', 'port', '/path/to/unix/socket'. 每个进程池都需要设置.</span> listen.backlog = -<span class="hljs-number">1</span> <span class="hljs-preprocessor">#backlog数,-1表示无限制,由操作系统决定,此行注释掉就行。backlog含义参考:http://www.3gyou.cc/?p=41</span> listen.allowed_clients = <span class="hljs-number">127.0</span><span class="hljs-number">.0</span><span class="hljs-number">.1</span> <span class="hljs-preprocessor">#允许访问FastCGI进程的IP,设置any为不限制IP,如果要设置其他主机的nginx也能访问这台FPM进程,listen处要设置成本地可被访问的IP。默认值是any。每个地址是用逗号分隔. 如果没有设置或者为空,则允许任何服务器请求连接</span> listen.owner = www listen.group = www listen.mode = <span class="hljs-number">0666</span> <span class="hljs-preprocessor">#unix socket设置选项,如果使用tcp方式访问,这里注释即可。</span> user = www group = www <span class="hljs-preprocessor">#启动进程的帐户和组</span> pm = dynamic #对于专用服务器,pm可以设置为<span class="hljs-keyword">static</span>。 <span class="hljs-preprocessor">#如何控制子进程,选项有static和dynamic。如果选择static,则由pm.max_children指定固定的子进程数。如果选择dynamic,则由下开参数决定:</span> pm.max_children #,子进程最大数 pm.start_servers #,启动时的进程数 pm.min_spare_servers #,保证空闲进程数最小值,如果空闲进程小于此值,则创建新的子进程 pm.max_spare_servers #,保证空闲进程数最大值,如果空闲进程大于此值,此进行清理 pm.max_requests = <span class="hljs-number">1000</span> <span class="hljs-preprocessor">#设置每个子进程重生之前服务的请求数. 对于可能存在内存泄漏的第三方模块来说是非常有用的. 如果设置为 '0' 则一直接受请求. 等同于 PHP_FCGI_MAX_REQUESTS 环境变量. 默认值: 0.</span> pm.status_path = /status <span class="hljs-preprocessor">#FPM状态页面的网址. 如果没有设置, 则无法访问状态页面. 默认值: none. munin监控会使用到</span> ping.path = /ping <span class="hljs-preprocessor">#FPM监控页面的ping网址. 如果没有设置, 则无法访问ping页面. 该页面用于外部检测FPM是否存活并且可以响应请求. 请注意必须以斜线开头 (/)。</span> ping.response = pong <span class="hljs-preprocessor">#用于定义ping请求的返回相应. 返回为 HTTP 200 的 text/plain 格式文本. 默认值: pong.</span> request_terminate_timeout = <span class="hljs-number">0</span> <span class="hljs-preprocessor">#设置单个请求的超时中止时间. 该选项可能会对php.ini设置中的'max_execution_time'因为某些特殊原因没有中止运行的脚本有用. 设置为 '0' 表示 'Off'.当经常出现502错误时可以尝试更改此选项。</span> request_slowlog_timeout = <span class="hljs-number">10</span>s <span class="hljs-preprocessor">#当一个请求该设置的超时时间后,就会将对应的PHP调用堆栈信息完整写入到慢日志中. 设置为 '0' 表示 'Off'</span> slowlog = log/$pool.log.slow <span class="hljs-preprocessor">#慢请求的记录日志,配合request_slowlog_timeout使用</span> rlimit_files = <span class="hljs-number">1024</span> <span class="hljs-preprocessor">#设置文件打开描述符的rlimit限制. 默认值: 系统定义值默认可打开句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。</span> rlimit_core = <span class="hljs-number">0</span> <span class="hljs-preprocessor">#设置核心rlimit最大限制值. 可用值: 'unlimited' 、0或者正整数. 默认值: 系统定义值.</span> chroot = <span class="hljs-preprocessor">#启动时的Chroot目录. 所定义的目录需要是绝对路径. 如果没有设置, 则chroot不被使用.</span> chdir = <span class="hljs-preprocessor">#设置启动目录,启动时会自动Chdir到该目录. 所定义的目录需要是绝对路径. 默认值: 当前目录,或者/目录(chroot时)</span> catch_workers_output = yes <span class="hljs-preprocessor">#重定向运行过程中的stdout和stderr到主要的错误日志文件中. 如果没有设置, stdout 和 stderr 将会根据FastCGI的规则被重定向到 /dev/null . 默认值: 空.</span></code><ul style="" class="pre-numbering"><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li><li>21</li><li>22</li><li>23</li><li>24</li><li>25</li><li>26</li><li>27</li><li>28</li><li>29</li><li>30</li><li>31</li><li>32</li><li>33</li><li>34</li><li>35</li><li>36</li><li>37</li><li>38</li><li>39</li><li>40</li><li>41</li><li>42</li><li>43</li><li>44</li><li>45</li><li>46</li><li>47</li><li>48</li><li>49</li><li>50</li><li>51</li><li>52</li><li>53</li><li>54</li><li>55</li><li>56</li><li>57</li><li>58</li><li>59</li><li>60</li><li>61</li><li>62</li><li>63</li><li>64</li><li>65</li><li>66</li><li>67</li><li>68</li><li>69</li><li>70</li><li>71</li><li>72</li><li>73</li><li>74</li><li>75</li><li>76</li><li>77</li><li>78</li><li>79</li></ul> 总结篇502
504错误主要查看nginx.conf关于网关如fastcgi的配置 request_terminate_timeout设置0或者过长问题(502)如果设置为0或者过长的时间,可能会引起file_get_contents的资源问题。
max_requests参数配置不当,可能会引起间歇性502错误php-fpm的慢日志,debug及异常排查神参考资料 1)php-fpm优化方法汇总 2)多Sock文件和php-fpm实例配置 3) Nginx+PHP-FPM优化技巧总结 |
2022-07-18
2022-08-17
2022-11-06
2022-08-18
2022-08-16
请发表评论