MySQL 常見(jiàn)數(shù)據(jù)拆分辦法
在生產(chǎn)環(huán)境中,由于業(yè)務(wù)的增長(zhǎng)或者業(yè)務(wù)的拆分,DBA經(jīng)常需要拆庫(kù)操作。那么我們常見(jiàn)的拆庫(kù)手段有哪些呢?
我這里提供幾種解決辦法:
1. 使用mysqldump 把表邏輯倒出,然后再source 到其它地方
2. 使用xtrabackup 把表、或者庫(kù)邏輯備份出,然后再recovery出一個(gè)實(shí)例
3. 使用MySQL自帶的表空間轉(zhuǎn)移(Transport)[這個(gè)需要MySQL 5.6.6 以上版本支持]
I: 先來(lái)看一下MySQL 的 Transport 表空間的特性吧
比如我們要把 tab_test1 從 db_A 移動(dòng)到 db_B ,那么我們需要做這么一系列動(dòng)作:
Step 1: use db_A; show create table tab_test1;(首先,拿到需要的表結(jié)構(gòu))
Step 2: use db_B; create table tab_test1; alter tale tab_test1 discard tablespace;(discard tablespace 就是把ibd文件刪掉,只留下.frm文件)(其次,到目標(biāo)庫(kù)刪除掉idb文件)
Step 4: use db_A; flush table test122 for export;(把相關(guān)表的內(nèi)存數(shù)據(jù)寫(xiě)入到數(shù)據(jù)庫(kù))
Step 5: 拷貝 tab_test1.ibd 文件到 db_B/ 目錄下;(操作系統(tǒng)層執(zhí)行拷貝ibd文件操作)
Step 6: use db_A; unlock tables; (源庫(kù)上解鎖表)
Step 7: use db_B; alter table tab_test1 import tablespace;(目標(biāo)庫(kù)執(zhí)行表空間導(dǎo)入)
執(zhí)行完上邊幾個(gè)步驟,我們就完成了 在庫(kù)之間遷移 某些個(gè)表的操作了。
II: 再來(lái)看一下 xtrabackup 導(dǎo)出部分表,以達(dá)到遷移目的
Step 1: 我們需要使用xtrabackup 備份部分表
nohup perl /home/ddb/tmp/xtrabackup/bin/innobackupex-1.5.1 --ibbackup=/home/tmp/xtrabackup/bin/xtrabackup_55 --user=root --password=123 --defaults-file=/home/my.cnf --slave-info --tables-file=/mnt/back_tables.txt /mnt/backup_1
Step 2: 應(yīng)用日志,進(jìn)行恢復(fù)操作
nohup perl /home/tmp/percona-xtrabackup-2.1.9-Linux-x86_64/bin/innobackupex-1.5.1 --ibbackup=/home/tmp/percona-xtrabackup-2.1.9-Linux-x86_64/bin/xtrabackup_55 --export --apply-log --defaults-file=/home/node-1-1/backup-my.cnf /home/node-1-1/ > /tmp/r.log 2>&1 &
Step 3: 重新起實(shí)例,配置復(fù)制關(guān)系,只復(fù)制部分表
my.cnf 文件配置: Replicate_Wild_Do_Table/Replicate_Wild_Ignore_Table
執(zhí)行完上邊幾個(gè)步驟,我們就完成了表的遷移操作,并且新起了個(gè)實(shí)例,達(dá)到了分庫(kù)的目的。
III:最后我們就看一下 mysqldump 的姿勢(shì)吧
額, 這個(gè)就不多啰嗦了吧, mysqldump 做的事情就是 一些邏輯的導(dǎo)出, 倒出來(lái)的數(shù)據(jù)我們是可以用人肉可見(jiàn)的。 這個(gè)需要注意的一點(diǎn)就是 --single-transcation 選項(xiàng)
關(guān)于以上幾種辦法,我們?cè)趯?shí)際工作中需要 考慮 服務(wù)器的資源、內(nèi)存容量等, 需要結(jié)合實(shí)際情況來(lái)使用 合適的辦法進(jìn)行拆庫(kù)操作。
相關(guān)文章
linux系統(tǒng)下安裝配置解壓版的MySQL數(shù)據(jù)庫(kù)圖解
這篇文章主要介紹了linux系統(tǒng)下安裝配置解壓版的MySQL數(shù)據(jù)庫(kù)的相關(guān)資料,需要的朋友可以參考下2017-12-12
數(shù)據(jù)庫(kù)設(shè)計(jì)工具M(jìn)ySQL?Workbench使用教程(超級(jí)詳細(xì)!)
MySQL?Workbench為數(shù)據(jù)庫(kù)管理員、程序開(kāi)發(fā)者和系統(tǒng)規(guī)劃師提供可視化的Sql開(kāi)發(fā)、數(shù)據(jù)庫(kù)建模、以及數(shù)據(jù)庫(kù)管理功能,下面這篇文章主要給大家介紹了關(guān)于MySQL設(shè)計(jì)工具Workbench使用的相關(guān)資料,需要的朋友可以參考下2023-02-02
mysql如何定時(shí)自動(dòng)新增分區(qū)
這篇文章主要介紹了mysql如何定時(shí)自動(dòng)新增分區(qū)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Linux下安裝MySQL5.7.19問(wèn)題小結(jié)
第一次在自己虛機(jī)上安裝mysql 中間碰到很多問(wèn)題 在這里記下來(lái),特此分享到腳本之家平臺(tái)供大家參考2017-08-08
Mysql忘記密碼怎么重置密碼的幾種實(shí)現(xiàn)方法
本文主要介紹了Mysql忘記密碼怎么重置密碼的幾種實(shí)現(xiàn)方法,每種方法都有其適用的情況,根據(jù)具體情況選擇合適的方法,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10

