溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何檢測(cè)數(shù)據(jù)庫(kù)遷移的準(zhǔn)確性

發(fā)布時(shí)間:2021-12-02 14:23:20 來(lái)源:億速云 閱讀:222 作者:柒染 欄目:軟件技術(shù)

這篇文章將為大家詳細(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ò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI