記一次debug -- php的session_start timeout

今天回到公司,打開電腦嗽仪,循例摸完魚(劃掉)之后準備開始工作荒勇,打開Chrome,打開本地后臺闻坚,等了好久之后沽翔,給我報了time out


image.png

??仅偎?PHP掛掉了跨蟹?先去看下PHP進程在不在

image.png

進程還在?是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)該也能解決這個問題韧拒,不過這個辦法并沒有真正解決問題。

以上十性。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末叛溢,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子劲适,更是在濱河造成了極大的恐慌楷掉,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件霞势,死亡現(xiàn)場離奇詭異烹植,居然都是意外死亡,警方通過查閱死者的電腦和手機愕贡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門草雕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人固以,你說我怎么就攤上這事。” “怎么了败晴?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長稳懒。 經(jīng)常有香客問我,道長慢味,這世上最難降的妖魔是什么场梆? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮纯路,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘驰唬。我一直安慰自己,他們只是感情好叫编,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布辖佣。 她就那樣靜靜地躺著,像睡著了一般搓逾。 火紅的嫁衣襯著肌膚如雪卷谈。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天世蔗,我揣著相機與錄音朗兵,去河邊找鬼污淋。 笑死矛市,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的浊吏。 我是一名探鬼主播救氯,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼找田,長吁一口氣:“原來是場噩夢啊……” “哼着憨!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤心铃,失蹤者是張志新(化名)和其女友劉穎挫剑,沒想到半個月后去扣,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體樊破,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年奔滑,在試婚紗的時候發(fā)現(xiàn)自己被綠了顺少。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片朋其。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡梅猿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出粒没,到底是詐尸還是另有隱情,我是刑警寧澤癞松,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布入蛆,位于F島的核電站响蓉,受9級特大地震影響哨毁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜扼褪,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望话浇。 院中可真熱鬧,春花似錦幔崖、人聲如沸渣淤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽自娩。三九已至,卻和暖如春椒功,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背动漾。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留旱眯,地道東北人。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像呀页,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蓬蝶,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354