下文給大家?guī)碛嘘P(guān)檢查MySQL數(shù)據(jù)是否一致用到的工具內(nèi)容,相信大家一定看過類似的文章。我們給大家?guī)淼挠泻尾煌??一起來看看正文部分吧,相信看完檢查MySQL數(shù)據(jù)是否一致用到的工具你一定會有所收獲。
作為一家“創(chuàng)意+整合+營銷”的成都網(wǎng)站建設(shè)機(jī)構(gòu),我們在業(yè)內(nèi)良好的客戶口碑。創(chuàng)新互聯(lián)提供從前期的網(wǎng)站品牌分析策劃、網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站、創(chuàng)意表現(xiàn)、網(wǎng)頁制作、系統(tǒng)開發(fā)以及后續(xù)網(wǎng)站營銷運(yùn)營等一系列服務(wù),幫助企業(yè)打造創(chuàng)新的互聯(lián)網(wǎng)品牌經(jīng)營模式與有效的網(wǎng)絡(luò)營銷方法,創(chuàng)造更大的價(jià)值。
1、MySQL checksum命令
在執(zhí)行checksum命令時(shí),表會被加一個讀鎖(read lock),checksum table的原理是對表中的數(shù)據(jù)進(jìn)行一行一行的較驗(yàn)和計(jì)算,因些對于大表,這是一個很耗時(shí)的過程。
如果對于myisam表,建表時(shí)加上CHECKSUM=1選項(xiàng),那么在對這樣的表進(jìn)行checksum table時(shí)將會非???/p>
checksum table test.tbname;
root@test09:43:36>checksum table test.tbname;
+-------------+------------+
| Table | Checksum |
+-------------+------------+
| test.tbname | 1105600045 |
+-------------+------------+
1 row in set (0.00 sec)
具體邏輯見MySQL源碼(MySQL 5.7.17):
sql/sql_table.cc
bool mysql_checksum_table(THD thd, TABLE_LIST tables,HA_CHECK_OPT *check_opt)
2、mysqldiff
mysqldiff該工具是官方mysql-utilities工具集的一個腳本,可以用來對比不同數(shù)據(jù)庫之間的表結(jié)構(gòu),或者同個數(shù)據(jù)庫間的表結(jié)構(gòu)。
下載地址:
https://dev.mysql.com/downloads/utilities/
示例一:檢查server1,server2上的某個表結(jié)構(gòu)是否一致
mysqldiff --server1=user:pwd@host:port --server2=user:pwd@host:port --changes-for=server2 dbname.tablename:dbname.tablename
示例二:檢查server1,server2上的兩個數(shù)據(jù)庫中的表結(jié)構(gòu)是否一致
mysqldiff --server1=user:pwd@host:port --server2=user:pwd@host:port dbname:dbname --changes-for=server2
3、mysqldbcompare
mysqldiff該工具是官方mysql-utilities工具集的一個腳本,可以用來檢查不同數(shù)據(jù)庫之間的數(shù)據(jù)一致性,檢查內(nèi)容包括數(shù)據(jù)庫字符集、表結(jié)構(gòu)、數(shù)據(jù)內(nèi)容,只要有一個不一樣,則檢查不通過。
示例:
mysqldbcompare --server1=user:pwd@192.168.56.110:3306 --server2=user:pwd@192.168.56.111:3306 --changes-for=server1 dbname:dbname
4、pt-table-checksum
pt-table-checksum是在線的主從數(shù)據(jù)一致性檢查工具,能夠?qū)Υ髷?shù)據(jù)量的數(shù)據(jù)庫進(jìn)行高效的主從數(shù)據(jù)一致性檢查,能夠自動控制檢查數(shù)據(jù)量的大小,避免對線上業(yè)務(wù)造成較大的影響。下面對展示該工具的常見幾種用法,更多細(xì)節(jié)見pt-table-checksum官方幫助文檔。
示例一:對特定表的一致性進(jìn)行檢查
pt-table-checksum --host='192.168.56.110' --user='admin' --password='pwd' --port=3306 --recursion-method=processlist --replicate=percona.checksums --no-check-binlog-format --chunk-time=0.5 --tables='dbname.tb1,dbname2.tb2'
示例二:對特定數(shù)據(jù)庫的一致性進(jìn)行檢查
pt-table-checksum --host='192.168.56.110' --user='admin' --password='pwd' --port=3306 --recursion-method=processlist --replicate=percona.checksums --no-check-binlog-format --chunk-time=0.5 --databases='dbname1,dbname2'
示例三:對所有數(shù)據(jù)庫的一致性進(jìn)行檢查
pt-table-checksum --host='192.168.56.110' --user='admin' --password='pwd' --port=3306 --recursion-method=processlist --replicate=percona.checksums --no-check-binlog-format --chunk-time=0.5
對于上文關(guān)于檢查MySQL數(shù)據(jù)是否一致用到的工具,大家覺得是自己想要的嗎?如果想要了解更多相關(guān),可以繼續(xù)關(guān)注我們的行業(yè)資訊板塊。