Kafka發(fā)送消息與AOP沖突報錯

最近在做項目時依痊,在“發(fā)送系統(tǒng)通知”功能模塊采用kafka作為消息中間件都伪,使用生產者發(fā)送消息時出現(xiàn)空指針異常,后發(fā)現(xiàn)與日志記錄功能(使用AOP織入)出現(xiàn)沖突策州,修改后解決問題埠褪,具體如下浓利。


版權聲明:本文為博主原創(chuàng)文章,禁止轉載
作者博客:codesong.cn
created: 2019-12-05


功能描述

項目為一個類似于百度貼吧的社區(qū)項目钞速,采用Spring Boot框架贷掖。
在評論(comment)、點贊(like)渴语、關注(follow)等高頻使用的功能上采用了kafka消息隊列苹威,出現(xiàn)以上三種行為時,生產者(producer)會發(fā)送一個事件(event)到消息隊列中驾凶。
觸發(fā)事件后牙甫,生產者將消息以JSON串的格式發(fā)送到隊列中。在評論调违、點贊等功能對應的controller加入生產者窟哺,部分代碼如下:

// 觸發(fā)評論事件
Event event = new Event()
        .setTopic(TOPIC_COMMENT)
        .setUserId(hostHolder.getUser().getId())    //用戶id
        .setEntityType(comment.getEntityType())     //實體類型
        .setEntityId(comment.getEntityId())         //實體id
        .setData("postId", discussPostId);          //帖子id
eventProducer.fireEvent(event);                     //發(fā)送系統(tǒng)通知

報錯及原因

啟動zookeeper、kafka后啟動項目進行測試技肩,在帖子下發(fā)表評論且轨,訪問數據庫發(fā)現(xiàn)評論事件沒有存在數據庫中(沒有加入消息隊列),且控制臺出現(xiàn)如下報錯:

kafka報錯1

kafka報錯2

點擊錯誤信息虚婿,發(fā)現(xiàn)之前“統(tǒng)一記錄日志”功能中旋奢,使用AOP織入了日志記錄功能:

aop報錯

空指針異常出現(xiàn)在attribute對象,attribute是與請求有關的對象然痊,在加入生產者-消費者模型之前至朗,AOP攔截的是service,而所有的service都是通過controller調用的剧浸。
加入消費者之后锹引,消費者會調用評論、點贊等service辛蚊,而不是controller調用了service粤蝎,因此沒有請求(request),此時attribute對象為空袋马,導致報錯。

解決方法

在記錄日志功能的AOP出現(xiàn)異常的地方秸应,判斷當前對象是否為空虑凛,如果為空(消費者調用而不是controller調用)就返回


aop報錯處理

重新啟動項目進行測試碑宴,發(fā)現(xiàn)數據庫中已經能查詢到評論、點贊桑谍、關注等操作觸發(fā)的消息事件延柠,說明使用生產者-消費者模式統(tǒng)一發(fā)送通知功能已經正確實現(xiàn),問題解決锣披。

消息事件

因此贞间,在寫代碼時要多考慮業(yè)務的邏輯,思考會不會出現(xiàn)為空的情況雹仿。

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末增热,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子胧辽,更是在濱河造成了極大的恐慌峻仇,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,331評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件邑商,死亡現(xiàn)場離奇詭異摄咆,居然都是意外死亡,警方通過查閱死者的電腦和手機人断,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,372評論 3 398
  • 文/潘曉璐 我一進店門吭从,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人恶迈,你說我怎么就攤上這事涩金。” “怎么了蝉绷?”我有些...
    開封第一講書人閱讀 167,755評論 0 360
  • 文/不壞的土叔 我叫張陵鸭廷,是天一觀的道長。 經常有香客問我熔吗,道長辆床,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,528評論 1 296
  • 正文 為了忘掉前任桅狠,我火速辦了婚禮讼载,結果婚禮上,老公的妹妹穿的比我還像新娘中跌。我一直安慰自己咨堤,他們只是感情好,可當我...
    茶點故事閱讀 68,526評論 6 397
  • 文/花漫 我一把揭開白布漩符。 她就那樣靜靜地躺著一喘,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上凸克,一...
    開封第一講書人閱讀 52,166評論 1 308
  • 那天议蟆,我揣著相機與錄音,去河邊找鬼萎战。 笑死咐容,一個胖子當著我的面吹牛,可吹牛的內容都是我干的蚂维。 我是一名探鬼主播戳粒,決...
    沈念sama閱讀 40,768評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼虫啥!你這毒婦竟也來了蔚约?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,664評論 0 276
  • 序言:老撾萬榮一對情侶失蹤孝鹊,失蹤者是張志新(化名)和其女友劉穎炊琉,沒想到半個月后,有當地人在樹林里發(fā)現(xiàn)了一具尸體又活,經...
    沈念sama閱讀 46,205評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡苔咪,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,290評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了柳骄。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片团赏。...
    茶點故事閱讀 40,435評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖耐薯,靈堂內的尸體忽然破棺而出舔清,到底是詐尸還是另有隱情,我是刑警寧澤曲初,帶...
    沈念sama閱讀 36,126評論 5 349
  • 正文 年R本政府宣布体谒,位于F島的核電站,受9級特大地震影響臼婆,放射性物質發(fā)生泄漏抒痒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,804評論 3 333
  • 文/蒙蒙 一颁褂、第九天 我趴在偏房一處隱蔽的房頂上張望故响。 院中可真熱鬧,春花似錦颁独、人聲如沸彩届。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,276評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽樟蠕。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間坯墨,已是汗流浹背寂汇。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工病往, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留捣染,地道東北人。 一個月前我還...
    沈念sama閱讀 48,818評論 3 376
  • 正文 我出身青樓停巷,卻偏偏與公主長得像耍攘,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子畔勤,可洞房花燭夜當晚...
    茶點故事閱讀 45,442評論 2 359

推薦閱讀更多精彩內容