Spark Streaming如何消費Kafka的大消息(30M-40MB)

本文基于Spark2.1.0版本

雖然很少有生產(chǎn)環(huán)境用Kafka傳遞超過1M消息的場景(因為高吞吐、低延時的要求,Kafka 發(fā)布-訂閱模型中Producer-Broker-Consumer 3方的相關(guān)默認配置都是1M)麦向,但由于手上項目的特殊需求子檀,希望Spark Streaming抽取Kafka數(shù)據(jù)源時,能消費30M-40MB大小的消息陶衅。下面我把相關(guān)配置及源碼提供一下屡立,有需要的同學可以參考。

(本文只涉及ETL過程中數(shù)據(jù)的抽取搀军,不涉及轉(zhuǎn)換和加載過程)

業(yè)務模型如下:

1膨俐,修改Producer-Broker-Consumer 3方配置,使其支持超大消息的傳遞和接收

producer配置
producer配置

A:修改Producer的max.request.size罩句,允許生產(chǎn)者發(fā)送超大消息焚刺,默認是1M

vim $KAFKA_HOME/config/producer.properties

修改max.request.size=41943040 ?#40MB

修改Producer的buffer.memory,允許生產(chǎn)者發(fā)送超大消息時的緩沖區(qū)的止,默認是32M

buffer.memory=45000000 # >40MB

Broker配置
Broker配置
Broker配置

B:修改Broker的message.max.bytes檩坚、replica.fetch.max.bytes、max.message.bytes允許Broker傳遞和備份超大消息诅福,默認是1M

vim $KAFKA_HOME/config/server.properties

修改message.max.bytes=41943040? #40MB

修改replica.fetch.max.bytes=41943040? #40MB

max.message.bytes可以不用修改匾委,默認值=message.max.bytes

Consumer配置

C:修改Consumer的fetch.message.max.bytes,允許消費者拉取超大消息氓润,默認是1M

vim $KAFKA_HOME/config/consumer.properties

修改fetch.message.max.bytes=41943040? #40MB

上述配置修改完成后赂乐,所有Broker都需要重啟Kafka服務。

2咖气,Spark Streaming用Kafka 0.10.2的new Kafka consumer API 來消費超大消息

使用spark-streaming-kafka-0-10_2.11-2.1.0.jar提供的KafkaUtils.createDirectStream接口

3挨措,測試

通過$KAFKA_HOME/bin下的kafka-producer-perf-test.sh充當生產(chǎn)者,發(fā)送40MB左右的消息

./kafka-producer-perf-test.sh --topic wl_test --num-records 1 --record-size 40000000 --throughput? 1 --producer-props bootstrap.servers=wl1:9092 max.request.size=45000000 buffer.memory=45000000


生產(chǎn)者發(fā)送消息后崩溪,通過Kafka Manager觀察浅役,Consumer已經(jīng)完成了消息抽取后的commit,Consumer offset增加伶唯。

driver端輸出消息

web ui能看到消費的具體情況

4觉既,Spark 2.1.0 的Streaming使用Kafka 0.10.2新Consumer API的整合接口好處多多

詳見官網(wǎng):

spark.apache.org/docs/latest/streaming-kafka-0-10-integration.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市乳幸,隨后出現(xiàn)的幾起案子瞪讼,更是在濱河造成了極大的恐慌,老刑警劉巖粹断,帶你破解...
    沈念sama閱讀 222,627評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件符欠,死亡現(xiàn)場離奇詭異,居然都是意外死亡瓶埋,警方通過查閱死者的電腦和手機希柿,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,180評論 3 399
  • 文/潘曉璐 我一進店門诊沪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人狡汉,你說我怎么就攤上這事娄徊。” “怎么了盾戴?”我有些...
    開封第一講書人閱讀 169,346評論 0 362
  • 文/不壞的土叔 我叫張陵,是天一觀的道長兵多。 經(jīng)常有香客問我尖啡,道長,這世上最難降的妖魔是什么剩膘? 我笑而不...
    開封第一講書人閱讀 60,097評論 1 300
  • 正文 為了忘掉前任衅斩,我火速辦了婚禮,結(jié)果婚禮上怠褐,老公的妹妹穿的比我還像新娘畏梆。我一直安慰自己,他們只是感情好奈懒,可當我...
    茶點故事閱讀 69,100評論 6 398
  • 文/花漫 我一把揭開白布奠涌。 她就那樣靜靜地躺著,像睡著了一般磷杏。 火紅的嫁衣襯著肌膚如雪溜畅。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,696評論 1 312
  • 那天极祸,我揣著相機與錄音慈格,去河邊找鬼。 笑死遥金,一個胖子當著我的面吹牛浴捆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播稿械,決...
    沈念sama閱讀 41,165評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼选泻,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了溜哮?” 一聲冷哼從身側(cè)響起滔金,我...
    開封第一講書人閱讀 40,108評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎茂嗓,沒想到半個月后餐茵,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,646評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡述吸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,709評論 3 342
  • 正文 我和宋清朗相戀三年忿族,在試婚紗的時候發(fā)現(xiàn)自己被綠了锣笨。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,861評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡道批,死狀恐怖错英,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情隆豹,我是刑警寧澤椭岩,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站璃赡,受9級特大地震影響判哥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜碉考,卻給世界環(huán)境...
    茶點故事閱讀 42,196評論 3 336
  • 文/蒙蒙 一塌计、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧侯谁,春花似錦锌仅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,698評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至嫩痰,卻和暖如春剿吻,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背串纺。 一陣腳步聲響...
    開封第一講書人閱讀 33,804評論 1 274
  • 我被黑心中介騙來泰國打工丽旅, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人纺棺。 一個月前我還...
    沈念sama閱讀 49,287評論 3 379
  • 正文 我出身青樓榄笙,卻偏偏與公主長得像,于是被迫代替她去往敵國和親祷蝌。 傳聞我的和親對象是個殘疾皇子茅撞,可洞房花燭夜當晚...
    茶點故事閱讀 45,860評論 2 361

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