session_start()卡死、session锁定导致并发阻塞 解决办法

2019-04-28 01:30:05

今天测试网站的时候,发现网站好卡的,通过php-fpm慢日志查看发现:session_start()卡死

 

通过上图就知道我使用的ajax进行异步获取数据时,一个页面中存在2个ajax异步执行!

 

根据观察ajax.php:

第一个ajax请求发起成功,这个请求得php运算100秒后才返回结果。

第二个ajax在第一个请求发起后也跟随发起请求,第二个请求php运算10秒就可以发回结果,但是结果却是得第一个请求完全执行完成返回结果后第二个才跟随返回。

 

原因:

原因在于:执行session_start()后,对应的session文件是被锁定的,直到当前脚本结束才会解锁。

session数据被锁定以防止并发写入,所以任何时候只有一个脚本可以在session上运行。

在锁定期间,另一个进程访问相同session id 要等文件解锁后session_start()才会开始。

 

解决办法

办法也非常简单,开启session后,做了相应的操作,一定要关闭session;

例如:只需要在 session 设置好数据后调用, session_write_close() 将数据写入文件并且结束session;

 

PHP示例代码如下:

如果不加入session_write_close();并发3个进程访问该页面,第一个进程执行10秒 第二个执行20秒 第三个执行30秒。

加入session_write_close()后 ,并发3个进程会同时在10秒后执行完成!

发表评论:

  • Nickname_62 :Very nice post I just stumbled upon your weblog and wanted to say that Ive truly enjoyed surfing around your blog posts After all I will be subscribing to your feed and I hope you write again very soon

  • Nickname_93 :Ive been exploring for a little bit for any highquality articles or weblog posts in this kind of area Exploring in Yahoo I ultimately stumbled upon this website Studying this info So im happy to show that I have an incredibly excellent uncanny feeling I discovered exactly what I needed I most indisputably will make sure to do not disregard this site and provides it a look on a constant basis

  • Nickname_98 :These are really enormous ideas in about blogging You have touched some fastidious points here Any way keep up wrinting

  • Nickname_680 :I was suggested this web site by way of my cousin Im now not certain whether this put up is written by way of him as nobody else realize such specific approximately my problem You are wonderful Thank you

  • Nickname_1469 :Excellent post I will be experiencing some of these issues as well

  • Nickname_1612 :If you are going for most excellent contents like me simply pay a quick visit this site all the time because it provides quality contents thanks

  • Nickname_1709 :Its going to be end of mine day but before end I am reading this enormous article to improve my knowhow

  • Nickname_2085 :Hello This post could not be written any better Reading through this post reminds me of my good old room mate He always kept chatting about this I will forward this writeup to him Pretty sure he will have a good read Many thanks for sharing

  • Nickname_2327 :Hello there I know this is kinda off topic but I was wondering which blog platform are you using for this website Im getting tired of Wordpress because Ive had problems with hackers and Im looking at alternatives for another platform I would be great if you could point me in the direction of a good platform

  • Nickname_2506 :Whats up I read your new stuff daily Your storytelling style is witty keep doing what youre doing

  • Nickname_2925 :Hey very interesting blog

  • Nickname_2960 :Hello very nice site Man Excellent Superb I will bookmark your blog and take the feeds additionally Im happy to search out numerous useful information right here in the submit we need work out extra techniques in this regard thanks for sharing

  • Nickname_3000 :Thank you a bunch for sharing this with all people you really understand what you are speaking about Bookmarked Kindly additionally visit my web site = We can have a hyperlink exchange contract among us

  • Nickname_3041 :Why visitors still use to read news papers when in this technological world everything is presented on web

  • Nickname_3212 :I think the admin of this website is really working hard for his site as here every information is quality based material

  • Nickname_4006 :Hey just wanted to give you a quick heads up The words in your content seem to be running off the screen in Chrome Im not sure if this is a formatting issue or something to do with internet browser compatibility but I figured Id post to let you know The design look great though Hope you get the problem fixed soon Cheers

  • Nickname_5615 :This is my first time visit at here and i am really pleassant to read all at one place

  • Nickname_5968 :great issues altogether you just received a emblem new reader What could you suggest in regards to your publish that you simply made a few days in the past Any sure

  • Nickname_5973 :Its an amazing paragraph in support of all the web viewers; they will take advantage from it I am sure

  • Nickname_6151 :Hello Do you know if they make any plugins to safeguard against hackers Im kinda paranoid about losing everything Ive worked hard on Any tips

  • Nickname_6845 :That is very attentiongrabbing Youre an excessively skilled blogger Ive joined your rss feed and sit up for in the hunt for extra of your excellent post Also I have shared your website in my social networks

  • Nickname_7643 :Hey would you mind letting me know which hosting company youre working with Ive loaded your blog in 3 different browsers and I must say this blog loads a lot quicker then most Can you suggest a good internet hosting provider at a fair price Many thanks I appreciate it

  • Nickname_7931 :May I just say what a relief to discover somebody that really knows what they are talking about on the net You actually understand how to bring a problem to light and make it important A lot more people really need to read this and understand this side of your story Its surprising you arent more popular given that you surely have the gift

  • Nickname_7998 :Hi I want to subscribe for this blog to obtain most recent updates thus where can i do it please help out

  • Nickname_8199 :You should take part in a contest for one of the greatest blogs online I am going to highly recommend this web site

  • Nickname_8714 :Hello to all the contents present at this site are actually awesome for people experience well keep up the good work fellows

  • Nickname_8807 :Wonderful beat I wish to apprentice while you amend your web site how could i subscribe for a blog site The account helped me a acceptable deal I had been tiny bit acquainted of this your broadcast offered bright clear idea

  • Nickname_8850 :Why visitors still make use of to read news papers when in this technological globe everything is existing on web

  • Nickname_9097 :I just could not depart your website prior to suggesting that I really loved the usual info a person provide on your guests Is going to be again regularly to check up on new posts

  • Nickname_9102 :Hello there Would you mind if I share your blog with my myspace group Theres a lot of folks that I think would really appreciate your content Please let me know Thanks

  • Nickname_9188 :I needed to thank you for this wonderful read I certainly enjoyed every little bit of it I have you bookmarked to check out new stuff you post…

  • Nickname_9520 :We are a group of volunteers and starting a new scheme in our community Your site provided us with useful information to work on You have done a formidable process and our entire neighborhood shall be thankful to you

  • Nickname_9705 :I have been surfing online greater than 3 hours nowadays yet I by no means discovered any interesting article like yours Its pretty value enough for me Personally if all web owners and bloggers made excellent content material as you probably did the internet will probably be a lot more useful than ever before

  • Nickname_9709 :Aw this was a really good post Spending some time and actual effort to produce a great article… but what can I say… I hesitate a whole lot and dont seem to get anything done

  • Nickname_10205 :Great delivery Solid arguments Keep up the great spirit

Powered by PHP 学习者(mail:517730729@qq.com)

原百度博客:http://hi.baidu.com/ssfnadn

备案号:闽ICP备17000564号-1

开源中国 PHPCHINA