JpaRepository 로그 출력이 안됩니다
463
4 asked
안녕하세요
강의를 우선 한번 다 듣고 예제를 직접 만들어보면 학습을 하고있는데 다음과같은 문제가 생겼습니다
간단한 controller - service - repository 구조의 api를 만들었는데
controller - service 까지는 로그가 잘 찍히는데 레포지토리에서 로그가 찍히지 않았습니다(소스가 코틀린이 죄송합니다..)
@Aspect
@Component
class LogTraceAspect(private val logTrace: LogTrace) {
// @Around("execution(* com.example.logger.app..*(..)) || target(com.example.logger.app.repository.MemberRepository)")
// @Around("execution(* com.example.logger.app..*.*(..))")
@Around("within(com.example.logger.app..*)")
@Throws(Throwable::class)
fun execute(joinPoint: ProceedingJoinPoint): Any {
var status: TraceStatus? = null
return try {
val message = joinPoint.signature.toShortString()
status = logTrace.begin(message)
val result = joinPoint.proceed()
logTrace.end(status)
result
} catch (e: Exception) {
logTrace.exception(status!!, e)
throw e
}
}
}
package com.example.logger.app.repository
import com.example.logger.app.entity.Member
import com.example.logger.app.entity.Team
import com.example.logger.app.redis.TeamDtoPoint
import org.springframework.data.jpa.repository.JpaRepository
import org.springframework.data.repository.CrudRepository
interface TeamRepository : JpaRepository<Team, Long>
interface MemberRepository : JpaRepository<Member, Long>
interface TeamRedisRepository : CrudRepository<TeamDtoPoint, String>
첫번째로 주석처리된 포인트컷처럼 target으로 직접 repository를 지정해주면 로그가 찍히는데 그렇지 않을 경우에는 로그가 찍히지 않았습니다. (TeamRepository, MemberRepository 둘다)
그런데 이상한건 같은 패키지에 있는 redis용 레포지토리인 TeamRedisRepository는 로그가 찍힙니다..
제가 어떤 부분을 놓치고 있는 걸까요??
전체 소스코드는 https://github.com/rkdals213/logger 여기있습니다
Answer 1
0
일단 원인을 찾았습니다.
TeamRepository와 MemberRepository는 JpaRepository를 상속받습니다. 그리고 정의된 함수들은 JpaRepository에 선언되어 있죠
그렇기 때문에 포인트컷으로 TeamRepository와 MemberRepository를 범위에 포함시키더라도 실제로 선언된 함수가 없고 사용한 함수는 JpaRepository에 선언되어 있기 때문에 로그가 찍히지 않던것입니다
또한 TeamRepository나 MemberRepository에 함수를 정의하여 호출하게 된다면 이는 로그에 찍히게 됩니다.
JpaRepository에 있는 함수 로그를 찍기위해선 포인트컷으로
execution(* org.springframework.data.jpa.repository.JpaRepository.*(..))
를 추가해주면 됩니다
그런데 CrudRepository를 상속받는 TeamRedisRepository 함수는 왜 로그에 찍혔을까요??
SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception
0
30
2
어드바이스 순서 디폴트 기준이 궁금합니다.
0
61
1
AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?
0
91
2
구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?
0
64
1
TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?
0
58
1
Decorator 에서 추상메서드로 뺄때 질문 있습니다.
0
58
1
대상 클래스에 기본 생성자가 없을 때
0
79
1
스프링 부트 버전 4.0 aop 의존성 명칭 변경
1
391
2
final 키워드 사용 관련 질문
0
81
1
안녕하세요
0
71
1
ThradLocal 실무 사례
0
101
2
실무에서의 동시성 문제
0
69
1
로그 등 부가 기능에 대한 테스트코드
0
55
1
ProceedingJoinPoint와 MethodInvocation에 대하여
0
71
1
실무 멀티스레딩에 대한 궁금증
0
74
1
안녕하세요 질문있습니다
0
46
1
AspectV3 aop 실행 순서 문의 드립니다
0
41
1
MDC vs AOP 중에 고민중입니다.
0
80
1
순환참조
0
164
2
this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이
0
81
1
빈 후처리에 등록 질문 있습니다.
0
83
1
AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.
0
94
1
ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?
0
119
2
@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부
0
73
1

