是否可以将日志发送到Logstash

时间:2016-02-11 17:30:33

标签: spring-boot logstash logback

在我的Spring Boot应用程序中,我使用Logback将日志写入/tmp/myLog.log中的文件。

在我的app.yml中:

logging:
  file: /tmp/myLog.log

我的logback.xml:

<configuration>
    <property name="LOG_FILE" value="${LOG_FILE:-${LOG_PATH:-${LOG_TEMP:-${java.io.tmpdir:-/tmp}}/}spring.log}"/>
    <property name="FILE_LOG_PATTERN" value="%d{yyyy-MM-dd HH:mm:ss.SSS} %5p ${PID:- } [%t] --- %-40.40logger{39} : %m%n"/>

    <appender name="FILE"
              class="ch.qos.logback.core.rolling.RollingFileAppender">
        <encoder>
            <pattern>${FILE_LOG_PATTERN}</pattern>
        </encoder>
        <file>${LOG_FILE}</file>
        <rollingPolicy class="ch.qos.logback.core.rolling.FixedWindowRollingPolicy">
            <fileNamePattern>${LOG_FILE}.%i</fileNamePattern>
        </rollingPolicy>
        <triggeringPolicy
                class="ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy">
            <MaxFileSize>10MB</MaxFileSize>
        </triggeringPolicy>
    </appender>

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

</configuration>

然后我告诉Logstash在我的conf文件中查看这个日志文件:

input {
  file {
    path => "/tmp/myLog.log"
    start_position => "beginning"
  }
}
output {
  elasticsearch { hosts => ["localhost:9200"] }
  stdout { codec => json }
} 

现在正在myLog.log查看此位置。有没有办法在我的Spring Boot应用程序中将日志发送到logstash而不是告诉它查看某个位置?

1 个答案:

答案 0 :(得分:3)

我成功地使用了1。你可能想尝试一下。