<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    qileilove

    blog已經(jīng)轉(zhuǎn)移至github,大家請?jiān)L問 http://qaseven.github.io/

    如何將數(shù)據(jù)庫從MySQL移植MemSQL

      本例子假設(shè)你的MySQL和MemSQL都跑在同一臺機(jī)器上,MySQL 在3306 端口,而MemSQL在 3307端口,同時(shí)假設(shè)二者都可以通過root賬號無需密碼訪問。

      使用mysqldump工具移植

      mysqldump是MySQL客戶端最常用的數(shù)據(jù)備份工具之一,它會生成一些列創(chuàng)建表和插入數(shù)據(jù)的SQL語句,因此用來恢復(fù)一個(gè)數(shù)據(jù)庫是最方便的。

      當(dāng)你確定要將數(shù)據(jù)遷移到MemSQL之前,有幾個(gè)注意事項(xiàng):

      大多數(shù)MySQL存儲引擎都是使用 B-tree 來存儲索引的,而 MemSQL 是使用單向無鎖的 skip 列表或者無鎖的哈希表。選擇正確的索引數(shù)據(jù)結(jié)構(gòu)對應(yīng)用程序的性能會有顯著的提升。其中哈希表主要適合 key-value 的查找,而 skip 列表特別適合用于復(fù)雜范圍的掃描和排序(ORDER BY)。因此在進(jìn)行遷移之前,你得重新審視你得表定義并確定是否能使用 MemSQL 專有的優(yōu)化。默認(rèn)的 BTREE 符號將被轉(zhuǎn)成升序的 skip 列表。如果你需要對某個(gè)列做雙向的范圍掃描,你可以考慮同時(shí)增加升序和降序的索引,更多 MemSQL 的索引信息請看 indexes

      因?yàn)?code generation 的緣故,  MemSQL 首次加載數(shù)據(jù)庫結(jié)構(gòu)的速度要比 MySQL 慢,因?yàn)?MemSQL 首次加載表結(jié)構(gòu)時(shí),會生成并編譯代碼來實(shí)現(xiàn)這個(gè)表的架構(gòu),包括內(nèi)存分配、插入、刪除和迭代方法等等。一旦表被編譯完成,MemSQL 將在整個(gè)運(yùn)行期間直接使用編譯好的代碼。而 mysqldump 生成的 INSERT 語句也將特別編譯一次。

      mysqldump 會生成一些 MemSQL 不支持的 SQL 語句,例如不支持 UNIQUE_CHECKS,為了更好的支持 mysqldump,MemSQL 對這些不支持的語句只是予以警告,可通過調(diào)整warn_level 變量來控制錯(cuò)誤的級別,詳情請看 Unsupported Features . 某些 CREATE TABLE 語句可能被完全阻止執(zhí)行,如果你遇見這種問題,只能手工去修改表的定義SQL。

      如果你運(yùn)行 MemSQL 的機(jī)器沒有足夠的內(nèi)存來加載數(shù)據(jù),服務(wù)器將會對 INSERT 語句執(zhí)行報(bào) out-of-memory 的錯(cuò)誤信息,這種情況你只能安裝更多的內(nèi)存。如果你將已有的 memsqlbin 目錄復(fù)制到新的機(jī)器上,那么MemSQL 會繼續(xù)沿用已編譯的表定義和 INSERT 語句。如果你使用的是 MemSQL 開發(fā)版,而且超過了10G 的限制,那你可以參考 memsql.com/next 來了解如何升級。

      建議你將數(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é)果。

      轉(zhuǎn)換你的應(yīng)用程序

      讓應(yīng)用程序支持 MemSQL 非常簡單,只需要改連接配置即可。

      注意

      如果你要連接到本機(jī)的 MemSQL 應(yīng)該使用 127.0.0.1 而不是 localhost,多數(shù) MySQL 客戶端可將 localhost 解析并使用 MySQL 的 socket 文件進(jìn)行連接而忽略端口設(shè)置,詳情請看 this page

      一旦你開始運(yùn)行程序,可監(jiān)控 memsql_tracelog。一些不支持的SQL語法會在這里顯示。

    posted on 2012-06-25 09:41 順其自然EVO 閱讀(347) 評論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫

    <2012年6月>
    272829303112
    3456789
    10111213141516
    17181920212223
    24252627282930
    1234567

    導(dǎo)航

    統(tǒng)計(jì)

    常用鏈接

    留言簿(55)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲AV电影天堂男人的天堂| 亚洲精品无码专区2| 亚洲自偷自偷精品| 黄色a三级三级三级免费看| 在线a级毛片免费视频| 亚洲日韩乱码久久久久久| 99亚偷拍自图区亚洲| 四虎成年永久免费网站| 亚洲国产美女精品久久久久| 2021国产精品成人免费视频| 亚洲人配人种jizz| 黑人粗长大战亚洲女2021国产精品成人免费视频 | 久久久久久亚洲精品中文字幕| 女同免费毛片在线播放| 亚洲成AV人片一区二区密柚| 一级毛片免费不卡在线| 热99re久久精品精品免费| 国产精品亚洲AV三区| 亚洲一级Av无码毛片久久精品| 亚洲一卡2卡3卡4卡国产网站 | 全部免费国产潢色一级| 久久亚洲精品成人AV| 91成年人免费视频| 亚洲а∨精品天堂在线| 桃子视频在线观看高清免费完整| 亚洲av成人一区二区三区| 免费一级毛片在播放视频| 国产一级a毛一级a看免费人娇| 亚洲精品国产第1页| 成人免费在线视频| 一级毛片试看60分钟免费播放| 亚洲va无码va在线va天堂| 91网站免费观看| 美女裸免费观看网站| 国产精品国产亚洲精品看不卡| 永久免费视频网站在线观看| 亚洲av中文无码字幕色不卡| 国产午夜亚洲不卡| 中文字幕在线免费看线人| 亚洲在成人网在线看| 国产嫩草影院精品免费网址|