本篇內(nèi)容主要講解“怎么把數(shù)據(jù)庫從MySQL移植到MemSQL”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“怎么把數(shù)據(jù)庫從MySQL移植到MemSQL”吧!

因?yàn)?MemSQL 完全兼容 MySQL,因此將數(shù)據(jù)從 MySQL 遷移到 MemSQL 上是非常直接的,你可以使用標(biāo)準(zhǔn)的 MySQL 工具來遷移。
本例子假設(shè)你的 MySQL 和 MemSQL 都跑在同一臺(tái)機(jī)器上,MySQL 在 3306 端口,而 MemSQL 在 3307 端口,同時(shí)假設(shè)二者都可以通過 root 賬號(hào)無需密碼訪問。
mysqldump 是 MySQL 客戶端最常用的數(shù)據(jù)備份工具之一,它會(huì)生成一些列創(chuàng)建表和插入數(shù)據(jù)的SQL語句,因此用來恢復(fù)一個(gè)數(shù)據(jù)庫是最方便的。
當(dāng)你確定要將數(shù)據(jù)遷移到 MemSQL 之前,有幾個(gè)注意事項(xiàng):
大多數(shù) MySQL 存儲(chǔ)引擎都是使用 B-tree 來存儲(chǔ)索引的,而 MemSQL 是使用單向無鎖的 skip 列表或者無鎖的哈希表。選擇正確的索引數(shù)據(jù)結(jié)構(gòu)對(duì)應(yīng)用程序的性能會(huì)有顯著的提升。其中哈希表主要適合 key-value 的查找,而 skip 列表特別適合用于復(fù)雜范圍的掃描和排序(ORDER BY)。因此在進(jìn)行遷移之前,你得重新審視你得表定義并確定是否能使用 MemSQL 專有的優(yōu)化。默認(rèn)的 BTREE 符號(hào)將被轉(zhuǎn)成升序的 skip 列表。如果你需要對(duì)某個(gè)列做雙向的范圍掃描,你可以考慮同時(shí)增加升序和降序的索引,更多 MemSQL 的索引信息請(qǐng)看indexes
因?yàn)?em>code generation 的緣故, MemSQL 首次加載數(shù)據(jù)庫結(jié)構(gòu)的速度要比 MySQL 慢,因?yàn)?MemSQL 首次加載表結(jié)構(gòu)時(shí),會(huì)生成并編譯代碼來實(shí)現(xiàn)這個(gè)表的架構(gòu),包括內(nèi)存分配、插入、刪除和迭代方法等等。一旦表被編譯完成,MemSQL 將在整個(gè)運(yùn)行期間直接使用編譯好的代碼。而 mysqldump 生成的 INSERT 語句也將特別編譯一次。
mysqldump 會(huì)生成一些 MemSQL 不支持的 SQL 語句,例如不支持 UNIQUE_CHECKS,為了更好的支持 mysqldump,MemSQL 對(duì)這些不支持的語句只是予以警告,可通過調(diào)整 warn_level 變量來控制錯(cuò)誤的級(jí)別,詳情請(qǐng)看Unsupported Features . 某些 CREATE TABLE 語句可能被完全阻止執(zhí)行,如果你遇見這種問題,只能手工去修改表的定義SQL。
如果你運(yùn)行 MemSQL 的機(jī)器沒有足夠的內(nèi)存來加載數(shù)據(jù),服務(wù)器將會(huì)對(duì) INSERT 語句執(zhí)行報(bào) out-of-memory 的錯(cuò)誤信息,這種情況你只能安裝更多的內(nèi)存。如果你將已有的 memsqlbin 目錄復(fù)制到新的機(jī)器上,那么MemSQL 會(huì)繼續(xù)沿用已編譯的表定義和 INSERT 語句。如果你使用的是 MemSQL 開發(fā)版,而且超過了10G 的限制,那你可以參考 memsql.com/next 來了解如何升級(jí)。
建議你將數(shù)據(jù)庫結(jié)構(gòu)定義和數(shù)據(jù)分開獨(dú)立文件存放,這樣就可以在需要的時(shí)候來調(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
運(yùn)行這些步驟時(shí),你可以觀察memsql_tracelog (同時(shí)也輸出到stderr) 來查看執(zhí)行過程中被忽略的不被支持的特性。一旦導(dǎo)入完成后,你可以連接到 MemSQL 并查詢結(jié)果。
讓應(yīng)用程序支持 MemSQL 非常簡(jiǎn)單,只需要改連接配置即可。
注意
如果你要連接到本機(jī)的 MemSQL 應(yīng)該使用 127.0.0.1 而不是 localhost,多數(shù) MySQL 客戶端可將 localhost 解析并使用 MySQL 的 socket 文件進(jìn)行連接而忽略端口設(shè)置,詳情請(qǐng)看this page
一旦你開始運(yùn)行程序,可監(jiān)控memsql_tracelog. 一些不支持的SQL語法會(huì)在這里顯示。更多 MemSQL 的SQL Statements
OSCHINA原創(chuàng)翻譯自 MemSQL 官方文檔。
到此,相信大家對(duì)“怎么把數(shù)據(jù)庫從MySQL移植到MemSQL”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
當(dāng)前題目:怎么把數(shù)據(jù)庫從MySQL移植到MemSQL-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://chinadenli.net/article34/hjgpe.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導(dǎo)航、網(wǎng)站設(shè)計(jì)公司、云服務(wù)器、營銷型網(wǎng)站建設(shè)、企業(yè)建站、企業(yè)網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容