Maison >base de données >tutoriel mysql >Explication détaillée sur l'utilisation de la commande kill pour résoudre le problème de blocage dans Mysql

Explication détaillée sur l'utilisation de la commande kill pour résoudre le problème de blocage dans Mysql

黄舟
黄舟original
2017-06-18 10:45:062295parcourir

Cet article présente principalement les informations pertinentes sur Mysql utilisant la commande kill pour résoudre le problème de blocage (tuer une instruction SQL en cours d'exécution. Les amis dans le besoin peuvent se référer à

lors de l'exécution de certains). déclarations utilisant mysql dans , un blocage se produira en raison de la grande quantité de données, qui n'est pas reflétée. À ce stade, vous devez supprimer une instruction de requête qui consomme des ressources. Le format de syntaxe de la commande KILL est le suivant :


KILL [CONNECTION | QUERY] thread_id

Chaque connexion à mysqld en cours d'exécution. dans un thread séparé, vous pouvez utiliser l'instruction SHOW PROCESSLIST pour voir quels threads sont en cours d'exécution et utiliser l'instruction KILL thread_id pour terminer un thread.

KILL autorise les modificateurs facultatifs CONNECTION ou QUERY : KILL CONNECTION est le même que KILL sans modificateurs : il termine la connexion associée au thread_id donné. KILL QUERY termine l'instruction en cours d'exécution sur la connexion, mais laisse la connexion intacte.

Si vous disposez de l'autorisation PROCESS, vous pouvez afficher tous les fils de discussion. Si vous disposez des privilèges de super-administrateur, vous pouvez mettre fin à tous les threads et instructions. Sinon, vous pouvez uniquement afficher et mettre fin à vos propres fils de discussion et déclarations. Vous pouvez également utiliser les commandes mysqladmin processlist et mysqladmin kill pour vérifier et tuer les threads.

Connectez-vous d'abord à MySQL, puis utilisez : show processlist; pour afficher le statut de chaque thread dans le mysql actuel.


mysql> show processlist; 
+------+------+----------------------+----------------+---------+-------+-----------+---------------------  
| Id  | User | Host         | db       | Command | Time | State   | Info 
+------+------+----------------------+----------------+---------+-------+-----------+---------------------  
| 7028 | root | ucap-devgroup:53396 | platform    | Sleep  | 19553 |      | NULL  
| 8352 | root | ucap-devgroup:54794 | platform    | Sleep  | 4245 |      | NULL 
| 8353 | root | ucap-devgroup:54795 | platform    | Sleep  |   3 |      | NULL 
| 8358 | root | ucap-devgroup:62605 | platform    | query  | 4156 | updating | update t_shop set |

Ce ci-dessus montre la liste des instructions SQL en cours d'exécution. Trouvez l'identifiant correspondant à l'instruction qui consomme le plus de ressources.

Ensuite. exécutez la commande kill, le format de commande est le suivant :


kill id; 
- 示例: 
kill 8358

Tuez-le simplement.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn