logstash-json日志

springboot和logstash整合,可以直接将日志输入到logstash的服务端上,也可以将日志以json格式输出到制定位置的文件,由logstash自己去收集

下面先介绍springboot输出标准logstash的本地json格式文件

logback输出标准logstash的本地json格式文件

1. 需要用到的依赖包pom.xml

<dependency>
    <groupId>net.logstash.logback</groupId>
    <artifactId>logstash-logback-encoder</artifactId>
    <version>5.1</version>
</dependency>

2. springboot配置application.yml

spring:
  application:
    name: service-demo           
management:
  endpoints:
    web:
      exposure:
        include: "*"
logging:
  root: /opt/service/log
  config: classpath:service-logback.xml
  file: /opt/service/log/${spring.application.name}/${spring.application.name}.info.log

3. logback配置文件logback.xml

 <!-- 为logstash输出的JSON格式的Appender -->
   <appender name="logstash" class="ch.qos.logback.core.rolling.RollingFileAppender">
           <file>${LOG_PATH}/${APP_NAME}/${APP_NAME}.info-logstash.json</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${LOG_PATH}/${APP_NAME}/${APP_NAME}.%d{yyyy-MM-dd}.info-logstash.%i.json</fileNamePattern>
            <maxHistory>30</maxHistory>
            <timeBasedFileNamingAndTriggeringPolicy class="ch.qos.logback.core.rolling.SizeAndTimeBasedFNATP">
                <maxFileSize>512MB</maxFileSize>
            </timeBasedFileNamingAndTriggeringPolicy>
        </rollingPolicy>
        <encoder class="net.logstash.logback.encoder.LoggingEventCompositeJsonEncoder" charset="UTF-8">
          <providers>
            <timestamp>
                <timeZone>UTC</timeZone>
            </timestamp>
            <pattern>
                <pattern>
                    {
                        "app": "${APP_NAME}",
                        "level": "%level",
                        "pid": "${PID:-}",
                        "thread": "%thread",
                        "class": "%logger{40}",
                        "message": "%message",
                        "stack_trace": "%exception{10}"
                    }
                </pattern>
            </pattern>
          </providers>
        </encoder>
  </appender>


    <root level="INFO">
        <appender-ref ref="logstash" />
    </root>

4. 输出

{"@timestamp":"2019-04-11T07:07:39.334+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"com.example.demo.DemoApplication","message":"Starting DemoApplication on user-PC with PID 8699 (/home/user/Documents/code-source/demo/target/classes started by user in /home/user/Documents/code-source/demo)","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:39.338+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"com.example.demo.DemoApplication","message":"No active profile set, falling back to default profiles: default","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:39.357+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.b.d.e.DevToolsPropertyDefaultsPostProcessor","message":"Devtools property defaults active! Set 'spring.devtools.add-properties' to 'false' to disable","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:39.358+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.b.d.e.DevToolsPropertyDefaultsPostProcessor","message":"For additional web related logging consider setting the 'logging.level.web' property to 'DEBUG'","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.046+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.b.w.embedded.tomcat.TomcatWebServer","message":"Tomcat initialized with port(s): 8080 (http)","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.063+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"org.apache.catalina.core.StandardService","message":"Starting service [Tomcat]","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.064+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"org.apache.catalina.core.StandardEngine","message":"Starting Servlet engine: [Apache Tomcat/9.0.17]","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.104+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.a.c.c.C.[Tomcat].[localhost].[/]","message":"Initializing Spring embedded WebApplicationContext","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.104+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.web.context.ContextLoader","message":"Root WebApplicationContext: initialization completed in 746 ms","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.371+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.s.concurrent.ThreadPoolTaskExecutor","message":"Initializing ExecutorService 'applicationTaskExecutor'","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.528+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.b.d.a.OptionalLiveReloadServer","message":"LiveReload server is running on port 35729","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.534+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.b.a.e.web.EndpointLinksResolver","message":"Exposing 16 endpoint(s) beneath base path '/actuator'","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.594+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"o.s.b.w.embedded.tomcat.TomcatWebServer","message":"Tomcat started on port(s): 8080 (http) with context path ''","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.599+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"com.example.demo.DemoApplication","message":"Started DemoApplication in 1.58 seconds (JVM running for 1.992)","stack_trace":""}
{"@timestamp":"2019-04-11T07:07:40.610+00:00","app":"service-demo","level":"INFO","pid":"8699","thread":"restartedMain","class":"com.example.demo.DemoApplication","message":"开始记录日志。。。","stack_trace":""}

Last updated