PHP comes with a session hidden Danger (session file exclusive lock causes blocking)

Source: Internet
Author: User
PHP comes with a session hidden Danger (session file exclusive lock causes blocking)

PHP Default Session processor is Session.save_handler = files (that is, file). If the same client concurrently sends multiple requests (such as Ajax sending multiple requests at the same time on the page), and the script executes longer, it can cause the session file to block and affect performance. Because PHP executes session_start () for each request, the file exclusive lock is taken, and the exclusive lock is released only after the request processing has ended. In this way, multiple requests can cause blocking at the same time. The solution is as follows:

(1) After modifying the session variable, use Session_write_close () immediately to save the session data and release the file lock.

[PHP] view plaincopy

Session_Start ();

$_session[' test ' = ' test ';

Session_write_close ();

Do something



(2) using the Session_set_save_handler () function is the implementation of custom session processing.

[PHP] view plaincopy

function open ($savePath, $sessionName)

{

Echo ' Open is called ';

return true;

}

function Close ()

{

Echo ' Close is called ';

return true;

}

function Read ($SESSIONID)

{

Echo ' read is called ';

Return ';

}

function Write ($sessionId, $data)

{

Echo ' write is called ';

return true;

}

function Destroy ($SESSIONID)

{

Echo ' destroy is called ';

return true;

}

Function GC ($LIFETIME)

{

Echo ' GC is called ';

return true;

}

Session_set_save_handler ("Open", "close", "read", "write", "Destroy", "GC");

Register_shutdown_function (' Session_write_close ');

Session_Start ();

$_session[' foo '] = "bar";



Of course, after PHP 5.4.0, you can use it by implementing the Sessionhandlerinterface interface or inheriting the Sessionhandler class.

[PHP] view plaincopy

Class Mysessionhandler extends Sessionhandler {

Public Function __construct ()

{

}

Public function open ($save _path, $session _id)

{

}

Public Function Close ()

{

}

Public Function Create_sid ()

{

}

Public function read ($id)

{

}

Public function Write ($id, $data)

{

}

Public function Destroy ($ID)

{

}

}

$handler = new Mysessionhandler ();

The 2nd parameter registers the function Session_write_close () as a register_shutdown_function () function.

Session_set_save_handler ($handler, true);



You can implement and encapsulate the code above, using MySQL or other in-memory databases to manage session data. It can also solve the problem of session data sharing when using cluster.



Reference Source:
PHP comes with a session hidden Danger (session file exclusive lock causes blocking)
Http://www.lai18.com/content/407206.html

  • Contact Us

    The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

    If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.