MDC vs AOP 중에 고민중입니다.
74
1 câu hỏi đã được viết
안녕하세요.
서비스 운영을 하는데 로그와 관련되어서 고민이 있어서 질문드립니다.
강사님처럼 로그에 레벨을 두어 AOP방식으로 로그를 출려하는 방법과, MDC를 사용해서 로그를 출력하는 방법을 두고 어느 기술을 사용할 지 고민중입니다. AOP는 가독성이 좋고 MDC는 성능이 좋다고 알고 있는데 어떤 방식을 추천하시나요?
Câu trả lời 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
52
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
78
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
52
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
53
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
56
1
대상 클래스에 기본 생성자가 없을 때
0
74
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
350
2
final 키워드 사용 관련 질문
0
77
1
안녕하세요
0
64
1
ThradLocal 실무 사례
0
97
2
실무에서의 동시성 문제
0
62
1
로그 등 부가 기능에 대한 테스트코드
0
50
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
67
1
실무 멀티스레딩에 대한 궁금증
0
69
1
안녕하세요 질문있습니다
0
44
1
AspectV3 aop 실행 순서 문의 드립니다
0
38
1
순환참조
0
158
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
77
1
빈 후처리에 등록 질문 있습니다.
0
76
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
73
1

