kafka-console-consumer.sh使用2次grep管道無法提取消息的解決
問題
在使用kafka自帶腳本消費(fèi)時(shí),想用grep關(guān)鍵詞過濾出來想要的信息
./kafka-console-consumer.sh \ --bootstrap-server node1:9092,node2:9092,node3:9092 \ --topic test \ --from-beginning \ --consumer-property group.id=gaofeng_test\ | grep "b786aba6f3a6" | grep 388aabd
但是發(fā)現(xiàn)grep命令在這里有問題,無法取到想要消息
已經(jīng)消費(fèi)到latest了,都沒有提取到想要的msg
這里確認(rèn)了producer端已經(jīng)發(fā)送成功了,回調(diào)函數(shù)里都沒有任何異常
懷疑
懷疑是否kafka存在丟數(shù)據(jù)的情況
排查問題后發(fā)現(xiàn)kafka集群一切正常,性能也很強(qiáng)勁
并且在存儲(chǔ)消息的日志文件中也已經(jīng)查詢到了我想要的消息了,為什么就是消費(fèi)不出來呢
分析
將kafka的這個(gè)主題 --from-beginning 消費(fèi)到文件topic.log中去
對(duì)topic.log這個(gè)靜態(tài)文件進(jìn)行g(shù)rep “b786aba6f3a6” | grep 388aabd抽取,發(fā)現(xiàn)取到了自己想要的這條消息
kafka消費(fèi)時(shí)結(jié)果是動(dòng)態(tài)的,grep這里用法不對(duì),只有對(duì)靜態(tài)的文件可以抽取到數(shù)據(jù)
--line-buffered
Force output to be line buffered. By default, output is line buffered when standard output is
a terminal and block buffered otherwise
上面的意思是
- 強(qiáng)制輸出結(jié)果使用行緩沖
- 默認(rèn)情況下,如果標(biāo)準(zhǔn)輸入時(shí)終端,則使用line bufferred
- 否則,使用塊緩沖,(默認(rèn)的大小為4096 bytes,因系統(tǒng)和配置而異)
所以,這也就解釋了為什么雙重grep過濾沒有內(nèi)容,因?yàn)闆]有達(dá)到塊緩沖限制。
驗(yàn)證
生產(chǎn)消息
a,b,c
消費(fèi)時(shí)兩次grep則無消息
消費(fèi)時(shí)一次grep則都出來
結(jié)論
- 剛剛
/kafka-console-consumer.sh
第一次grep過濾出來的的消息小于4k了,所以傳給第二次grep是不可以直接輸出出來的,因?yàn)樵诰彌_區(qū) - 如果第一次grep出來的數(shù)據(jù)大于4k,傳給第二個(gè)grep時(shí)則不會(huì)緩沖著,第二個(gè)grep收到就立刻傳入到terminal輸出了
- 反之第一次grep過濾出來的的消息大于還是小于4k,一旦后面沒有管道符號(hào),直接輸出給terminal的話,則遵循line bufferred規(guī)則立馬輸出
解決
使用如下命令即可
./kafka-console-consumer.sh \ --bootstrap-server node1:9092,node2:9092,node3:9092 \ --topic test \ --from-beginning \ --consumer-property group.id=gaofeng_test\ | grep --line-buffered "b786aba6f3a6" | grep 388aabd
【注意】
這里用了grep 的 --line-buffered參數(shù)
具體用法
查閱http://www.dbjr.com.cn/article/277299.htm
最后
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
SpringMVC解析JSON請(qǐng)求數(shù)據(jù)問題解析
這篇文章主要介紹了SpringMVC解析JSON請(qǐng)求數(shù)據(jù)問題解析,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04詳解servlet的url-pattern匹配規(guī)則
本篇文章主要介紹了=servlet的url-pattern匹配規(guī)則,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12SpringBoot 設(shè)置傳入?yún)?shù)非必要的操作
這篇文章主要介紹了SpringBoot 設(shè)置傳入?yún)?shù)非必要的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-02-02Elasticsearch查詢及聚合類DSL語句寶典示例詳解
這篇文章主要為大家介紹了Elasticsearch查詢及聚合類DSL語句寶典示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-01-01SpringBoot工程啟動(dòng)順序與自定義監(jiān)聽超詳細(xì)講解
這篇文章主要介紹了SpringBoot工程啟動(dòng)順序與自定義監(jiān)聽,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-11-11java開源調(diào)度如何給xxljob加k8s執(zhí)行器
這篇文章主要介紹了java開源調(diào)度如何給xxljob加一個(gè)k8s執(zhí)行器,?xxljob?在設(shè)計(jì)上,抽象出了執(zhí)行器的接口,所以實(shí)現(xiàn)一個(gè)語言的執(zhí)行器并不復(fù)雜,這里主要探索下,如何利用k8s的pod?的能力,使用?xxljob?調(diào)度?pod?運(yùn)行,實(shí)現(xiàn)一個(gè)通用的和語言無關(guān)的執(zhí)行器2022-02-02淺談Java代理(jdk靜態(tài)代理、動(dòng)態(tài)代理和cglib動(dòng)態(tài)代理)
下面小編就為大家?guī)硪黄獪\談Java代理(jdk靜態(tài)代理、動(dòng)態(tài)代理和cglib動(dòng)態(tài)代理)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-01-01