您好,登錄后才能下訂單哦!
下文給大家?guī)?lái)有關(guān)檢查MySQL數(shù)據(jù)是否一致用到的工具內(nèi)容,相信大家一定看過(guò)類似的文章。我們給大家?guī)?lái)的有何不同呢?一起來(lái)看看正文部分吧,相信看完檢查MySQL數(shù)據(jù)是否一致用到的工具你一定會(huì)有所收獲。
1、MySQL checksum命令
在執(zhí)行checksum命令時(shí),表會(huì)被加一個(gè)讀鎖(read lock),checksum table的原理是對(duì)表中的數(shù)據(jù)進(jìn)行一行一行的較驗(yàn)和計(jì)算,因些對(duì)于大表,這是一個(gè)很耗時(shí)的過(guò)程。
如果對(duì)于myisam表,建表時(shí)加上CHECKSUM=1選項(xiàng),那么在對(duì)這樣的表進(jìn)行checksum table時(shí)將會(huì)非???/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)
具體邏輯見(jiàn)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工具集的一個(gè)腳本,可以用來(lái)對(duì)比不同數(shù)據(jù)庫(kù)之間的表結(jié)構(gòu),或者同個(gè)數(shù)據(jù)庫(kù)間的表結(jié)構(gòu)。
下載地址:
https://dev.mysql.com/downloads/utilities/
示例一:檢查server1,server2上的某個(gè)表結(jié)構(gòu)是否一致
mysqldiff --server1=user:pwd@host:port --server2=user:pwd@host:port --changes-for=server2 dbname.tablename:dbname.tablename
示例二:檢查server1,server2上的兩個(gè)數(shù)據(jù)庫(kù)中的表結(jié)構(gòu)是否一致
mysqldiff --server1=user:pwd@host:port --server2=user:pwd@host:port dbname:dbname --changes-for=server2
3、mysqldbcompare
mysqldiff該工具是官方mysql-utilities工具集的一個(gè)腳本,可以用來(lái)檢查不同數(shù)據(jù)庫(kù)之間的數(shù)據(jù)一致性,檢查內(nèi)容包括數(shù)據(jù)庫(kù)字符集、表結(jié)構(gòu)、數(shù)據(jù)內(nèi)容,只要有一個(gè)不一樣,則檢查不通過(guò)。
示例:
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ù)庫(kù)進(jìn)行高效的主從數(shù)據(jù)一致性檢查,能夠自動(dòng)控制檢查數(shù)據(jù)量的大小,避免對(duì)線上業(yè)務(wù)造成較大的影響。下面對(duì)展示該工具的常見(jiàn)幾種用法,更多細(xì)節(jié)見(jiàn)pt-table-checksum官方幫助文檔。
示例一:對(duì)特定表的一致性進(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'
示例二:對(duì)特定數(shù)據(jù)庫(kù)的一致性進(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'
示例三:對(duì)所有數(shù)據(jù)庫(kù)的一致性進(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
對(duì)于上文關(guān)于檢查MySQL數(shù)據(jù)是否一致用到的工具,大家覺(jué)得是自己想要的嗎?如果想要了解更多相關(guān),可以繼續(xù)關(guān)注我們的行業(yè)資訊板塊。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。