Spring Boot 시작 중에 발생한 예외를 FailureAnalyzer로 잡는다.
10332 단어 spring-bootKotlinspring
경위
여기를 참조
htps : // 코 m / 샤 s s ぇ th / ms / 476436 b7c81 81 d b2
아무튼 지정의 포트가 벌써 사용되고 있었을 경우의 Exception은
원래 Spring Boot에서 사용할 수 있습니다.
덮어 쓸 수 있고 추가 할 수 있다는 이야기
환경
Spring Boot 2.2.2.RELEASE - 2.2.4.RELEASE
Kotlin 1.3.61
Gradle
환경은 다음 기사의 만다
Spring Boot 측이 준비해 주는 FailureAnalyzer
예외를 잡으려면 AbstractFailureAnalyzer
을 상속해야합니다.
검색을 통해 나온 수업이
data:image/s3,"s3://crabby-images/ea84a/ea84ae5474e799a76b473d0c7bb6dbcbb7a67b2c" alt=""
총 17개
또한 각 클래스를 상속 할 수 있기 때문에 더있을 수 있습니다.
포트가 이미 사용되었을 때 호출되는 Exception은 PortInUseException
그것을 잡는 것이 PortInUseFailureAnalyzer
PortInUseFailureAnalyzer.javaclass PortInUseFailureAnalyzer extends AbstractFailureAnalyzer<PortInUseException> {
@Override
protected FailureAnalysis analyze(Throwable rootFailure, PortInUseException cause) {
return new FailureAnalysis("Web server failed to start. Port " + cause.getPort() + " was already in use.",
"Identify and stop the process that's listening on port " + cause.getPort() + " or configure this "
+ "application to listen on another port.",
cause);
}
}
안의 클래스는 이런 느낌
적당히 뒤에서 포트 8080 사용으로
data:image/s3,"s3://crabby-images/c7e8c/c7e8c7b749b848d457e3d7177656afd05f8fc2b2" alt=""
Boot Run으로 앱을 시작하면 ...
data:image/s3,"s3://crabby-images/10861/10861d11a79ea54f78a8b21f0c1f7157f4bce307" alt=""
이런 느낌
FailureAnalyzer에 있는 Description과 Action이 로그에 기록되어 있다고 합니다.
Spring Boot에서 제공하는 FailureAnalyzer를 자체로 다시 작성
정직 추천은 할 수 없다
MyPortInUseFailureAnalyzer.ktclass MyPortInUseExceptionFailureAnalyzer : AbstractFailureAnalyzer<PortInUseException>() {
override fun analyze(rootFailure: Throwable, cause: PortInUseException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Port already in use!!!",
cause
)
}
}
AbstractFailureAnalyzer<PortInUseException>
를 상속받은 클래스를 만드십시오.
resources/META-INF/
폴더 아래에 spring.factories
파일을 만듭니다.
resources/META-INF/spring.factoriesorg.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer
그 내용은 이런 느낌
이제 등록 OK
또한 적당히 포트 8080을 뒤에서 사용해 두고 Boot Run하면
data:image/s3,"s3://crabby-images/0a840/0a840de73015668ff32301686dd398e39f4dc1c7" alt=""
덮어쓸 수있었습니다.
추천하지 않는다는 것도 예외시에 출력되는 정보를 변경할 수 있기 때문에 실제로 예외가 발생했을 때 무엇이 있었는지 모르기 때문에
출력되는 내용은 바꾸지 않고 처리를 끼우거나 하는 것이 좋은 것일까···?
FailureAnalyzer의 커스터마이즈의 용도로서는 이하가 실용적일지도 모른다
독자적인 Exception을 FailureAnalyzer로 잡는다
SampleFailureAnalyzer.kt/**
* 独自の例外
*/
class SampleException(message: String?) : RuntimeException(message)
/**
* カスタムFailureAnalyzerのサンプル
* アプリ起動中に発生したSampleExceptionをつかむ
*/
class SampleFailureAnalyzer : AbstractFailureAnalyzer<SampleException>() {
override fun analyze(rootFailure: Throwable, cause: SampleException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Sample Exception!",
cause
)
}
}
이런 식으로 독자적인 예외를 만들어 두고, 그것을 잡는 FailureAnalyzer를 작성해 둔다
spring.factories
이런 느낌
resources/META-INF/spring.factoriesorg.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer ,\
com.example.spring.boot.web.failure.analyzer.SampleFailureAnalyzer
여러 FailureAnalyzer를 등록할 수도 있습니다.
그래서 만든 SampleFailureAnalyzer가 제대로 잡을 수 있는지 확인하고 싶습니다.
다음을 적당히 만들어 둔다
SampleFailureAnalyzer.kt/**
* アプリ起動中に読み込まれるサンプルComponent
*/
@Component
class SampleComponent {
fun run() {
throw SampleException("exception!")
}
}
/**
* リフレッシュ時にイベント発火するListenerクラス
*/
@Component
class SampleApplicationListener : ApplicationListener<ContextRefreshedEvent?> {
@Autowired
private val sampleComponent: SampleComponent? = null
/**
* リフレッシュ時にSampleComponentのrunを実行する(例外を発生させる)
*/
override fun onApplicationEvent(event: ContextRefreshedEvent) {
sampleComponent!!.run()
}
}
Spring Boot 2.2.2.RELEASE - 2.2.4.RELEASE
Kotlin 1.3.61
Gradle
환경은 다음 기사의 만다
Spring Boot 측이 준비해 주는 FailureAnalyzer
예외를 잡으려면 AbstractFailureAnalyzer
을 상속해야합니다.
검색을 통해 나온 수업이
data:image/s3,"s3://crabby-images/ea84a/ea84ae5474e799a76b473d0c7bb6dbcbb7a67b2c" alt=""
총 17개
또한 각 클래스를 상속 할 수 있기 때문에 더있을 수 있습니다.
포트가 이미 사용되었을 때 호출되는 Exception은 PortInUseException
그것을 잡는 것이 PortInUseFailureAnalyzer
PortInUseFailureAnalyzer.javaclass PortInUseFailureAnalyzer extends AbstractFailureAnalyzer<PortInUseException> {
@Override
protected FailureAnalysis analyze(Throwable rootFailure, PortInUseException cause) {
return new FailureAnalysis("Web server failed to start. Port " + cause.getPort() + " was already in use.",
"Identify and stop the process that's listening on port " + cause.getPort() + " or configure this "
+ "application to listen on another port.",
cause);
}
}
안의 클래스는 이런 느낌
적당히 뒤에서 포트 8080 사용으로
data:image/s3,"s3://crabby-images/c7e8c/c7e8c7b749b848d457e3d7177656afd05f8fc2b2" alt=""
Boot Run으로 앱을 시작하면 ...
data:image/s3,"s3://crabby-images/10861/10861d11a79ea54f78a8b21f0c1f7157f4bce307" alt=""
이런 느낌
FailureAnalyzer에 있는 Description과 Action이 로그에 기록되어 있다고 합니다.
Spring Boot에서 제공하는 FailureAnalyzer를 자체로 다시 작성
정직 추천은 할 수 없다
MyPortInUseFailureAnalyzer.ktclass MyPortInUseExceptionFailureAnalyzer : AbstractFailureAnalyzer<PortInUseException>() {
override fun analyze(rootFailure: Throwable, cause: PortInUseException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Port already in use!!!",
cause
)
}
}
AbstractFailureAnalyzer<PortInUseException>
를 상속받은 클래스를 만드십시오.
resources/META-INF/
폴더 아래에 spring.factories
파일을 만듭니다.
resources/META-INF/spring.factoriesorg.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer
그 내용은 이런 느낌
이제 등록 OK
또한 적당히 포트 8080을 뒤에서 사용해 두고 Boot Run하면
data:image/s3,"s3://crabby-images/0a840/0a840de73015668ff32301686dd398e39f4dc1c7" alt=""
덮어쓸 수있었습니다.
추천하지 않는다는 것도 예외시에 출력되는 정보를 변경할 수 있기 때문에 실제로 예외가 발생했을 때 무엇이 있었는지 모르기 때문에
출력되는 내용은 바꾸지 않고 처리를 끼우거나 하는 것이 좋은 것일까···?
FailureAnalyzer의 커스터마이즈의 용도로서는 이하가 실용적일지도 모른다
독자적인 Exception을 FailureAnalyzer로 잡는다
SampleFailureAnalyzer.kt/**
* 独自の例外
*/
class SampleException(message: String?) : RuntimeException(message)
/**
* カスタムFailureAnalyzerのサンプル
* アプリ起動中に発生したSampleExceptionをつかむ
*/
class SampleFailureAnalyzer : AbstractFailureAnalyzer<SampleException>() {
override fun analyze(rootFailure: Throwable, cause: SampleException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Sample Exception!",
cause
)
}
}
이런 식으로 독자적인 예외를 만들어 두고, 그것을 잡는 FailureAnalyzer를 작성해 둔다
spring.factories
이런 느낌
resources/META-INF/spring.factoriesorg.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer ,\
com.example.spring.boot.web.failure.analyzer.SampleFailureAnalyzer
여러 FailureAnalyzer를 등록할 수도 있습니다.
그래서 만든 SampleFailureAnalyzer가 제대로 잡을 수 있는지 확인하고 싶습니다.
다음을 적당히 만들어 둔다
SampleFailureAnalyzer.kt/**
* アプリ起動中に読み込まれるサンプルComponent
*/
@Component
class SampleComponent {
fun run() {
throw SampleException("exception!")
}
}
/**
* リフレッシュ時にイベント発火するListenerクラス
*/
@Component
class SampleApplicationListener : ApplicationListener<ContextRefreshedEvent?> {
@Autowired
private val sampleComponent: SampleComponent? = null
/**
* リフレッシュ時にSampleComponentのrunを実行する(例外を発生させる)
*/
override fun onApplicationEvent(event: ContextRefreshedEvent) {
sampleComponent!!.run()
}
}
class PortInUseFailureAnalyzer extends AbstractFailureAnalyzer<PortInUseException> {
@Override
protected FailureAnalysis analyze(Throwable rootFailure, PortInUseException cause) {
return new FailureAnalysis("Web server failed to start. Port " + cause.getPort() + " was already in use.",
"Identify and stop the process that's listening on port " + cause.getPort() + " or configure this "
+ "application to listen on another port.",
cause);
}
}
정직 추천은 할 수 없다
MyPortInUseFailureAnalyzer.kt
class MyPortInUseExceptionFailureAnalyzer : AbstractFailureAnalyzer<PortInUseException>() {
override fun analyze(rootFailure: Throwable, cause: PortInUseException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Port already in use!!!",
cause
)
}
}
AbstractFailureAnalyzer<PortInUseException>
를 상속받은 클래스를 만드십시오.resources/META-INF/
폴더 아래에 spring.factories
파일을 만듭니다.resources/META-INF/spring.factories
org.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer
그 내용은 이런 느낌
이제 등록 OK
또한 적당히 포트 8080을 뒤에서 사용해 두고 Boot Run하면
data:image/s3,"s3://crabby-images/0a840/0a840de73015668ff32301686dd398e39f4dc1c7" alt=""
덮어쓸 수있었습니다.
추천하지 않는다는 것도 예외시에 출력되는 정보를 변경할 수 있기 때문에 실제로 예외가 발생했을 때 무엇이 있었는지 모르기 때문에
출력되는 내용은 바꾸지 않고 처리를 끼우거나 하는 것이 좋은 것일까···?
FailureAnalyzer의 커스터마이즈의 용도로서는 이하가 실용적일지도 모른다
독자적인 Exception을 FailureAnalyzer로 잡는다
SampleFailureAnalyzer.kt/**
* 独自の例外
*/
class SampleException(message: String?) : RuntimeException(message)
/**
* カスタムFailureAnalyzerのサンプル
* アプリ起動中に発生したSampleExceptionをつかむ
*/
class SampleFailureAnalyzer : AbstractFailureAnalyzer<SampleException>() {
override fun analyze(rootFailure: Throwable, cause: SampleException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Sample Exception!",
cause
)
}
}
이런 식으로 독자적인 예외를 만들어 두고, 그것을 잡는 FailureAnalyzer를 작성해 둔다
spring.factories
이런 느낌
resources/META-INF/spring.factoriesorg.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer ,\
com.example.spring.boot.web.failure.analyzer.SampleFailureAnalyzer
여러 FailureAnalyzer를 등록할 수도 있습니다.
그래서 만든 SampleFailureAnalyzer가 제대로 잡을 수 있는지 확인하고 싶습니다.
다음을 적당히 만들어 둔다
SampleFailureAnalyzer.kt/**
* アプリ起動中に読み込まれるサンプルComponent
*/
@Component
class SampleComponent {
fun run() {
throw SampleException("exception!")
}
}
/**
* リフレッシュ時にイベント発火するListenerクラス
*/
@Component
class SampleApplicationListener : ApplicationListener<ContextRefreshedEvent?> {
@Autowired
private val sampleComponent: SampleComponent? = null
/**
* リフレッシュ時にSampleComponentのrunを実行する(例外を発生させる)
*/
override fun onApplicationEvent(event: ContextRefreshedEvent) {
sampleComponent!!.run()
}
}
/**
* 独自の例外
*/
class SampleException(message: String?) : RuntimeException(message)
/**
* カスタムFailureAnalyzerのサンプル
* アプリ起動中に発生したSampleExceptionをつかむ
*/
class SampleFailureAnalyzer : AbstractFailureAnalyzer<SampleException>() {
override fun analyze(rootFailure: Throwable, cause: SampleException): FailureAnalysis {
return FailureAnalysis(
cause.message,
"Sample Exception!",
cause
)
}
}
org.springframework.boot.diagnostics.FailureAnalyzer =\
com.example.spring.boot.web.failure.analyzer.MyPortInUseFailureAnalyzer ,\
com.example.spring.boot.web.failure.analyzer.SampleFailureAnalyzer
/**
* アプリ起動中に読み込まれるサンプルComponent
*/
@Component
class SampleComponent {
fun run() {
throw SampleException("exception!")
}
}
/**
* リフレッシュ時にイベント発火するListenerクラス
*/
@Component
class SampleApplicationListener : ApplicationListener<ContextRefreshedEvent?> {
@Autowired
private val sampleComponent: SampleComponent? = null
/**
* リフレッシュ時にSampleComponentのrunを実行する(例外を発生させる)
*/
override fun onApplicationEvent(event: ContextRefreshedEvent) {
sampleComponent!!.run()
}
}
느낌
이제 앱을 시작할 때 오류가 발생합니다.
실행해 보면
data:image/s3,"s3://crabby-images/e41a3/e41a30fa6a4c75ec21613dafd5aae5a34fb81697" alt=""
제대로 메시지를 낼 수 있습니다!
spring.factories를 등록하지 않은 경우 스택 추적이 표시됩니다.
data:image/s3,"s3://crabby-images/6e50f/6e50f1f6832efde570d62c4b2c81b8fc1b9ffee1" alt=""
요약
스택 트레이스 쪽이 알기 쉬운 경우도 있고, 일괄적으로 모든 Exception를 잡는 편이 좋다고는 말할 수 없는 것일까···?
하지만 파악할 수 있는 Exception인지, 발생 가능한 예외인지의 판단은 할 수 있고, 아무튼 편리하다고는 생각한다
Reference
이 문제에 관하여(Spring Boot 시작 중에 발생한 예외를 FailureAnalyzer로 잡는다.), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/ShassBeleth/items/113e1a2b5703d86d21b5텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)