国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

大規模集群下的Hadoop NameNode

大數據 Hadoop
本文我們來看看,如果大量客戶端對NameNode發起高并發(比如每秒上千次)訪問來修改元數據,此時NameNode該如何抗住?

本文我們來看看,如果大量客戶端對NameNode發起高并發(比如每秒上千次)訪問來修改元數據,此時NameNode該如何抗住?

一、問題源起

我們先來分析一下,高并發請求NameNode會遇到什么樣的問題。

大家現在都知道了,每次請求NameNode修改一條元數據(比如說申請上傳一個文件,那么就需要在內存目錄樹中加入一個文件),都要寫一條edits log,包括兩個步驟:

寫入本地磁盤。

通過網絡傳輸給JournalNodes集群。

但是如果對Java有一定了解的同學都該知道多線程并發安全問題吧?

NameNode在寫edits log時的***條原則:

必須保證每條edits log都有一個全局順序遞增的transactionId(簡稱為txid),這樣才可以標識出來一條一條的edits log的先后順序。

那么如果要保證每條edits log的txid都是遞增的,就必須得加鎖。

每個線程修改了元數據,要寫一條edits log的時候,都必須按順序排隊獲取鎖后,才能生成一個遞增的txid,代表這次要寫的edits log的序號。

好的,那么問題來了,大家看看下面的圖。

如果每次都是在一個加鎖的代碼塊里,生成txid,然后寫磁盤文件edits log,網絡請求寫入journalnodes一條edits log,會咋樣?

大規模集群下的Hadoop NameNode

不用說,這個絕對完蛋了!

NameNode本身用多線程接收多個客戶端發送過來的并發的請求,結果多個線程居然修改完內存中的元數據之后,排著隊寫edits log!

而且你要知道,寫本地磁盤 + 網絡傳輸給journalnodes,都是很耗時的啊!性能兩大殺手:磁盤寫 + 網絡寫!

如果HDFS的架構真要是這么設計的話,基本上NameNode能承載的每秒的并發數量就很少了,可能就每秒處理幾十個并發請求處理撐死了!

二、HDFS優雅的解決方案

所以說,針對這個問題,人家HDFS是做了不少的優化的!

首先大家想一下,既然咱們不希望每個線程寫edits log的時候,串行化排隊生成txid + 寫磁盤 + 寫JournalNode,那么是不是可以搞一個內存緩沖?

也就是說,多個線程可以快速的獲取鎖,生成txid,然后快速的將edits log寫入內存緩沖。

接著就快速的釋放鎖,讓下一個線程繼續獲取鎖后,生成id + 寫edits log進入內存緩沖。

然后接下來有一個線程可以將內存中的edits log刷入磁盤,但是在這個過程中,還是繼續允許其他線程將edits log寫入內存緩沖中。

但是這里又有一個問題了,如果針對同一塊內存緩沖,同時有人寫入,還同時有人讀取后寫磁盤,那也有問題,因為不能并發讀寫一塊共享內存數據!

所以HDFS在這里采取了double-buffer雙緩沖機制來處理!將一塊內存緩沖分成兩個部分:

其中一個部分可以寫入

另外一個部分用于讀取后寫入磁盤和JournalNodes。

大家可能感覺文字敘述不太直觀,老規矩,咱們來一張圖,按順序給大家闡述一下。

大規模集群下的Hadoop NameNode

(1)分段加鎖機制 + 內存雙緩沖機制

首先各個線程依次***次獲取鎖,生成順序遞增的txid,然后將edits log寫入內存雙緩沖的區域1,接著就立馬***次釋放鎖了。

趁著這個空隙,后面的線程就可以再次立馬***次獲取鎖,然后立即寫自己的edits log到內存緩沖。

寫內存那么快,可能才耗時幾十微妙,接著就立馬***次釋放鎖了。所以這個并發優化絕對是有效果的,大家有沒有感受到?

接著各個線程競爭第二次獲取鎖,有線程獲取到鎖之后,就看看,有沒有誰在寫磁盤和網絡?

如果沒有,好,那么這個線程是個幸運兒!直接交換雙緩沖的區域1和區域2,接著第二次釋放鎖。這個過程相當快速,內存里判斷幾個條件,耗時不了幾微秒。

好,到這一步為止,內存緩沖已經被交換了,后面的線程可以立馬快速的依次獲取鎖,然后將edits log寫入內存緩沖的區域2,區域1中的數據被鎖定了,不能寫。

怎么樣,是不是又感受到了一點點多線程并發的優化?

(2)多線程并發吞吐量的百倍優化

接著,之前那個幸運兒線程,將內存緩沖的區域1中的數據讀取出來(此時沒人寫區域1了,都在寫區域2),將里面的edtis log都寫入磁盤文件,以及通過網絡寫入JournalNodes集群。

這個過程可是很耗時的!但是沒關系啊,人家做過優化了,在寫磁盤和網絡的過程中,是不持有鎖的!

因此后面的線程可以噼里啪啦的快速的***次獲取鎖后,立馬寫入內存緩沖的區域2,然后釋放鎖。

這個時候大量的線程都可以快速的寫入內存,沒有阻塞和卡頓!

怎么樣?并發優化的感覺感受到了沒有!

(3)緩沖數據批量刷磁盤 + 網絡的優化

那么在幸運兒線程吭哧吭哧把數據寫磁盤和網絡的過程中,排在后面的大量線程,快速的***次獲取鎖,寫內存緩沖區域2,釋放鎖,之后,這些線程第二次獲取到鎖后會干嘛?

他們會發現有人在寫磁盤啊,兄弟們!所以會立即休眠1秒,釋放鎖。

此時大量的線程并發過來的話,都會在這里快速的第二次獲取鎖,然后發現有人在寫磁盤和網絡,快速的釋放鎖,休眠。

怎么樣,這個過程沒有人長時間的阻塞其他人吧!因為都會快速的釋放鎖,所以后面的線程還是可以迅速的***次獲取鎖后寫內存緩沖!

again!并發優化的感覺感受到了沒有?

而且這時,一定會有很多線程發現,好像之前那個幸運兒線程的txid是排在自己之后的,那么肯定就把自己的edits log從緩沖里寫入磁盤和網絡了。

這些線程甚至都不會休眠等待,直接就會返回后去干別的事情了,壓根兒不會卡在這里。這里又感受到并發的優化沒有?

然后那個幸運兒線程寫完磁盤和網絡之后,就會喚醒之前休眠的那些線程。

那些線程會依次排隊再第二次獲取鎖后進入判斷,咦!發現沒有人在寫磁盤和網絡了!

然后就會再判斷,有沒有排在自己之后的線程已經將自己的edtis log寫入磁盤和網絡了。

如果有的話,就直接返回了。

沒有的話,那么就成為第二個幸運兒線程,交換兩塊緩沖區,區域1和區域2交換一下。

然后釋放鎖,自己開始吭哧吭哧的將區域2的數據寫入磁盤和網絡。

但是這個時候沒有關系啊,后面的線程如果要寫edits log的,還是可以***次獲取鎖后立馬寫內存緩沖再釋放鎖。以此類推。

三、總結

其實這套機制還是挺復雜的,涉及到了分段加鎖以及內存雙緩沖兩個機制。

通過這套機制,NameNode保證了多個線程在高并發的修改元數據之后寫edits log的時候,不會說一個線程一個線程的寫磁盤和網絡,那樣性能實在太差,并發能力太弱了!

所以通過上述那套復雜的機制,盡***的努力保證,一個線程可以批量的將一個緩沖中的多條edits log刷入磁盤和網絡。

在這個漫長的吭哧吭哧的過程中,其他的線程可以快速的高并發寫入edits log到內存緩沖里,不會阻塞其他的線程寫edits log。

所以,正是依靠以上機制,***限度優化了NameNode處理高并發訪問修改元數據的能力!

責任編輯:未麗燕 來源: 搜狐
相關推薦

2023-02-17 07:41:18

KubernetePrometheus

2010-12-23 11:01:19

集群FTPFTP代理

2015-08-31 05:51:37

集群運維私有云

2015-06-11 13:24:27

集群運維

2021-08-29 20:02:38

高并發集群部署

2016-08-12 15:40:17

CCEKubernetes華為

2015-10-12 15:11:36

GoogleBorg集群管理

2015-10-13 11:06:36

谷歌Google Borg集群管理

2015-09-07 12:06:10

51CTO技術周刊集群運維

2020-07-27 08:23:15

HadoopPrometheusZabbix

2022-05-11 09:34:15

云原生集群數倉

2015-06-26 09:17:28

WOT2015360孔德亮

2019-10-09 10:00:02

集群故障場景

2019-10-09 09:39:15

PythonHDFS大數據

2020-04-09 11:56:10

Elasticsear集群硬件

2011-07-15 17:12:15

云計算SkyptLync

2024-06-07 14:01:29

2015-07-28 15:58:26

2022-02-17 20:16:15

DDOS網絡攻擊

2013-07-11 13:39:23

Hadoop
點贊
收藏

51CTO技術棧公眾號

亚洲精品视频免费看| 一本色道久久综合亚洲精品按摩| 国产精品综合久久| 91黄在线观看| 99se视频在线观看| 在线电影一区| 久久综合88中文色鬼| 深夜视频在线免费| 国产精品传媒入口麻豆| 黄色高清无遮挡| 极品尤物久久久av免费看| 国产91亚洲精品| 亚洲视频自拍| 一区二区三区美女| 国产成人天天5g影院在线观看| 亚洲免费福利一区| 在线综合亚洲欧美在线视频| 福利片免费在线观看| 成人免费高清在线| 干日本少妇首页| 中文字幕日韩av资源站| 操日韩av在线电影| 三级在线看中文字幕完整版| 精品国产1区2区| 日韩专区一区二区| 欧美色图免费看| a国产在线视频| 久久久久久久爱| 女人av一区| 99久久99久久精品国产片| 五月天久久久| 欧美一区二区三区在线播放| 老司机免费视频一区二区| 中文字幕在线中文字幕日亚韩一区| 老司机精品视频在线| 日本精品免费在线观看| 亚洲 欧美综合在线网络| av在线中文| www.久久久久| 欧美成人黑人| 91精品视频在线| 西瓜成人精品人成网站| 国内成人精品一区| 永久91嫩草亚洲精品人人| 国产综合动作在线观看| 国内精品视频一区二区三区八戒| 内射国产内射夫妻免费频道| 亚洲男人的天堂在线aⅴ视频| 一区 二区 三区| 在线播放国产精品| 91麻豆精品国产91久久久平台 | 91日韩在线视频| 麻豆成人久久精品二区三区红| 污片在线免费看| 亚洲电影天堂av| 精品国产一区探花在线观看 | 国产一区三区三区| 视频在线国产| 中文字幕亚洲一区| 久久精品麻豆| 在线免费看污| 国产免费一区二区三区在线能观看 | 日韩免费高清视频| 性欧美xxxx免费岛国不卡电影| 日韩精品一区二区三区丰满| 日本一区二区三区高清不卡| 欧美videossex| 92看片淫黄大片欧美看国产片| 久久久亚洲国产美女国产盗摄| 性欧美又大又长又硬| 国产中文一区二区| 日韩欧美a级成人黄色| 国产成人夜色高潮福利影视 | 国产精品国产三级国产aⅴ中文| 樱花草涩涩www在线播放| 精品国产乱码久久久久久久软件| 国产精品乱码久久久久久| 欧美aa一级| 国产日韩欧美大片| 亚洲丁香婷深爱综合| 美女一区二区视频| 国产日产一区二区三区| 久久精品日韩精品| 91精品国产欧美一区二区18| 亚洲欧美视频一区二区三区| 求av网址在线观看| 亚洲精品成人a8198a| 亚洲国产中文字幕久久网| 久久aⅴ国产欧美74aaa| a'aaa级片在线观看| 在线观看一区欧美| 夜夜躁日日躁狠狠久久88av| www亚洲一区| 欧美精美视频| www.亚洲资源| 日本黄色片一级片| 久久久久久尹人网香蕉| 亚洲精品视频观看| 亚洲精品123区| 久久久成人av毛片免费观看| 青青草国产精品视频| 国产91精品最新在线播放| 欧美伊人久久久久久午夜久久久久| 国产亚洲成人一区| 992tv国产精品成人影院| www.成人69.com| 精品国产电影| 国内揄拍国内精品少妇国语| 欧美性色综合网| 国产日韩一级二级三级| 国产精品啊啊啊| 中文在线综合| 欧美a级在线观看| 国产奶头好大揉着好爽视频| 欧美疯狂性受xxxxx另类| 欧美经典一区二区| 很黄很黄激情成人| 任你弄精品视频免费观看| www红色一片_亚洲成a人片在线观看_| 国产一区二区四区| 久久婷婷国产综合尤物精品| 欧美精品久久一区二区| 亚洲福利在线播放| 欧美色图免费看| 夜夜嗨av一区二区三区四季av| 日韩专区中文字幕一区二区| 欧美gvvideo网站| 日韩aaa久久蜜桃av| 欧美成人三级| aa国产成人| av网站大全在线| 久操视频在线| 手机亚洲第一页| 91在线最新| 亚洲国产精品成人一区二区在线| www.精品在线| 欧美成年人视频在线观看| 青青在线视频观看| 毛片在线视频观看| 欧美 国产 精品| 免费拍拍拍网站| 337p粉嫩大胆噜噜噜鲁| 色香蕉在线观看| 在线观看日韩片| www.在线观看av| 好吊妞无缓冲视频观看| aa免费在线观看| 国模杨依粉嫩蝴蝶150p| 丝袜老师办公室里做好紧好爽| 国产精品天天av精麻传媒| 又黄又免费的网站| 美女一级全黄| 日本韩国一区| 欧美a级在线观看| 国产 日韩 欧美 综合 一区| 精品中国亚洲| 欧美视频一区| 国产成人av电影在线| 国产性做久久久久久| 亚洲专区一二三| 亚洲国产一区自拍| 国产香蕉一区二区三区在线视频| 色妞在线综合亚洲欧美| 午夜免费久久久久| 99在线国产| 91看片就是不一样| 日本天堂在线| 国产精品一区三区在线观看| 大片网站久久| 国产美女久久久久| 亚洲主播在线观看| 亚洲美女av在线| 国产精品美女久久久久久免费| 亚洲一区二区三区四区中文| 白天操夜夜操| 亚洲伦乱视频| 一本久道综合久久精品| 国产三级精品三级| 一个人看的www久久| 91网免费观看| 先锋成人影院| 日韩一区二区三区在线免费观看 | 飘雪影院手机免费高清版在线观看| free性护士videos欧美| 国产精品久久久久久| 99九九99九九九视频精品| 欧美不卡一区二区三区四区| 青青草精品毛片| 国产原创popny丨九色| av最新在线| 日韩精品欧美精品| 欧美吻胸吃奶大尺度电影| 国产欧美日韩精品专区| 久草福利视频在线| 台湾天天综合人成在线| 免费亚洲网站| 精品日韩一区二区三区| 欧美二区三区| 成人性生交大片免费看在线播放| 午夜在线精品偷拍|