欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL下200GB大表備份的操作(利用傳輸表空間解決停服發(fā)版表備份問(wèn)題)

 更新時(shí)間:2025年04月15日 08:45:14   作者:GreatSQL  
這篇文章主要介紹了MySQL下200GB大表備份的操作(利用傳輸表空間解決停服發(fā)版表備份問(wèn)題),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

問(wèn)題背景

在停服發(fā)版更新時(shí),需對(duì) 200GB 大表(約 200 億行數(shù)據(jù))進(jìn)行快速備份以預(yù)防操作失誤。

因?yàn)樵?jīng)出現(xiàn)過(guò)有開(kāi)發(fā)寫(xiě)的發(fā)版語(yǔ)句里,UPDATE語(yǔ)句的WHERE條件寫(xiě)錯(cuò)了,原本只需要更新幾行數(shù)據(jù),最終導(dǎo)致更新了半張表的數(shù)據(jù)。

MySQL版本是MySQL 8.0.X,為了預(yù)防這種情況,需要對(duì)某個(gè)重要的大表進(jìn)行預(yù)先備份,以便可以及時(shí)回滾,及時(shí)恢復(fù),及時(shí)回退,對(duì)于備份方法大概有下面幾種:

方案優(yōu)點(diǎn)缺點(diǎn)
mysqldump 導(dǎo)出簡(jiǎn)單易用大表導(dǎo)出耗時(shí)(200GB 可能需數(shù)小時(shí))
CREATE TABLE...SELECT直接 SQL 操作數(shù)據(jù)復(fù)制慢,鎖表風(fēng)險(xiǎn)高
表空間傳輸秒級(jí)備份,零數(shù)據(jù)復(fù)制需操作系統(tǒng)權(quán)限,依賴文件拷貝
主從復(fù)制/延遲復(fù)制無(wú)需停服,恢復(fù)靈活需主從架構(gòu),維護(hù)成本高

這個(gè)場(chǎng)景的核心需求:停服更新的時(shí)間非常有限,比如1個(gè)小時(shí)之內(nèi)要完成更新。

操作流程

前面兩種都比較簡(jiǎn)單,通過(guò)導(dǎo)數(shù)據(jù)的方法來(lái)備份舊表,萬(wàn)一出現(xiàn)問(wèn)題,可以使用導(dǎo)出來(lái)的數(shù)據(jù)進(jìn)行快速恢復(fù),第三種方法估計(jì)比較少人用,下面是具體操作方法

  • 源表與備胎表結(jié)構(gòu)
-- 源表(aa)
CREATE TABLE aa (
  id int(11) DEFAULT NULL,
  sname VARCHAR(100)
) ENGINE=InnoDB;
-- 備胎表(bb)
CREATE TABLE bb (
  id int(11) DEFAULT NULL,
  sname VARCHAR(100)
) ENGINE=InnoDB;
greatsql> INSERT INTO aa SELECT 1,"nihao";

2、備胎表卸載表空間:

greatsql> ALTER TABLE bb DISCARD TABLESPACE;  -- 加鎖并生成配置文件

3、源表執(zhí)行表空間導(dǎo)出:

greatsql> USE school;
greatsql> FLUSH TABLES aa FOR EXPORT;   

4、拷貝表空間文件(ibd和cfg文件),然后重新賦予權(quán)限,確保導(dǎo)入表空間時(shí)候不會(huì)出現(xiàn)問(wèn)題

$ cd /data/mysql/mysql3306/data/school
$ cp aa.ibd  bb.ibd  
$ cp aa.cfg  bb.cfg
$ chown -R mysql:mysql /data/mysql/mysql3306/data/*

5、在相同數(shù)據(jù)庫(kù)下,備胎表和源表都導(dǎo)入表空間

greatsql> USE school;
greatsql> UNLOCK TABLES;  
greatsql> ALTER TABLE bb IMPORT TABLESPACE;
greatsql> ALTER TABLE aa IMPORT TABLESPACE;

6、查詢表數(shù)據(jù),驗(yàn)證數(shù)據(jù)一致性

greatsql> USE school;
greatsql> SELECT * FROM bb;
greatsql> SELECT * FROM aa;

查詢表數(shù)據(jù)正常,沒(méi)有任何問(wèn)題

greatsql> SELECT * FROM aa;
+------+-------+
| id   | sname |
+------+-------+
|    1 | nihao |
+------+-------+
1 row in set (0.01 sec)
greatsql> SELECT * FROM bb;
+------+-------+
| id   | sname |
+------+-------+
|    1 | nihao |
+------+-------+
1 row in set (0.00 sec)

查看表的數(shù)據(jù)文件,沒(méi)什么問(wèn)題

$ ll
total 228
-rw-r----- 1 mysql mysql 114688 Mar  4 16:51 aa.ibd
-rw-r----- 1 mysql mysql    781 Mar  4 16:52 bb.cfg
-rw-r----- 1 mysql mysql 114688 Mar  4 16:52 bb.ibd

7、發(fā)版更新與回滾

-- 發(fā)版操作(示例)
greatsql> UPDATE aa SET sname = 'new_value' WHERE id > 1;

8、如果發(fā)版有問(wèn)題,直接交換表名,最快速度恢復(fù)整個(gè)表的數(shù)據(jù)

-- 回滾操作(交換表名)
greatsql> ALTER TABLE aa RENAME TO aa_temp; 
greatsql> ALTER TABLE bb RENAME TO aa; 

總結(jié)

整個(gè)操作最重要的是第4步,操作系統(tǒng)級(jí)別的拷貝就完成了整個(gè)表的備份,相比于數(shù)據(jù)倒來(lái)倒去在速度上要快不少。另外,第5步的備胎表也可以不用導(dǎo)入,只有當(dāng)發(fā)現(xiàn)發(fā)版出現(xiàn)問(wèn)題時(shí)候,再導(dǎo)入也可以。

這種方法的關(guān)鍵優(yōu)勢(shì)如下

  • 直接拷貝 .ibd 文件,無(wú)需逐行復(fù)制數(shù)據(jù)。
  • 零鎖表時(shí)間:FLUSH TABLES tablename FOR EXPORT 僅短暫加鎖(秒級(jí))。
  • 快速恢復(fù):通過(guò)表名交換實(shí)現(xiàn)秒級(jí)回滾。

特別適合于這幾種場(chǎng)景:無(wú)主從架構(gòu)的單實(shí)例環(huán)境、大表快速備份、停服時(shí)間敏感。

當(dāng)然,如果有主從架構(gòu)的話,則更加推薦使用第四種方法,在操作上也更加可控,短時(shí)間也能保證能夠完成。

關(guān)于 GreatSQL

GreatSQL是適用于金融級(jí)應(yīng)用的國(guó)內(nèi)自主開(kāi)源數(shù)據(jù)庫(kù),具備高性能、高可靠、高易用性、高安全等多個(gè)核心特性,可以作為MySQL或Percona Server的可選替換,用于線上生產(chǎn)環(huán)境,且完全免費(fèi)并兼容MySQL或Percona Server。

到此這篇關(guān)于MySQL下200GB大表備份,利用傳輸表空間解決停服發(fā)版表備份問(wèn)題的文章就介紹到這了,更多相關(guān)使用java代碼獲取JVM信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL 使用 ORDER BY 排序和 DELETE 刪除記錄的操作過(guò)程

    MySQL 使用 ORDER BY 排序和 DELETE 刪

    這篇文章主要介紹了MySQL 使用 ORDER BY 排序和 DELETE 刪除記錄的操作過(guò)程,即數(shù)據(jù)庫(kù)查詢與數(shù)據(jù)操作,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2023-11-11
  • MySQL與PHP的基礎(chǔ)與應(yīng)用專題之增刪改查

    MySQL與PHP的基礎(chǔ)與應(yīng)用專題之增刪改查

    MySQL是一個(gè)關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng),由瑞典MySQL AB 公司開(kāi)發(fā),屬于 Oracle 旗下產(chǎn)品。MySQL 是最流行的關(guān)系型數(shù)據(jù)庫(kù)管理系統(tǒng)之一,本系列將帶你掌握php與mysql的基礎(chǔ)應(yīng)用,本篇從數(shù)據(jù)庫(kù)的增刪改查開(kāi)始
    2022-02-02
  • Navicat連接MySQL時(shí)出現(xiàn)的連接失敗問(wèn)題及解決

    Navicat連接MySQL時(shí)出現(xiàn)的連接失敗問(wèn)題及解決

    這篇文章主要介紹了Navicat連接MySQL時(shí)出現(xiàn)的連接失敗問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • MySQL數(shù)據(jù)庫(kù)設(shè)計(jì)概念及多表查詢和事物操作

    MySQL數(shù)據(jù)庫(kù)設(shè)計(jì)概念及多表查詢和事物操作

    數(shù)據(jù)庫(kù)設(shè)計(jì)就是根據(jù)業(yè)務(wù)系統(tǒng)具體需求,結(jié)合我們所選用的DBMS,為這個(gè)業(yè)務(wù)系統(tǒng)構(gòu)造出最優(yōu)的數(shù)據(jù)存儲(chǔ)模型,本文給大家介紹MySQL數(shù)據(jù)庫(kù)設(shè)計(jì)概念及多表查詢和事物操作,感興趣的朋友一起看看吧
    2022-05-05
  • MySQL函數(shù)大全及用法示例分享

    MySQL函數(shù)大全及用法示例分享

    這篇文章主要介紹了MySQL的一些函數(shù)及用法示例,需要的朋友可以參考下
    2014-03-03
  • mysql主從基于docker和django實(shí)現(xiàn)讀寫(xiě)分離

    mysql主從基于docker和django實(shí)現(xiàn)讀寫(xiě)分離

    這篇文章主要介紹了mysql主從基于docker和django實(shí)現(xiàn)讀寫(xiě)分離,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-08-08
  • MySQL 使用DQL命令查詢數(shù)據(jù)的實(shí)現(xiàn)方法

    MySQL 使用DQL命令查詢數(shù)據(jù)的實(shí)現(xiàn)方法

    這篇文章主要介紹了MySQL 使用DQL命令查詢數(shù)據(jù)的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • MySQL collation方法

    MySQL collation方法

    在以前用oracle的時(shí)候,很少關(guān)于它的collation方法,但是在mysql中,這點(diǎn)不加注意的話,卻有可能會(huì)出現(xiàn)問(wèn)題。
    2008-10-10
  • MySQL插入中文不亂碼的5種方法

    MySQL插入中文不亂碼的5種方法

    這篇文章主要介紹了MySQL 插入中文不亂碼的5種方法,需要的朋友可以參考下
    2016-06-06
  • MySQL中substr函數(shù)使用方法實(shí)例詳解

    MySQL中substr函數(shù)使用方法實(shí)例詳解

    MySQL的SUBSTR()函數(shù)可以用于從指定字符串的指定位置開(kāi)始提取指定長(zhǎng)度的字符,下面這篇文章主要給大家介紹了關(guān)于MySQL中substr函數(shù)使用方法的相關(guān)資料,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08

最新評(píng)論