복붙노트

[SPRING] 스프링 부트의 스택 추적을 줄일 수 있습니까?

SPRING

스프링 부트의 스택 추적을 줄일 수 있습니까?

stacktrace를 예외에서 스프링 스택을 무시하도록 줄일 수 있습니까?

내 메서드가 IllegalArgumentException (의도 한대로)을 throw하고 log4j에 메시지와 스택 트레이스를 기록 할 때 Spring 스택의 전체 로그를 얻습니다. 실제로 throw 된 내 자신의 예외에 필요한 모든 것은 해당 코드의 관련 부분입니다. 실제로 놀고있다.

예를 들어 아래 스택은 org.springframework와 forward를 무시하고 8 줄로 줄여야합니다.

ERROR  2015-10-19 13:36:38,138 ID-TESTPRVR AccountDataValidation -Failed to parse Account Data!
java.lang.IllegalArgumentException: Unsupported String length: [4]
com.test.util.AccountData.<init>(AccountData.java:105)
com.test.AccountDataValidation.getAccountData(AccountDataValidation.java:61)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:606)
org.springframework.web.method.support.InvocableHandlerMethod.doInvoke(InvocableHandlerMethod.java:221)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:137)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:110)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:776)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:705)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:85)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:959)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:893)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:967)
org.springframework.web.servlet.FrameworkServlet.doPost(FrameworkServlet.java:869)
javax.servlet.http.HttpServlet.service(HttpServlet.java:648)
org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:843)
javax.servlet.http.HttpServlet.service(HttpServlet.java:729)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:291)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.springframework.boot.actuate.autoconfigure.EndpointWebMvcAutoConfiguration$ApplicationContextHeaderFilter.doFilterInternal(EndpointWebMvcAutoConfiguration.java:295)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.springframework.boot.actuate.trace.WebRequestTraceFilter.doFilterInternal(WebRequestTraceFilter.java:102)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:77)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:85)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.springframework.boot.actuate.autoconfigure.MetricsFilter.doFilterInternal(MetricsFilter.java:69)
org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)
org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:239)
org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:219)
org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:106)
org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:502)
org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:142)
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:79)
org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:88)
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:518)
org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1091)
org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:673)
org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1526)
org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1482)
java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
java.lang.Thread.run(Thread.java:745)

물론 Spring이 독자적으로 예외를 던질 때 스택 트레이스를 보여줄 것으로 기대된다.

해결법

  1. ==============================

    1.스택 추적을 필터링 할 수있는 Log4J 애드온이 있습니다. 클래스 경로의 사용자 정의 레이아웃을 사용하면 구성에서 필터링하도록 요소를 구성 할 수 있습니다.

    스택 추적을 필터링 할 수있는 Log4J 애드온이 있습니다. 클래스 경로의 사용자 정의 레이아웃을 사용하면 구성에서 필터링하도록 요소를 구성 할 수 있습니다.

    <appender name="console" class="org.apache.log4j.ConsoleAppender">
        <layout class="it.openutils.log4j.FilteredPatternLayout">
            <param name="ConversionPattern" value="%-5p  %c %F(%M:%L) %d{dd.MM.yyyy HH:mm:ss}  %m%n" />
            <param name="Filter" value="org.apache.catalina" />
            <param name="Filter" value="org.apache.tomcat" />
            <param name="Filter" value="org.apache.coyote" />
            <param name="Filter" value="org.myapp.web.filters" />
            <param name="Filter" value="com.opensymphony.module.sitemesh.filter" />
            <param name="Filter" value="sun.reflect" />
            <param name="Filter" value="javax.servlet.http" />
        </layout>
    </appender>
    
  2. ==============================

    2.Google의 Guava 라이브러리에는 Throwables API에 유용한 유틸리티 메소드가 있습니다. 귀하의 특정 경우에, 나는 getRootCause (Throwable) 또는 getCausalChain (Throwable) 잘 작동한다고 생각해.

    Google의 Guava 라이브러리에는 Throwables API에 유용한 유틸리티 메소드가 있습니다. 귀하의 특정 경우에, 나는 getRootCause (Throwable) 또는 getCausalChain (Throwable) 잘 작동한다고 생각해.

    인과 사슬 구아바는 예외의 인과 관계를 연구하는 것이 다소 쉽다. 서명이 자명 한 세 가지 유용한 메소드를 제공한다.

    Throwable getRootCause(Throwable)
    List<Throwable> getCausalChain(Throwable)
    String getStackTraceAsString(Throwable)
    
  3. from https://stackoverflow.com/questions/33220719/can-the-stacktrace-in-spring-boot-be-reduced by cc-by-sa and MIT license