【MySQL】 已經存在大量資料的表做分區

來源:互聯網
上載者:User

標籤:mysql 分區

環境:

  資料庫版本:5.6

  系統內容:CentOS 6.8


複製架構:


需求:

  需要將執行個體C上面一個2500萬行資料的Innodb引擎的表table進行分區,但是在執行個體A上面表table不做任何的修改。

思考的問題:

  在執行個體C上面的表table做分區,分區之後會不會影響執行個體A和執行個體C之間表table的傳輸,會不會造成資料不一致或者插入失敗,或者分區之後插入的資料會比較慢。

實際操作:都是在執行個體C上面的操作

  1. stop slave IO_THREAD 停掉IO_THREAD並且等待執行個體C重放relay log完畢。

    Master_Log_File == Relay_Master_Log_File and  Read_Master_Log_Pos == Exec_Master_Log_Pos 當這倆個運算式成立的時候表明本地的relay log已經重做完畢。

  2.邏輯備份表table的資料:

 mysqldump -S /var/lib/mysql/mysql.sock -uroot -p --single-transaction --master-data=2 -t --skip-add-drop-table sbtest sbtest1 > sbtest1.sql 參數解釋: -t:不建立table --skip-add-drop-table:不做drop table操作

    在備份的時候不需要drop table 和 create table操作寫入備份的SQL語句中

  3.更改表名

    更改舊錶的表名 rename table sbtest1 to sbtest2; 這樣做的目的是為了在做備份匯入的時候不需要更改備份SQL語句,並且萬一分區失敗或者其他的原因至少也有表的備份存在。

  4.建立空表並且進行分區:

CREATE TABLE `sbtest1` (  `id` bigint(20) NOT NULL AUTO_INCREMENT,  `k` bigint(20) NOT NULL,  `c` varchar(20) NOT NULL,  `pad` varchar(50) COLLATE utf8mb4_bin NOT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB  DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin PARTITION BY KEY (id) PARTITIONS 64

  新表的表結構要和舊錶的表結構一致,唯一不同就是提前分好區。

  5.匯入邏輯備份語句

mysql -uroot -p sbtest < sbtest1.sql

  6.匯入完畢之後開啟slave並且觀察一段時間

start slave IO_THREAD

  7.pt-table-checksum資料一致性檢測(可做可不做)

    http://seanlook.com/2015/12/29/mysql_replica_pt-table-checksum/

  8.建議:

    因為2500萬行的資料的備份會花費比較長的時間,所以在備份的時候建議使用screen,那怕在你遠程回話斷開之後進程還是存在的。

【MySQL】 已經存在大量資料的表做分區

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.