在一臺(tái)服務(wù)器上搭建相對(duì)高可用HiveServer實(shí)踐

問(wèn)題及原因

搭建過(guò)一個(gè)hiveserver被ETL程序調(diào)用,hiveserver隔三差五地掛掉重啟,網(wǎng)上查了些資料,這是一個(gè)比較普遍的問(wèn)題拆吆,原因基本上都是進(jìn)程內(nèi)存用爆引發(fā)的hiveserver奔潰,內(nèi)存爆掉的原因大概有兩個(gè):

  • hiveserver2會(huì)加載大量的元數(shù)據(jù)脂矫,元數(shù)據(jù)多了枣耀,內(nèi)存就oom了
  • 連接hiverserver2的sql性能慢,查詢時(shí)間超長(zhǎng)庭再,占用大量?jī)?nèi)存

解決方法

目前內(nèi)存爆掉沒(méi)有太好的解決方法捞奕,一般的解決方法監(jiān)控和重啟,使用探針程序定時(shí)監(jiān)測(cè)hiveserver是否工作拄轻,如果不工作就重啟颅围。另外啟動(dòng)多個(gè)hiveserver,使用HA工具進(jìn)行切換恨搓,本文中采用HAProxy院促,HAProxy是一個(gè)開(kāi)源的HA工具,可以工作在TCP層和HTTP層斧抱。

image.png

實(shí)踐方案

軟硬件配置

  • 16G內(nèi)存服務(wù)器一臺(tái)
  • Hive客戶端
  • HAProxy
 ##使用不同的端口啟動(dòng)三個(gè)hiveserver
hiveserver2 --hiveconf hive.server2.thrift.port=10000 &
hiveserver2 --hiveconf hive.server2.thrift.port=10001 &
hiveserver2 --hiveconf hive.server2.thrift.port=10004 &
##crontab定時(shí)執(zhí)行的檢查程序
##探針程序常拓,每分鐘執(zhí)行一次,檢查hiveserver是否運(yùn)行正常
java -jar HiveserverState-jar-with-dependencies.jar -Ddatasource=plumber -Dport=10000
if [ $? -ne 0 ]
then
##內(nèi)存監(jiān)控重定向到文件夺姑,查看hiveserver掛的那個(gè)時(shí)刻內(nèi)存的快照
ps -ef|grep "org.apache.hive.service.server.HiveServer2 --hiveconf 
hive.server2.thrift.port=10000" | grep -v grep | awk '{print $2}'  | xargs jstat -gcutil >> mem_stat.log
ps -ef|grep "org.apache.hive.service.server.HiveServer2 --hiveconf hive.server2.thrift.port=10000" | grep -v grep | awk '{print $2}'  | xargs kill -9
nohup hiveserver2 --hiveconf hive.server2.thrift.port=10000 &
echo 'restart Hiveserver 10000 端口成功'
fi

java -jar HiveserverState-jar-with-dependencies.jar -Ddatasource=plumber -Dport=10001
if [ $? -ne 0 ]
then
ps -ef|grep "org.apache.hive.service.server.HiveServer2 --hiveconf hive.server2.thrift.port=10001" | grep -v grep | awk '{print $2}'  | xargs jstat -gcutil >> mem_stat.log
ps -ef|grep "org.apache.hive.service.server.HiveServer2 --hiveconf hive.server2.thrift.port=10001" | grep -v grep | awk '{print $2}' | xargs kill -9
nohup hiveserver2 --hiveconf hive.server2.thrift.port=10001 &
echo 'restart Hiveserver 10001 端口成功'
fi

java -jar HiveserverState-jar-with-dependencies.jar -Ddatasource=plumber -Dport=10004
if [ $? -ne 0 ]
then
ps -ef|grep "org.apache.hive.service.server.HiveServer2 --hiveconf hive.server2.thrift.port=10004" | grep -v grep | awk '{print $2}'  | xargs jstat -gcutil >> mem_stat.log
ps -ef|grep "org.apache.hive.service.server.HiveServer2 --hiveconf hive.server2.thrift.port=10004" | grep -v grep | awk '{print $2}' | xargs kill -9
nohup hiveserver2 --hiveconf hive.server2.thrift.port=10004 &
echo 'restart Hiveserver 10004 端口成功'
fi
  • HA配置如下
listen hive             #hive后端定義
        bind 0.0.0.0:10003              #ha作為proxy所綁定的IP和端口
        mode tcp                        #以4層方式代理,重要
        balance leastconn               #調(diào)度算法 'leastconn' 最少連接數(shù)分配掌猛,或者 'roundrobin'盏浙,輪詢分配
        maxconn 10240                    #最大連接數(shù)
        server hive_1 server_ip:10000 check inter 180000 rise 1 fall 2
        server hive_2 server_ip:10001 check inter 180000 rise 1 fall 2
        server hive_3 server_ip:10004 check inter 180000 rise 1 fall 2
image.png

問(wèn)題及改進(jìn)

以上方法搭建的hiveserver只是相對(duì)高可用,應(yīng)對(duì)組內(nèi)的ETL任務(wù)已經(jīng)足夠了荔茬。因?yàn)橹挥幸慌_(tái)機(jī)器废膘,所以存在單點(diǎn)故障,在實(shí)際生產(chǎn)環(huán)境中慕蔚,可以使用兩臺(tái)機(jī)器作為HAProxy丐黄,另外三臺(tái)作為hiveserver。

參考文章

http://lanlian.blog.51cto.com/6790106/1305228
http://www.cnblogs.com/smartloli/p/4368676.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末孔飒,一起剝皮案震驚了整個(gè)濱河市灌闺,隨后出現(xiàn)的幾起案子艰争,更是在濱河造成了極大的恐慌,老刑警劉巖桂对,帶你破解...
    沈念sama閱讀 211,561評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甩卓,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蕉斜,警方通過(guò)查閱死者的電腦和手機(jī)逾柿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)宅此,“玉大人机错,你說(shuō)我怎么就攤上這事「竿螅” “怎么了弱匪?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,162評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)侣诵。 經(jīng)常有香客問(wèn)我痢法,道長(zhǎng),這世上最難降的妖魔是什么杜顺? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,470評(píng)論 1 283
  • 正文 為了忘掉前任财搁,我火速辦了婚禮,結(jié)果婚禮上躬络,老公的妹妹穿的比我還像新娘尖奔。我一直安慰自己,他們只是感情好穷当,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布提茁。 她就那樣靜靜地躺著,像睡著了一般馁菜。 火紅的嫁衣襯著肌膚如雪茴扁。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,806評(píng)論 1 290
  • 那天汪疮,我揣著相機(jī)與錄音峭火,去河邊找鬼。 笑死智嚷,一個(gè)胖子當(dāng)著我的面吹牛卖丸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播盏道,決...
    沈念sama閱讀 38,951評(píng)論 3 407
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼稍浆,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起衅枫,我...
    開(kāi)封第一講書(shū)人閱讀 37,712評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤嫁艇,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后为鳄,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體裳仆,經(jīng)...
    沈念sama閱讀 44,166評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評(píng)論 2 327
  • 正文 我和宋清朗相戀三年孤钦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了歧斟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,643評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡偏形,死狀恐怖静袖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情俊扭,我是刑警寧澤队橙,帶...
    沈念sama閱讀 34,306評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站萨惑,受9級(jí)特大地震影響捐康,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜庸蔼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評(píng)論 3 313
  • 文/蒙蒙 一解总、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧姐仅,春花似錦花枫、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,745評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)弥喉。三九已至订歪,卻和暖如春滔韵,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背颖变。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,983評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工生均, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人悼做。 一個(gè)月前我還...
    沈念sama閱讀 46,351評(píng)論 2 360
  • 正文 我出身青樓疯特,卻偏偏與公主長(zhǎng)得像哗魂,于是被迫代替她去往敵國(guó)和親肛走。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容