將數(shù)據(jù)庫從 MySQL 移植到 MemSQL |
發(fā)布時間: 2012/9/4 17:28:16 |
因為 MemSQL 完全兼容 MySQL,因此將數(shù)據(jù)從 MySQL 遷移到 MemSQL 上是非常直接的,你可以使用標(biāo)準(zhǔn)的 MySQL 工具來遷移。 本例子假設(shè)你的 MySQL 和 MemSQL 都跑在同一臺機器上,MySQL 在 3306 端口,而 MemSQL 在 3307 端口,同時假設(shè)二者都可以通過 root 賬號無需密碼訪問。-
當(dāng)你確定要將數(shù)據(jù)遷移到 MemSQL 之前,有幾個注意事項: 大多數(shù) MySQL 存儲引擎都是使用 B-tree 來存儲索引的,而 MemSQL 是使用單向無鎖的 skip 列表或者無鎖的哈希表。選擇正確的索引數(shù)據(jù)結(jié)構(gòu)對應(yīng)用程序的性能會有顯著的提升。其中哈希表主要適合 key-value 的查找,而 skip 列表特別適合用于復(fù)雜范圍的掃描和排序(ORDER BY)。因此在進行遷移之前,你得重新審視你得表定義并確定是否能使用 MemSQL 專有的優(yōu)化。默認的 BTREE 符號將被轉(zhuǎn)成升序的 skip 列表。如果你需要對某個列做雙向的范圍掃描,你可以考慮同時增加升序和降序的索引,更多 MemSQL 的索引信息請看 indexes 因為 code generation 的緣故, MemSQL 首次加載數(shù)據(jù)庫結(jié)構(gòu)的速度要比 MySQL 慢,因為 MemSQL 首次加載表結(jié)構(gòu)時,會生成并編譯代碼來實現(xiàn)這個表的架構(gòu),包括內(nèi)存分配、插入、刪除和迭代方法等等。一旦表被編譯完成,MemSQL 將在整個運行期間直接使用編譯好的代碼。而 mysqldump 生成的 INSERT 語句也將特別編譯一次。 建議你將數(shù)據(jù)庫結(jié)構(gòu)定義和數(shù)據(jù)分開獨立文件存放,這樣就可以在需要的時候來調(diào)整表結(jié)構(gòu),你可以使用下面命令來分別導(dǎo)出數(shù)據(jù)庫結(jié)構(gòu)和數(shù)據(jù)文件: $ mysqldump -h 127.0.0.1 -u root -B [database name] --no-data > schema.sql$ mysqldump -h 127.0.0.1 -u root -B [database name] --no-create-info > data.sql然后通過下面方法導(dǎo)入: $ mysql -h 127.0.0.1 -u root -P 3307 < schema.sql$ mysql -h 127.0.0.1 -u root -P 3307 < data.sql運行這些步驟時,你可以觀察 memsql_tracelog (同時也輸出到 stderr) 來查看執(zhí)行過程中被忽略的不被支持的特性。一旦導(dǎo)入完成后,你可以連接到 MemSQL 并查詢結(jié)果。 轉(zhuǎn)換你的應(yīng)用程序 注意 如果你要連接到本機的 MemSQL 應(yīng)該使用 127.0.0.1 而不是 localhost,多數(shù) MySQL 客戶端可將 localhost 解析并使用 MySQL 的 socket 文件進行連接而忽略端口設(shè)置,詳情請看 this page 一旦你開始運行程序,可監(jiān)控 memsql_tracelog. 一些不支持的SQL語法會在這里顯示。更多 MemSQL 的 SQL Statements
本文出自:億恩科技【mszdt.com】 服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM] |