如何使用 MySQL 和 PHP 关闭(杀死)执行时间过长的连接
问问题
1402 次
1 回答
3
解决方案是编写一个存储过程,在一段时间内杀死所有连接:
DELIMITER //
DROP PROCEDURE IF EXISTS ClearDB//
CREATE PROCEDURE ClearDB()
BEGIN
DECLARE nID, bCursor INT;
DECLARE cursorQuery CURSOR FOR
SELECT ID
FROM information_schema.processlist
WHERE `TIME` > 10;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET bCursor = 1;
OPEN cursorQuery;
SET bCursor = 0;
WHILE bCursor = 0 DO
FETCH cursorQuery INTO nID;
KILL nID;
END WHILE;
CLOSE cursorQuery;
END //
DELIMITER ;
该过程非常简单:获取 TIME 大于 10 的所有连接 ID,遍历结果并终止它们
您可以创建一个 cron 任务来调用 ClearDB() 过程,或者您可以在每次打开这样的新连接时调用它:
$pDB = new mysqli('localhost', 'user', 'pass', 'database');
if ($pDB->connect_error)
{
// Handle the error
}
$pDB->query('CALL ClearDB()');
希望它会帮助某人:)
于 2012-11-27T09:16:40.610 回答