微服務基于請求的日志跟蹤2

<<微服務基于請求的日志跟蹤>>上設計了基于請求的微服務日志處理方法, 但是發(fā)現(xiàn)在log4j處于異步的情況下會失效, 原因是RequestId無法從原線程傳輸?shù)酱蛴∪罩镜木€程, 異步情況下(AsyncLoggerConfig), 日志先被enqueue到一個隊列,然后若干線程去消費這個隊列, 因為跨了線程,所以不能通過線程變量傳遞過去.
查看了相關(guān)代碼, 發(fā)現(xiàn)log4j首先將message生成了LogEvent, 然后將LogEvent丟入隊列, 而LogEvent提供了一個ContenxtData的Map來攜帶屬性變量, 所以我們可以將RequestId放到這里面?zhèn)鬟f過去.

具體的代碼是:

import org.apache.logging.log4j.Level;
import org.apache.logging.log4j.Marker;
import org.apache.logging.log4j.core.LogEvent;
import org.apache.logging.log4j.core.config.Property;
import org.apache.logging.log4j.core.impl.ContextDataFactory;
import org.apache.logging.log4j.core.impl.MutableLogEvent;
import org.apache.logging.log4j.core.impl.ReusableLogEventFactory;
import org.apache.logging.log4j.message.Message;
import org.apache.logging.log4j.util.StringMap;

import java.util.List;
public class RequestIdLogEventFactory extends ReusableLogEventFactory {
    @Override
    public LogEvent createEvent(String loggerName, Marker marker, String fqcn, Level level, Message message, List<Property> properties, Throwable t) {
        LogEvent event = super.createEvent(loggerName, marker, fqcn, level, message, properties, t);
        if (event instanceof MutableLogEvent) {
            StringMap contextData = ContextDataFactory.createContextData();
            contextData.putAll(event.getContextData());
            contextData.putValue("RequestId", LogRequestIdPlugin.getRequestId());
            ((MutableLogEvent) event).setContextData(contextData);
        }
        return event;
    }
    public static String getRequestId(LogEvent event) {
        return event.getContextData().getValue("RequestId");
    }
}

同時修改LogRequestIdPlugin:

    @Override
    public void format(LogEvent event, StringBuilder toAppendTo) {
       toAppendTo.append(RequestIdLogEventFactory.getRequestId(event));
    }

設置應用的啟動參數(shù), 指定logEvent工廠, 增加:

-DLog4jLogEventFactory=your_package.RequestIdLogEventFactory

這樣即使在異步輸出的時候,也能傳遞RequestId到日志文件了.

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市赏廓,隨后出現(xiàn)的幾起案子檐盟,更是在濱河造成了極大的恐慌回梧,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件音瓷,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機传轰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谷婆,“玉大人慨蛙,你說我怎么就攤上這事〖涂妫” “怎么了期贫?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長异袄。 經(jīng)常有香客問我通砍,道長,這世上最難降的妖魔是什么烤蜕? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任封孙,我火速辦了婚禮,結(jié)果婚禮上讽营,老公的妹妹穿的比我還像新娘虎忌。我一直安慰自己,他們只是感情好橱鹏,可當我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布膜蠢。 她就那樣靜靜地躺著堪藐,像睡著了一般。 火紅的嫁衣襯著肌膚如雪挑围。 梳的紋絲不亂的頭發(fā)上礁竞,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音贪惹,去河邊找鬼苏章。 笑死,一個胖子當著我的面吹牛奏瞬,可吹牛的內(nèi)容都是我干的枫绅。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼硼端,長吁一口氣:“原來是場噩夢啊……” “哼并淋!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起珍昨,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤县耽,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后镣典,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體兔毙,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年兄春,在試婚紗的時候發(fā)現(xiàn)自己被綠了澎剥。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡赶舆,死狀恐怖哑姚,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情芜茵,我是刑警寧澤叙量,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站九串,受9級特大地震影響绞佩,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蒸辆,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一征炼、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧躬贡,春花似錦谆奥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽宰译。三九已至,卻和暖如春魄懂,著一層夾襖步出監(jiān)牢的瞬間沿侈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工市栗, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留缀拭,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓填帽,卻偏偏與公主長得像蛛淋,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子篡腌,可洞房花燭夜當晚...
    茶點故事閱讀 42,828評論 2 345

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