[TOC]
# PHP慢腳本日志
間歇性的502,是后端 PHP-FPM 不可用造成的,間歇性的502一般認為是由于 PHP-FPM 進程重啟造成的。
在 PHP-FPM 的子進程數目超過的配置中的數量時候,會出現間歇性的502錯誤,如果在配置中設置了max_requests的話,超過數量也會出現502錯誤,而max_requests的設置,正是為了防止不安全的第三方library腳本的 內存泄露 ,當然你自己編寫的腳本存在 死鎖 的話,也會出現502現象。
如果你發現mysql負載并不高,但是php-fpm的進程數和內存占用過高的話,恭喜你,大多數情況下是因為腳本存在死鎖。
既然找到了是php的問題,如何去定位php腳本呢?
開啟php慢查詢日志:
~~~
$ sudo vi /usr/loal/php/etc/php-fpm.conf
; Default Value: 0
request_slowlog_timeout = 1s
; The log file for slow requests
; Default Value: /usr/local/php/log/php-fpm.log.slow
slowlog = /usr/local/php/log/php-fpm.log.slow
~~~
默認的 request_slowlog_timeout 是0,php的慢腳本日志是關閉的,因此設置為大于0的n,表示執行時間超過n的腳本將記錄進入slowlog里。
然后監測到網站存在問題的時候查看下slowlog即可發現慢腳本,對腳本進行檢查處理即可。
* slowlog 設置慢查詢日志的生成目錄
* request_slowlog_timeout 設置慢查詢的標準時間(打開此配置就相當于開啟了慢查詢日志),配置以秒為單位,一般設置3s。
# php-error錯誤日志
一般情況下,php錯誤日志的配置都在php.ini文件中
* error_log 錯誤日志的生成目錄
* error_reporting 生產環境錯誤級別應全開
* display_errors 在頁面上不顯示錯誤
* log_errors 開啟錯誤日志
最終的結果是
~~~
error_log = /var/log/php_error.log
display_errors = Off
error_reporting = E_ALL
log_errors = On
~~~
開發的時候把display_errors設置為On
- OAuth
- 簡介
- 步驟
- 單點登錄
- .user.ini
- 時間轉換為今天昨天前天幾天前
- 獲取ip接口
- 協程
- 概念
- yield-from && return-values
- 協程與阻塞的思考
- 中間件
- mysqli異步與php的協程
- 代碼片段
- pdo 執行的sql語句
- 二進制安全
- 捕捉異常中斷
- global
- 利用cookie模擬登陸
- 解析非正常json
- 簡單的對稱加密算法
- RSA 加密
- 過濾掉emoji表情
- 判斷遠程圖片是否存在
- 一分鐘限制請求100次
- 文件處理
- 多文件上傳
- 顯示所有文件
- 文件下載和上面顯示所有文件配合
- 文件的刪除,統計,存數組等
- 圖片處理
- 簡介
- 驗證碼
- 圖片等比縮放
- 批量添加水印
- beanstalkd
- 安裝
- 使用
- RabbitMQ
- 簡介
- debain安裝
- centos安裝
- 常用方法
- 入門
- 工作隊列
- 訂閱,發布
- 路由
- 主題
- 遠程調用RPC
- 消息中間件的選型
- .htaccess
- isset、empty、if區別以及0、‘’、null
- php各版本
- php7.2 不向后兼容的改動
- php中的各種坑
- php7改變
- php慢日志
- 郵件
- PHPMailer實現發郵件
- 驗證郵件地址真實性
- 文件下載
- FastCgi 與 PHP-fpm 之間的關系
- openssl 加解密
- 反射
- 鉤子方法
- 查找插件
- opcode
- opcache使用
- opcache優化
- 分布式一致性hash算法
- 概念
- 哈希算法好壞的四個定義
- php實現
- java實現
- 數組
- jwt
- jwt簡介
- 單點登錄
- phpize
- GeoIP擴展
- php無法獲得https網頁內容的解決方案
- homestead運行的腳本
- Unicode和Utf-8轉換
- php優化
- kafka
- fpm配置
- configure配置詳解