inflearn logo
강의

Course

Instructor

Spring DB Part 1 - Core Principles of Data Access

Transaction Troubleshooting - Applying Transaction AOP

AopCheck Test 부분의 EnhancerBySpring 확인 법??

Resolved

66

Minho Lee

6 asked

0


질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]
17:20 부분에 보면 EnhancerBySpringCGLIB 어쩌구 이렇게 나온다는데

프록시로 쓰인다는건 AopCheck Test를 통해서 볼 수도 있고, Assertions로도 확인이 가능한데 저는 로그가 좀 다르게 나옵니다.

 

다르다기 보다는

Screenshot 2025-09-07 at 19.35.17.png

19:30:47.432 [Test worker] INFO h.jdbc.service.MemberServiceV3_3Test -- memberService class=class hello.jdbc.service.MemberServiceV3_3$$SpringCGLIB$$0

 

라고 나오는데, 혹시 EnhancerBySpring~ 이 부분은 어디서 확인이 가능할까요?

spring mvc spring-jdbc

Answer 2

1

yh

안녕하세요. Minho Lee님

스프링의 버전에 따라서 해당 키워드들이 달리 나올 수 있습니다.

화면에 보이는 SpringCGLIB라고 보이면 적용된 것으로 이해하시면 됩니다 🙂

다음 패치에 메뉴얼에도 반영해둘게요 🙂

감사합니다.

1

Minho Lee

감사합니다! 😃

1

communityai8509

안녕하세요, 인프런 AI 인턴입니다. Minho Lee님, 스프링에서 AOP 프록시 클래스를 확인하는 방법에 대해 질문 주셨군요.

스프링 애플리케이션에서 프록시가 생성될 때, 클래스 이름에 $$EnhancerBySpringCGLIB$$와 같은 패턴이 포함될 수 있습니다. 이는 CGLIB를 통해 생성된 프록시임을 나타냅니다. 때로는 $$SpringCGLIB$$라는 부분만 보일 수도 있는데, 이는 CGLIB 사용의 또 다른 결과입니다. 다소 다르게 로그가 출력되는 이유는 프록시 생성 방식이 변경되었거나 스프링 버전에 따라 로그 표현이 달라지기 때문입니다.

  1. EnhancerBySpringCGLIB 확인 방법: 스프링 AOP에서 주로 CGLIB을 사용하여 프록시를 생성할 때 EnhancerBySpringCGLIB 형식으로 표시됩니다. 이러한 표시를 보려면 설정상 프록시가 CGLIB 기반임을 확인해야 합니다.

  2. SpringCGLIB가 로그에 출력되는 이유: Spring 버전이나 프로젝트 설정에 따라, 프록시 클래스 이름이 간소화되어 SpringCGLIB으로만 표시될 수 있습니다. 이는 프록시가 생성되어 있음을 나타내며, 프록시의 기본 목적에 영향을 미치지 않습니다.

  3. 시험 환경에서 확인하는 방법: 실제로 memberService.getClass()를 호출하여 로그를 출력하면 현재 사용되는 프록시 객체의 클래스 이름을 확인할 수 있습니다. 테스트 코드에 출력문을 추가하여 생성된 프록시의 클래스를 직접 볼 수 있습니다.

이와 같이 다소 기술적인 부분으로 인한 차이가 발생할 수 있지만, 일반적으로 프록시가 생성되어야 할 상황에서 프록시가 생성되고 있는지를 확인하는 관점에서는 큰 차이가 없습니다. 더 궁금한 점이 생기시면, 이어서 질문해 주세요.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

0

Minho Lee

감사합니다! 😃

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

27

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

49

1

jdbc 학습하다 궁금해서 질문드려요

0

80

1

정상이체와 이체중 예외발생 차이

0

68

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

86

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

58

2

데이터베이스 선택 관련 질문.

0

68

2

after 메서드 사용 유무

0

56

2

데이터베이스 접근 및 DB 락

0

52

1

@SpingBootTest, @TestConfiguration

0

55

1

Read Committed 격리 수준 사용 관련 질문

0

48

1

커리큘럼 관련 질문

0

76

1

서비서 계층 스프링 프레임워크 사용

0

87

1

validation(toMember)의 위치

0

83

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

165

2

member 상수 질문

0

120

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

153

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

108

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

94

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

95

1

강의 14분쯤 Exception 질문

0

111

2

memberId 맴버변수를 String 으로 잡은 이유

0

127

2