INSERT DELAYED on locked tables blocks PHP processes to continue

Posted by sw0x2A on Server Fault See other posts from Server Fault or by sw0x2A
Published on 2011-01-03T18:43:01Z Indexed on 2011/01/03 18:55 UTC
Read the original article Hit count: 228

Filed under:
|

Our webservers write some tracking information into a MySQL database (using INSERT DELAYED into MyISAM table). When a huge SELECT query is executed on this table or when it is locked for another reason, the webserver processes (with INSERT DELAYED) are waiting for the database and in some cases the MaxServer limit is reached in Apaches, so they will stop serving requests.

We use INSERT DELAYED because

The DELAYED option for the INSERT statement is a MySQL extension to standard SQL that is very useful if you have clients that cannot or need not wait for the INSERT to complete. This is a common situation when you use MySQL for logging and you also periodically run SELECT and UPDATE statements that take a long time to complete.

Quote from MySQL documentation.

I am wondering why the Apache processes are waiting for the INSERT DELAYED to finish. And what can I do to just send the data and forget about it. (Since this is logging data, I do not care if we lose some entries.) Even when the table is locked the PHP script should just go on and should not wait for an answer of MySQL.

(We do not want to setup Master-slave for this table but we are thinking about move this data to some NoSQL database. But for now I would like to know why INSERT DELAYED is not working as expected.)

© Server Fault or respective owner

Related posts about mysql

Related posts about php