[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.스택 추적을 필터링 할 수있는 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.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)
from https://stackoverflow.com/questions/33220719/can-the-stacktrace-in-spring-boot-be-reduced by cc-by-sa and MIT license
'SPRING' 카테고리의 다른 글
[SPRING] Spring 프레임 워크는 임베디드 컨테이너를 시작할 수 없다. (0) | 2019.05.18 |
---|---|
[SPRING] Spring XML 메타 데이터 설정에서 빈에 대한 ServletContext 속성을 설정하는 방법 (0) | 2019.05.18 |
[SPRING] Apache Camel 및 웹 서비스 (0) | 2019.05.18 |
[SPRING] @AspectJ Spring 3.1을 기반으로 한 AOP (0) | 2019.05.18 |
[SPRING] 프로퍼티 파일의 경로를 얻고이를 런타임에 Bean에 전달하는 방법 (0) | 2019.05.18 |