springcloud集成logstash

需求:springcloud項目中需要對行為日志進行收集與上報无虚、分析
背景:項目開始階段日志框架使用的是spring-boot-starter-log4j2紫新,后因與logstash集成不夠友好梅惯,將日志框架替換為spring-boot-starter-logging憎蛤。spring-boot-starter-logging日志底層使用的是logback日志框架捞烟。
1吠卷、日志配置依賴如下:
  <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-logging</artifactId>
       <version>2.1.7.RELEASE</version>
 </dependency>
 <dependency>
       <groupId>net.logstash.logback</groupId>
       <artifactId>logstash-logback-encoder</artifactId>
       <version>5.2</version>
 </dependency>
2召庞、日志文件輸出位置岛心,日志文件名稱從項目配置中獲取来破,故進行配置
log:
  path: ./log
spring:
  application:
    name: xxxx
3、logstash地址配置
logstash:
  server-addr: 192.168.135.99:4560
4忘古、配置日志環(huán)境
logging:
  config: classpath:logback-busi-dev.xml
5徘禁、新建logback.xml配置文件
<?xml version="1.0" encoding="UTF-8"?>

<Configuration name="logback-dev-config" debug="true" scan="true" scanPeriod="60 seconds">
    <property name="log_pattern" value="%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%thread]%logger -%msg%n"/>
    <springProperty scope="context" name="logstash.server-addr" source="logstash.server-addr"/>
    <springProperty scope="context" name="log.path" source="log.path"/>
    <springProperty scope="context" name="log.name" source="spring.application.name"/>
    <!--控制臺-->
    <appender name="Console" class="ch.qos.logback.core.ConsoleAppender">
        <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">
            <Pattern>${log_pattern}</Pattern>
        </encoder>
    </appender>
    <!-- 輸出到Controller文件 -->
    <appender name="sysLogFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/${log.name}-sys.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/${log.name}-sys-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
            <maxHistory>60</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>10MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <Pattern>${log_pattern}</Pattern>
        </encoder>
    </appender>
    <!-- 輸出到Controller文件 -->
    <appender name="controllerLogFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/${log.name}-controller.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/${log.name}-controller-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
            <maxHistory>60</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>10MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <Pattern>${log_pattern}</Pattern>
        </encoder>
    </appender>
    <!-- 輸出到Service文件 -->
    <appender name="serviceLogFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${log.path}/${log.name}-service.log</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${log.path}/${log.name}-service-%d{yyyy-MM-dd}-%i.log</fileNamePattern>
            <maxHistory>60</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>10MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder>
            <Pattern>${log_pattern}</Pattern>
        </encoder>
    </appender>
    <appender name="stashLog" class="net.logstash.logback.appender.LogstashTcpSocketAppender">
        <destination>${logstash.server-addr}</destination>
        <encoder class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder">
            <jsonFactoryDecorator class="net.logstash.logback.decorate.CharacterEscapesJsonFactoryDecorator">
                <escape>
                    <targetCharacterCode>10</targetCharacterCode>
                    <escapeSequence>\u2028</escapeSequence>
                </escape>
            </jsonFactoryDecorator>
            <providers>
                <pattern>
                    <pattern>
                        {
                        "serviceName":"xx-businessx",
                        "timestamp":"%date{ISO8601}",
                        "message":"%msg%n"
                        }
                    </pattern>
                </pattern>
            </providers>
        </encoder>
        <keepAliveDuration>5 minutes</keepAliveDuration>
    </appender>
    <Logger name="com.xxx.business.controller" level="info" additivity="false">
        <appender-ref ref="Console"/>
        <appender-ref ref="controllerLogFile"/>
        <appender-ref ref="stashLog"/>
    </Logger>
    <Logger name="com.xxx.business.service" level="info" additivity="false">
        <appender-ref ref="Console"/>
        <appender-ref ref="serviceLogFile"/>
    </Logger>
    <root level="info">
        <appender-ref ref="Console"/>
        <appender-ref ref="sysLogFile"/>
    </root>
</Configuration>
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市髓堪,隨后出現(xiàn)的幾起案子送朱,更是在濱河造成了極大的恐慌,老刑警劉巖干旁,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驶沼,死亡現(xiàn)場離奇詭異,居然都是意外死亡争群,警方通過查閱死者的電腦和手機回怜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來换薄,“玉大人玉雾,你說我怎么就攤上這事∏嵋” “怎么了抹凳?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長伦腐。 經常有香客問我,道長失都,這世上最難降的妖魔是什么柏蘑? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮粹庞,結果婚禮上咳焚,老公的妹妹穿的比我還像新娘。我一直安慰自己庞溜,他們只是感情好革半,可當我...
    茶點故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著流码,像睡著了一般又官。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上漫试,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天六敬,我揣著相機與錄音,去河邊找鬼驾荣。 笑死外构,一個胖子當著我的面吹牛普泡,可吹牛的內容都是我干的。 我是一名探鬼主播审编,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼撼班,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了垒酬?” 一聲冷哼從身側響起砰嘁,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎伤溉,沒想到半個月后般码,有當地人在樹林里發(fā)現(xiàn)了一具尸體,經...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡乱顾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年板祝,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片走净。...
    茶點故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡券时,死狀恐怖,靈堂內的尸體忽然破棺而出伏伯,到底是詐尸還是另有隱情橘洞,我是刑警寧澤,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布说搅,位于F島的核電站炸枣,受9級特大地震影響,放射性物質發(fā)生泄漏弄唧。R本人自食惡果不足惜适肠,卻給世界環(huán)境...
    茶點故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望候引。 院中可真熱鬧侯养,春花似錦、人聲如沸澄干。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽麸俘。三九已至辩稽,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間从媚,已是汗流浹背搂誉。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人炭懊。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓并级,卻偏偏與公主長得像,于是被迫代替她去往敵國和親侮腹。 傳聞我的和親對象是個殘疾皇子嘲碧,可洞房花燭夜當晚...
    茶點故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內容