今天回到公司,打開電腦嗽仪,循例摸完魚(劃掉)之后準備開始工作荒勇,打開Chrome,打開本地后臺闻坚,等了好久之后沽翔,給我報了time out
??仅偎?PHP掛掉了跨蟹?先去看下PHP進程在不在
進程還在?是redis或者mysql的超時嗎橘沥?
用Navicat連了一下mysql窗轩,可以連。連了一下本地redis座咆,也沒問題痢艺。那是php本身的問題?
看了一下php和php-fpm錯誤日志介陶,也沒有報錯和異常堤舒,在腳本里面斷點也能夠打印出來,這就很奇怪了哺呜。
俗話說得好舌缤,沒有什么問題是重啟不能解決的,如果有某残,那就重裝系統(tǒng)(誤)国撵。
然后我把php和nginx都重啟了一遍,發(fā)現(xiàn)還是超時玻墅。不過執(zhí)行沒出錯介牙,超時的問題我已經(jīng)可以定位是php的問題了。然后我想起之前配置php-fpm的時候看到過有個slowlog慢日志的配置椭豫。
; The log file for slow requests
; Default Value: not set
; Note: slowlog is mandatory if request_slowlog_timeout is set
slowlog = /usr/local/php/7.1.29/var/log/$pool.log.slow
; The timeout for serving a single request after which a PHP backtrace will be
; dumped to the 'slowlog' file. A value of '0s' means 'off'.
; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
; Default Value: 0
request_slowlog_timeout = 10
打開慢日志耻瑟,把慢請求的時間設(shè)置為10秒
PS:request_slowlog_timeout設(shè)置為0會把慢日志關(guān)閉(dumped to the 'slowlog' file. A value of '0s' means 'off')
然后重啟php-fpm,執(zhí)行一遍赏酥,查看慢日志
[25-Jun-2019 14:17:38] [pool caisiming] pid 73482
script_filename = backend/web/index.php
[0x0000000103c197f0] session_start() vendor/yiisoft/yii2/web/Session.php:131
[0x0000000103c19690] open() vendor/yiisoft/yii2/web/Session.php:583
[0x0000000103c195c0] get() vendor/yiisoft/yii2/web/User.php:658
[0x0000000103c191b0] renewAuthStatus() vendor/yiisoft/yii2/web/User.php:188
[0x0000000103c190e0] getIdentity() vendor/yiisoft/yii2/web/User.php:340
[0x0000000103c19070] getIsGuest() common/controllers/Controller.php:31
[0x0000000103c18de0] init() vendor/yiisoft/yii2/base/Object.php:107
[0x0000000103c18d30] __construct() vendor/yiisoft/yii2/base/Controller.php:84
[0x0000000103c18c80] __construct() vendor/yiisoft/yii2/di/Container.php:373
[0x0000000103c18c20] newInstanceArgs() vendor/yiisoft/yii2/di/Container.php:373
[0x0000000103c18940] build() vendor/yiisoft/yii2/di/Container.php:154
[0x0000000103c18600] get() vendor/yiisoft/yii2/BaseYii.php:340
[0x0000000103c18440] createObject() vendor/yiisoft/yii2/base/Module.php:569
[0x0000000103c180f0] createControllerByID() vendor/yiisoft/yii2/base/Module.php:522
[0x0000000103c17d30] createController() vendor/yiisoft/yii2/base/Module.php:514
[0x0000000103c17970] createController() vendor/yiisoft/yii2/base/Module.php:448
[0x0000000103c176f0] runAction() vendor/yiisoft/yii2/web/Application.php:100
[0x0000000103c17390] handleRequest() vendor/yiisoft/yii2/base/Application.php:375
代碼最后執(zhí)行的是session_start函數(shù),看來是這一步超時了谆构,接下來就好辦了裸扶,google一下"session_start超時"。
得到的結(jié)果都是添加因為session文件鎖住了搬素,后面的請求沒有辦法獲取到session handler呵晨,導致了死鎖,從而請求超時熬尺。網(wǎng)上的建議是使用session_write_close函數(shù)摸屠。
好,拿到結(jié)果馬上干粱哼。但是我加上去之后完全沒有效果季二,還是超時。繼續(xù)google往下翻,還是一樣的結(jié)論胯舷,看來是彼之蜜糖刻蚯,吾之砒霜啊。
問題是找到了桑嘶,但是沒有解決辦法炊汹,總得要干活的吧,沒辦法逃顶,只好把session文件刪掉讨便,文件不存在了,鎖也應(yīng)該不存在了吧以政。
皮之不存器钟,毛將焉附
網(wǎng)上找到php的session文件在mac的存放位置
/private/var/tmp/
/var/tmp/
// 兩個目錄是一樣的
刪掉全部session文件,再運行項目妙蔗,就可以正常跑了傲霸。
結(jié)論:網(wǎng)上找的方法沒有用,我個人猜想是有個php子進程掛掉了眉反,或者成了僵尸進程昙啄?然后鎖住了session文件呵曹,我打開瀏覽器之后session還沒過期只怎,一直請求這個session,所以導致了死鎖疙教。
這樣想的話梳杏,那我在瀏覽器端刪掉sessionID應(yīng)該也能解決這個問題韧拒,不過這個辦法并沒有真正解決問題。
以上十性。