转:解决mysql锁表最终方法
转:解决mysql锁表终极方法 很多时候!一不小心就锁表!这里讲解决锁表终极方法! 案例一 mysqlshow?processlist; 参看sql语句 一般少的话 mysqlkill?thread_id; 就可以解决了 kill掉第一个锁表的进程,?依然没有改善.?既然不改善,?咱们就想办法将所有锁表的进
转:解决mysql锁表终极方法很多时候!一不小心就锁表!这里讲解决锁表终极方法!
案例一
mysql>show?processlist;
参看sql语句
一般少的话
mysql>kill?thread_id;
就可以解决了
kill掉第一个锁表的进程,?依然没有改善.?既然不改善,?咱们就想办法将所有锁表的进程kill掉吧,?简单的脚本如下.
#!/bin/bash
mysql?-u?root?-e?"show?processlist"?|?grep?-i?"Locked"?>>?locked_log.txt
for?line?in?`cat?locked_log.txt?|?awk?'{print?$1}'`
do?
echo?"kill?$line;"?>>?kill_thread_id.sql
done
现在kill_thread_id.sql的内容像这个样子
kill?66402982;
kill?66402983;
kill?66402986;
kill?66402991;
.....
好了,?我们在mysql的shell中执行,?就可以把所有锁表的进程杀死了.
mysql>source?kill_thread_id.sql
当然了,?也可以一行搞定
for?id?in?`mysqladmin?processlist?|?grep?-i?locked?|?awk?'{print?$1}'`
do
mysqladmin?kill?${id}
done?
案例二?如果大批量的操作能够通过一系列的select语句产生,那么理论上就能对这些结果批量处理。
但是mysql并没用提供eval这样的对结果集进行分析操作的功能。所以只能现将select结果保存到临时文件中,然后再执行临时文件中的指令。
具体过程如下:mysql>?SELECT?concat('KILL?',id,';')?FROM?information_schema.processlist?WHERE?user='root';
+------------------------+
|?concat('KILL?',id,';')?
+------------------------+
|?KILL?3101;?????????????
|?KILL?2946;?????????????
+------------------------+
2?rows?IN?SET?(0.00?sec)mysql>?SELECT?concat('KILL?',id,';')?FROM?information_schema.processlist?WHERE?user='root'?INTO?OUTFILE?'/tmp/a.txt';
Query?OK,?2?rows?affected?(0.00?sec)mysql>?source?/tmp/a.txt;
Query?OK,?0?rows?affected?(0.00?sec)??
案例三?MySQL?+?PHP的模式在大并发压力下经常会导致MySQL中存在大量僵死进程,导致服务挂死。为了自动干掉这些进程,弄了个脚本,放在服务器后台通过crontab自动执行。发现这样做了以后,的确很好的缓解了这个问题。把这个脚本发出来和大家Share.?根据自己的实际需要,做了一些修改:
SHELL脚本:mysqld_kill_sleep.sh
#!/bin/sh?
mysql_pwd="root的密码"?
mysqladmin_exec="/usr/local/bin/mysqladmin"?
mysql_exec="/usr/local/bin/mysql"?
mysql_timeout_dir="/tmp"?
mysql_timeout_log="$mysql_timeout_dir/mysql_timeout.log"?
mysql_kill_timeout_sh="$mysql_timeout_dir/mysql_kill_timeout.sh"?
mysql_kill_timeout_log="$mysql_timeout_dir/mysql_kill_timeout.log"?
$mysqladmin_exec?-uroot?-p"$mysql_pwd"?processlist?|?awk?'{?print?$12?,?$2?,$4}'?|?grep?-v?Time?|?grep?-v?'|'?|?sort?-rn?>?$mysql_timeout_log?
awk?'{if($1>30?&&?$3!="root")?print?"'""$mysql_exec""'?-e?"?"\""?"kill",$2?"\""?"?-uroot?"?"-p""\"""'""$mysql_pwd""'""\""?";"?}'?$mysql_timeout_log?>?$mysql_kill_timeout_sh?
echo?"check?start?...."?>>?$mysql_kill_timeout_log?
echo?`date`?>>?$mysql_kill_timeout_log?
cat?$mysql_kill_timeout_sh把这个写到mysqld_kill_sleep.sh。然后chmod?0?mysqld_kill_sleep.sh,chmod?u+rx?mysqld_kill_sleep.sh,然后用root账户到cron里面运行即可,时间自己调整。?
执行之后显示:?
www#?./mysqld_kill_sleep.sh?
/usr/local/bin/mysql?-e?"kill?27549"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27750"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27840"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27867"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27899"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27901"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27758"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27875"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27697"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27888"?-uroot?-p"mysql?root的密码";?
/usr/local/bin/mysql?-e?"kill?27861"?-uroot?-p"mysql?root的密码";
如果确认没有问题了,把最后的cat修改为sh即可。
本人改写了下上面的脚本:
#!/bin/bash?
mysql_pwd="密码"?
mysql_exec="/usr/local/mysql/bin/mysql"?
mysql_timeout_dir="/tmp"?
mysql_kill_timeout_sh="$mysql_timeout_dir/mysql_kill_timeout.sh"?
mysql_kill_timeout_log="$mysql_timeout_dir/mysql_kill_timeout.log"?
$mysql_exec?-uroot?-p$mysql_pwd?-e?"show?processlist"?|?grep?-i?"Locked"?>>?$mysql_kill_timeout_log?
chmod?777?$mysql_kill_timeout_log?
for?line?in?`$mysql_kill_timeout_log??|?awk?'{print?$1}'`?
do?
echo?"$mysql_exec?-uroot?-p$mysql_pwd?-e?\"kill?$line\""?>>?$mysql_kill_timeout_sh?
done?
chmod?777?$mysql_kill_timeout_sh?
cat?$mysql_kill_timeout_sh?是不是很方便呢!
最后贴个我在用的脚本
?
1 2 3 4 5 |
#!/bin/bash
mysql -uroot -pxxxxx -e? "show processlist" ?| grep ?-i? "Lock" ?| awk ?'{print $1}' ?>sqlid.sql
sed ?-i? 's/^/kill\ /g' ?
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
kill 2;
kill 1088;
kill 1265;
kill 1274;
kill 1287;
kill 1288;
kill 1289;
kill 1290;
kill 1291;
kill 1295;
kill 1296;
kill 1298;
kill 1299;
kill 1302;
kill 1304;
kill 1305;
kill 1309;
|
?
文章转自:http://hi.baidu.com/hunter6536/item/844223c05f0a9934449416ad

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

可以通過以下步驟打開 phpMyAdmin:1. 登錄網站控制面板;2. 找到並點擊 phpMyAdmin 圖標;3. 輸入 MySQL 憑據;4. 點擊 "登錄"。

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

Redis 使用單線程架構,以提供高性能、簡單性和一致性。它利用 I/O 多路復用、事件循環、非阻塞 I/O 和共享內存來提高並發性,但同時存在並發性受限、單點故障和不適合寫密集型工作負載的局限性。

MySQL和SQL是開發者必備技能。 1.MySQL是開源的關係型數據庫管理系統,SQL是用於管理和操作數據庫的標準語言。 2.MySQL通過高效的數據存儲和檢索功能支持多種存儲引擎,SQL通過簡單語句完成複雜數據操作。 3.使用示例包括基本查詢和高級查詢,如按條件過濾和排序。 4.常見錯誤包括語法錯誤和性能問題,可通過檢查SQL語句和使用EXPLAIN命令優化。 5.性能優化技巧包括使用索引、避免全表掃描、優化JOIN操作和提升代碼可讀性。

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

直接從數據庫中恢復被刪除的行通常是不可能的,除非有備份或事務回滾機制。關鍵點:事務回滾:在事務未提交前執行ROLLBACK可恢復數據。備份:定期備份數據庫可用於快速恢復數據。數據庫快照:可創建數據庫只讀副本,在數據誤刪後恢復數據。慎用DELETE語句:仔細檢查條件,避免誤刪數據。使用WHERE子句:明確指定要刪除的數據。使用測試環境:在執行DELETE操作前進行測試。
