婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 從云數據遷移服務看MySQL大表抽取模式的原理解析

從云數據遷移服務看MySQL大表抽取模式的原理解析

熱門標簽:百應電話機器人優勢 地圖標注費用是多少 曲靖移動外呼系統公司 武漢網絡外呼系統服務商 電話外呼系統改號 外呼系統打電話上限是多少 怎樣在地圖標注銷售區域 南昌三維地圖標注 啥是企業400電話辦理

摘要:MySQL JDBC抽取到底應該采用什么樣的方式,且聽小編給你娓娓道來。

小編最近在云上的一個遷移項目中被MySQL抽取模式折磨的很慘。一開始爆內存被客戶懟,再后來遷移效率低下再被懟。MySQL JDBC抽取到底應該采用什么樣的方式,且聽小編給你娓娓道來。

1.1 Java-JDBC通信原理

JDBC與數據庫之間的通信是通過socket完,大致流程如下圖所示。Mysql Server ->內核Socket Buffer -> 客戶端Socket Buffer ->JDBC所在的JVM

1.2 JDBC讀取數據的三種模式

1.2.1 方式1:使用JDBC默認參數讀取數據

主要分為以下幾步:

1)Mysql Server通過OuputStream 向 Socket Server 本地Kennel Buffer 寫入數據,這里是一次內存拷貝。

2)當Socket Server 本地Kennel Buffer 有數據,就會通過TCP鏈路把數據傳輸到Socket Client 所在機器的Kennel Buffer。

3)JDBC 所在JVM利用InputSream讀取本地Kennel Buffer 數據到JVM內存,沒有數據時,則讀取被阻塞。

接下來就是不斷重復1,2,3的過程。 問題 是,Socket Client 端的JVM在默認模式下讀取Kennel Buffer是沒有考慮本機內存大小的,有多少讀多少。如果數據太大,就會造成FULL GC,緊接著內存溢出。

參考 JDBC API docs,默認模式 Java demo 代碼如下

1.2.2 方式2:游標查詢

為了解決方式1爆內存的問題,JDBC提供了一個游標參數,在建立jdbc連接時加上useCursorFetch=true。設置游標后,JDBC 每次會告訴Server端每次抽取的數據量,避免爆內存。通信過程如下圖所示。

​ 方式2游標查詢雖然解決了內存溢出的問題,方式2極大的依賴網絡質量。當網絡時延增大,假設每次通信增加10ms,10萬次通信就會多出1000s。這里僅僅是每次發請求的RT,TCP每次發送報文,都要求反饋ACK保證數據可靠性。client每取100行(請求行數可配置),就會有多次通信,進一步放大時延增加導致的效率問題。此外,游標查詢下,Mysql無法預知查詢的結束時延,為了應對自身的DML操作會在本地建立一個臨時空間存放要抽取的數據。因此,游標查詢時會有以下幾個現象發生

a. IOPS飆升,Mysql將數據寫入到臨時空間,數據傳輸時從臨時空間讀取數據,這都會引發大量IO操作。

b. 磁盤空間飆升,臨時空間生命周期存在于整個JDBC讀取階段,直到客戶端發起Result.close()時才會被Mysql回收。

c. CPU和內存有一定比例上升。

有關游標查詢的原理可參考博客MySQL JDBC StreamResult通信原理淺析以及JDBC源碼,本文不在贅述。

參考 JDBC API docs,游標模式 Java demo 代碼如下

1.2.3 方式3: Stream讀取數據

方式1會導致JVM內存溢出,方式2雖然不會FULL GC但是通信效率較低,而且也會導致Mysql服務端IOPS飆升,消耗磁盤空間等問題。因此,我們介紹Stream讀取數據 ,流式需要在讀取Result前設置

方式3在通信前不會做任何Server-Cient的交互操作,避免通信效率低下。服務端準備好數據寫入Server的Kennel Buffer中,這些數據通過TCP鏈路傳輸到Client的Kennel Buffer中,緊接著client端inputStream.read()方法被喚醒去讀取數據,與方式1不同,client每次只會讀取一個package大小的數據,如果一個package不滿一行則會再讀取一個package。當client消費數據的速度不及數據傳輸速率時,client端kennel區的數據就會被堆滿,緊接著Server端的kennel數據也會堆滿進而阻塞了OuputStream。這樣,JDBC在Stream模式下就像一個水管連接兩個蓄水池,Client和Server達到一個平衡。

​對于JDBC客戶端,由于每次都是從kennel讀取數據,效率會比方式2高很多,每次讀取一小部分數據也不會導致JVM內存溢出。對于服務端,Mysql每次都是往kennel寫數據,無需建立臨時空間,不涉及IO讀取,服務端壓力也變小了。當然,方式3也有自己的問題,例如Stream流式時無法cancel,cancel不阻塞等等。

參考 JDBC API docs,網上很多教程需要設置useCursorFetch=trueResultSet.FETCH_REVERSE等,其實小編研究完JDBC驅動源碼后發現,只需要設fetchSize=Integer. MIN_VALUE,其他配置均和默認配置保持一致即可。游標模式 Java demo 代碼如下

1.3 云數據遷移服務在三種模式下的調優

云數據遷移服務(Cloud Data Migration, CDM)是華為云上一個遷移工具,詳見 CDM官網 ,小編則通過CDM介紹如何切換三種模式抽取數據。CDM默認使用的是方式3,流式抽取數據,如果需要切換方式1,方式2需額外配置。

1.3.1 配置方式1:默認讀取

新建Mysql連接器,建立方法詳見官網,在高級屬性中增加useCursorFetch=false和adopt.stream=false

1.3.2 配置方式2:游標查詢

編輯Mysql連接器,在高級屬性中增加useCursorFetch=true和adopt.stream=false。游標查詢的大小可通過界面上的Fetch Size調整,默認1000。

1.3.3 配置方式3:流式

CDM默認走的流式,無需額外配置。注意Stream模式下,界面上的 Fetch Size 是不起作用的,原因參考上一節。

1.3.4 性能對比

新建Mysql2Hive的CDM遷移作業,源表101個字段,100萬行數據,配置如下

方式1:寫入100萬行數據耗時1m22s

方式2:同樣寫入100萬行,調整fetchSzie分別為1,10,100,100,最低耗時2m1s

方式3:同樣寫入100萬行,耗時1m5s

小編還測試了100萬的小表,明顯方式1和方式3的速率要遠遠高于方式2,另外小編還測試了1000萬的大表,方式1爆內存,方式2正常遷移但耗時20分鐘以上,而方式3仍然可以在15分鐘內跑完。

到此這篇關于從云數據遷移服務看MySQL大表抽取模式的原理解析的文章就介紹到這了,更多相關MySQL大表抽取內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • mysql8.0.11數據目錄遷移的實現
  • mysql8.0.20數據目錄遷移的方法
  • 如何把本地mysql遷移到服務器數據庫
  • mysql事件之修改事件(ALTER EVENT)、禁用事件(DISABLE)、啟用事件(ENABLE)、事件重命名及數據庫事件遷移操作詳解
  • Docker版的MySQL5.7升級到MySQL8.0.13,數據遷移
  • Mysql的數據庫遷移到另一個機器上的方法詳解
  • MySQL數據庫遷移快速導出導入大量數據
  • python制作mysql數據遷移腳本
  • MySQL數據遷移相關總結

標簽:吉林 資陽 錦州 隨州 荊州 甘南 滄州 黑河

巨人網絡通訊聲明:本文標題《從云數據遷移服務看MySQL大表抽取模式的原理解析》,本文關鍵詞  從,云,數據,遷移,服務,看,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《從云數據遷移服務看MySQL大表抽取模式的原理解析》相關的同類信息!
  • 本頁收集關于從云數據遷移服務看MySQL大表抽取模式的原理解析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美精品三级日韩久久| 欧洲一区二区av| 天堂av在线一区| 午夜电影一区二区三区| 日本成人中文字幕在线视频| 国产麻豆日韩欧美久久| 色狠狠桃花综合| 精品久久一区二区| 一色屋精品亚洲香蕉网站| 亚洲一区二区av在线| 韩国成人在线视频| 色综合色综合色综合| 日韩免费视频一区二区| 中文字幕一区二区三区蜜月| 首页亚洲欧美制服丝腿| youjizz国产精品| 欧美一区二区三区免费| 国产精品国产成人国产三级| 丝袜美腿一区二区三区| 不卡一二三区首页| 欧美成人bangbros| 中国av一区二区三区| 奇米四色…亚洲| 日本高清不卡一区| 国产精品女主播av| 狠狠色综合播放一区二区| 欧美日韩一区在线观看| 国产精品毛片久久久久久| 久久精品国产免费| 欧美电影一区二区三区| 亚洲精品国产高清久久伦理二区| 国产精品12区| 久久综合99re88久久爱| 久久精品99久久久| 欧美婷婷六月丁香综合色| 国产精品久久毛片av大全日韩| 精品中文字幕一区二区小辣椒| 色八戒一区二区三区| 欧美日韩一区 二区 三区 久久精品| eeuss鲁片一区二区三区在线观看| 欧美精品一二三四| 亚洲人成网站在线| 国产69精品久久99不卡| 久久综合丝袜日本网| 蜜臀精品一区二区三区在线观看| 欧美日韩亚洲综合在线 | 亚洲国产你懂的| 99re这里都是精品| 国产精品成人一区二区三区夜夜夜| 国产高清久久久| 国产清纯白嫩初高生在线观看91| 精品一区二区三区免费播放| 日韩欧美国产wwwww| 免费在线看成人av| 日韩美女在线视频 | 欧美一级生活片| 亚洲成人精品一区| 91精品国产综合久久国产大片| 日韩国产一二三区| 日韩手机在线导航| 国产精品一区免费在线观看| 国产日韩欧美电影| 99精品欧美一区二区蜜桃免费| 《视频一区视频二区| 一本大道久久精品懂色aⅴ| 亚洲综合视频网| 91精品中文字幕一区二区三区| 日本美女视频一区二区| 久久综合色综合88| jiyouzz国产精品久久| 亚洲伦理在线免费看| 欧美在线观看视频一区二区三区| 亚洲成人7777| 精品99久久久久久| 97久久超碰精品国产| 香蕉久久一区二区不卡无毒影院 | 色视频欧美一区二区三区| 国产欧美日韩视频在线观看| 成人污视频在线观看| 日韩毛片视频在线看| 欧美性猛片xxxx免费看久爱| 日本系列欧美系列| 国产亚洲精久久久久久| 色综合久久综合| 日本欧美一区二区三区乱码 | 国产一区二区精品久久| 国产精品免费av| 欧美日韩极品在线观看一区| 国产麻豆成人传媒免费观看| 亚洲精品五月天| 日韩精品一区二区三区四区视频| 成人精品一区二区三区四区| 亚洲第一在线综合网站| 久久久精品影视| 欧美日韩成人在线一区| 99热精品一区二区| 狠狠久久亚洲欧美| 午夜精品久久久久影视| 国产精品丝袜91| 欧美日韩亚洲综合在线| 成人av在线资源网| 激情丁香综合五月| 无码av免费一区二区三区试看| 欧美韩国一区二区| 欧美成人艳星乳罩| 欧美日本一道本| 日本精品裸体写真集在线观看| 国产一区二区精品久久99| 日韩电影免费在线看| 亚洲精品免费播放| 国产精品久久久久婷婷二区次| 精品伦理精品一区| 欧美另类高清zo欧美| 91免费观看视频在线| 成人在线视频一区| 精品在线一区二区三区| 日韩高清在线一区| 亚洲风情在线资源站| 亚洲日本韩国一区| 国产精品短视频| 中文一区一区三区高中清不卡| 亚洲精品在线观看网站| 日韩一区二区三区四区五区六区| 欧美午夜在线一二页| 日本韩国视频一区二区| 色综合中文字幕国产 | 精品成人一区二区三区| 在线电影国产精品| 在线播放亚洲一区| 欧美视频自拍偷拍| 欧美色图免费看| 欧美日韩国产天堂| 欧美日韩大陆在线| 欧美肥妇毛茸茸| 欧美一卡二卡在线观看| 日韩视频一区二区三区| 欧美成人猛片aaaaaaa| 欧美zozozo| 久久久久国产成人精品亚洲午夜| 久久久久久久久久久久久久久99| 国产亚洲精久久久久久| 亚洲国产成人自拍| 国产精品福利av| 亚洲影院免费观看| 日韩精品五月天| 久久99精品国产91久久来源| 韩国v欧美v亚洲v日本v| 高清av一区二区| 99在线精品免费| 欧美丝袜丝交足nylons图片| 欧美精品高清视频| 26uuu国产电影一区二区| 国产精品污www在线观看| 亚洲激情在线激情| 三级一区在线视频先锋 | 精品久久久久久久久久久久久久久 | 亚洲国产精品天堂| 午夜精品福利一区二区三区av| 日本va欧美va欧美va精品| 国产麻豆成人传媒免费观看| eeuss国产一区二区三区| 色av一区二区| 这里是久久伊人| 久久久噜噜噜久久人人看 | 91网站在线观看视频| 欧美图片一区二区三区| 日韩欧美一区在线观看| 日本一区二区三区电影| 亚洲一二三四久久| 蜜桃视频在线一区| 99久久久国产精品| 在线播放日韩导航| 国产精品欧美一区二区三区| 午夜精品视频在线观看| 成人在线一区二区三区| 欧美久久久影院| 欧美—级在线免费片| 午夜视黄欧洲亚洲| 粉嫩绯色av一区二区在线观看 | 色噜噜狠狠色综合中国| 欧美一区二区三区公司| 亚洲欧洲一区二区在线播放| 蜜桃精品在线观看| 一本一本大道香蕉久在线精品 | 韩国精品久久久| 91成人在线精品| 久久精品一区二区三区四区| 欧美日韩在线精品一区二区三区激情 | 日韩精品一区二区三区视频| 最新日韩在线视频| 国产在线国偷精品产拍免费yy| 91久久精品日日躁夜夜躁欧美| 久久久久久电影| 亚洲va国产va欧美va观看| av亚洲产国偷v产偷v自拍| 精品精品欲导航| 日韩精品欧美精品| 欧美伊人久久大香线蕉综合69| 国产精品欧美一级免费| 国产美女一区二区三区|