Reputation: 4267
This is driving me nuts for a while now. I have an ajax
call like so:
function update()
{
$.get("update.php", function(data)
{
$("#output-progress").html(data);
});
}
And I call it like so:
window.setInterval(function()
{
update();
}, 2000);
}
Then I have another calc function which is also called:
function calc()
{
$.get("calc.php", function(data)
{
//whole bunch of lines to re-render page
});
}
So the idea is that while calc()
is running, the update()
will periodically update a div on the progress.
However what is happening is that if I open the console and check the calls to update()
is triggered every 5 seconds, but they just stall and they complete only after the calc()
has returned. I first thought this was a browser/jQuery
issue, but if I log both the functions into separate log files in PHP then the update()
gets logged only after the calc()
finishes!
Im not sure what is going on here, any pointers are greatly appreciated!
Upvotes: 0
Views: 230
Reputation: 5668
Most likely, you are using sessions, and both calc.php
and update.php
access session data. In order to ensure data consistency in sessions, access to session data is locked, so only one php process can access the session at a time. This means that while calc.php
has the session, no other page access can read it.
What you will want to do is call session_write_close() after calc.php
has finished anything that might require access to the session, and before it starts its time-consuming task.
session_write_close()
writes the current session's data and releases the lock. Once calc.php
is no longer holding to the session, accesses from update.php
can read it.
Upvotes: 1