Linux 如何定位文件锁的问题

2020-06-09

以php举例,在php里,session默认是文件存储的,同一个用户同一个cookie,session文件是固定的。

以下php说的情况都是同一个用户同一个cookie

那么,我们模拟一种情况,在一个多核CPU机器上,php-fpm设置多一点,保证,有进程可以处理请求,且资源打不满,同一个用户发起多个请求,其中一个请求 while(true)

image-20200609152817053

可以看到这里后续的请求都pending了

我们查找下原因,通过 cat /proc/locks 来查看文件锁

image-20200609153136454

我们发现了7609进程,锁住了id为3678229的文件,->表示有多少进程在等待7609释放锁,然后我们通过 lsof -p 来查看这个进程锁住了哪些文件

image-20200609153317679

通过一顿操作,我们找到了这个文件

/var/lib/php/session/sess_6r3vba026jj0dsravtubgq8rt0

一看session,也就找到原因,找响应的解决办法就可以了,譬如这里,在执行while前调用 sesssion_write_close 就可以了

其他问题类似。

Tags: Linux
使用支付宝打赏
使用微信打赏

若你觉得我的文章对你有帮助,欢迎点击上方按钮对我打赏

扫描二维码,分享此文章