MDC vs AOP 중에 고민중입니다.
74
1 asked
안녕하세요.
서비스 운영을 하는데 로그와 관련되어서 고민이 있어서 질문드립니다.
강사님처럼 로그에 레벨을 두어 AOP방식으로 로그를 출려하는 방법과, MDC를 사용해서 로그를 출력하는 방법을 두고 어느 기술을 사용할 지 고민중입니다. AOP는 가독성이 좋고 MDC는 성능이 좋다고 알고 있는데 어떤 방식을 추천하시나요?
Answer 1
0
안녕하세요, 인프런 AI 인턴입니다. InuappcenterServer님.
로그 관리를 위한 AOP와 MDC 방식 중 어떤 것을 선택할지 고민하고 계시는군요. 각 방식의 장단점을 설명해드리며 참고할 만한 자료를 함께 소개해 드리겠습니다.
AOP (Aspect Oriented Programming)
- 장점:
- 가독성: 코드의 핵심 로직과 부가적인 로직(로그 관리 등)을 분리하여 코드의 가독성을 높일 수 있습니다.
- 유지보수 용이: 로그가 필요한 여러 곳에서 일관성 있게 적용할 수 있으며, 한 곳에서 로직을 수정하면 모든 적용 지점에 반영됩니다.
- 가독성: 코드의 핵심 로직과 부가적인 로직(로그 관리 등)을 분리하여 코드의 가독성을 높일 수 있습니다.
- 단점:
- 성능: 로그 처리를 위해 추가적인 프록시 객체가 생성되므로, 약간의 성능 오버헤드가 발생할 수 있습니다.
- 성능: 로그 처리를 위해 추가적인 프록시 객체가 생성되므로, 약간의 성능 오버헤드가 발생할 수 있습니다.
MDC (Mapped Diagnostic Context)
- 장점:
- 성능: AOP와 비교하여 성능에 거의 영향을 주지 않는 방식입니다. 특히, 요청에 대한 추가 정보를 로깅할 때 유용합니다.
- 컨텍스트 기반 로깅: 로그마다 고유한 컨텍스트 정보를 함께 기록할 수 있어 추적이 용이합니다.
- 성능: AOP와 비교하여 성능에 거의 영향을 주지 않는 방식입니다. 특히, 요청에 대한 추가 정보를 로깅할 때 유용합니다.
- 단점:
- 부가적인 코드 추가: 로그를 출력하는 곳마다 MDC 설정과 해제가 필요하여 관리가 번거로울 수 있습니다.
- 부가적인 코드 추가: 로그를 출력하는 곳마다 MDC 설정과 해제가 필요하여 관리가 번거로울 수 있습니다.
추천
- AOP는 여러분의 애플리케이션 전반에 일관된 로깅 정책을 적용하기 위해 유용합니다. 특히, 공통적인 로깅이 필요한 경우 이 접근법이 적합합니다.
- MDC는 요청별 상태나 맥락을 로깅하고자 할 때 매우 유용합니다. 예를 들어, 특정 요청의 전체 흐름을 추적하고 싶다면 MDC를 통해 각 로그 메시지에 관련 정보를 덧붙이는 것이 좋습니다.
결국, 두 기술은 상호 보완적인 것이며, 특정한 요구사항에 따라 함께 사용될 수도 있습니다. 가독성을 우선시한다면 AOP를, 성능과 요청의 맥락을 강조하고 싶다면 MDC를 사용하는 것이 좋습니다.
추천 자료
- 코드 가독성을 높이는 AOP 로그 관리
- 유연한 로깅을 위한 MDC 활용법
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
어드바이스 순서 디폴트 기준이 궁금합니다.
0
51
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
78
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
52
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
53
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
55
1
대상 클래스에 기본 생성자가 없을 때
0
74
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
346
2
final 키워드 사용 관련 질문
0
75
1
안녕하세요
0
64
1
ThradLocal 실무 사례
0
97
2
실무에서의 동시성 문제
0
62
1
로그 등 부가 기능에 대한 테스트코드
0
50
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
67
1
실무 멀티스레딩에 대한 궁금증
0
69
1
안녕하세요 질문있습니다
0
43
1
AspectV3 aop 실행 순서 문의 드립니다
0
37
1
순환참조
0
158
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
77
1
빈 후처리에 등록 질문 있습니다.
0
75
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
88
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
117
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
67
1
ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)
0
73
2
빈으로 주입하지 않고 new로 객체 생성해도 되는데, 왜 ThreadLocal을 사용하나요?
0
72
1

