您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)如何檢測(cè)數(shù)據(jù)庫(kù)遷移的準(zhǔn)確性,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。
游戲運(yùn)營(yíng)中經(jīng)常遇到數(shù)據(jù)庫(kù)遷移的情況。比如:合服前的庫(kù)遷移。為了節(jié)省成本整合庫(kù)遷移。甚至換云服務(wù)商引起的庫(kù)遷移。其實(shí)運(yùn)維本身有責(zé)任和義務(wù)保證遷移過(guò)程中庫(kù)數(shù)據(jù)的準(zhǔn)確性和完整性。因?yàn)閷?duì)服務(wù)器而言。數(shù)據(jù)實(shí)在是太重要。批量遷移過(guò)程中總擔(dān)憂出問(wèn)題。數(shù)據(jù)會(huì)不會(huì)丟失。如何減少這種意外發(fā)生。如何做到雙重保障?這樣心里更加有把握。
雙重保障思路是:遷移前批量執(zhí)行庫(kù)中每個(gè)表的條數(shù)輸出到文本中。等運(yùn)維遷移后。再批量執(zhí)行庫(kù)中每個(gè)表的條數(shù)輸出到文本中。然后使用Beyond Compare 對(duì)比工具。因?yàn)檩敵鲰樞蛞恢?。文本前后完全相同。安全性大大提高。也可以?jiǎn)單的方式輸出每個(gè)庫(kù)表的總條數(shù)。相同也可以保證準(zhǔn)確性。
Shell腳本:CheckDbWork.sh
#!/bin/bash myvar=0 while [ $myvar -le 19 ] do echo $myvar mysql -uadmin -p'Pa$$w0' -h27.31.25.133 -P 3306 -Dtafang_s$(($myvar+6000)) <CheckDbWorkSql.sql myvar=$(( $myvar + 1 )) done myvar=20 while [ $myvar -le 39 ] do echo $myvar mysql -uadmin -p'Pa$$w0' -h27.31.25.134 -P 3306 -Dtafang_s$(($myvar+6000)) <CheckDbWorkSql.sql myvar=$(( $myvar + 1 )) done
Mysql腳本:CheckDbWork.sql
SET CHARACTER_SET_CLIENT=utf8; SET CHARACTER_SET_CONNECTION=utf8; DELIMITER $$ DROP PROCEDURE IF EXISTS `CheckDbWorkSql`$$ CREATE PROCEDURE `CheckDbWorkSql`() BEGIN DECLARE i INT DEFAULT 0; DECLARE tempCount INT DEFAULT 0; DECLARE dbSql VARCHAR(512) DEFAULT ''; DECLARE dbNameSql VARCHAR(512) DEFAULT ''; DECLARE checkDbSql VARCHAR(512) DEFAULT ''; DECLARE tableName VARCHAR(128) DEFAULT ''; DECLARE checkSrceSql VARCHAR(1024) DEFAULT ''; DECLARE runSrceSql VARCHAR(1024) DEFAULT ''; DECLARE calTableSql VARCHAR(1024) DEFAULT ''; DECLARE tempAllCount INT DEFAULT 0; DECLARE tempTableCount INT DEFAULT 0; -- 獲取當(dāng)前數(shù)據(jù)庫(kù) prepare stmt from "SELECT database() INTO @dbSql"; EXECUTE stmt; -- 循環(huán)導(dǎo)入數(shù)據(jù) SET @checkSql=CONCAT("SELECT COUNT(1) into @tempCount FROM information_schema.TABLES WHERE TABLE_SCHEMA = '",@dbSql,"'"); prepare stmt from @checkSql; EXECUTE stmt; SET @checkSrceSql=CONCAT("SELECT table_name into @tableName FROM information_schema.TABLES WHERE TABLE_SCHEMA = '",@dbSql,"' LIMIT [##],1"); WHILE i < @tempCount DO SET @runSrceSql=REPLACE(@checkSrceSql,'[##]',i); prepare stmt from @runSrceSql; EXECUTE stmt; SET @calTableSql=CONCAT("SELECT COUNT(1) into @tempTableCount FROM ",@tableName); prepare stmt from @calTableSql; EXECUTE stmt; SET i=i+1; SET tempAllCount=tempAllCount+@tempTableCount; -- SELECT @tempTableCount; END WHILE; SELECT @dbSql,tempAllCount; END$$ DELIMITER $$ CALL CheckDbWorkSql();
關(guān)于如何檢測(cè)數(shù)據(jù)庫(kù)遷移的準(zhǔn)確性就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。
免責(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)容。