inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 핵심 원리 - 고급편

정리

템플릿 콜백 패턴 V5 실행 관련 질문드립니다.

해결된 질문

414

gooroom

작성한 질문수 4

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

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

[질문 내용]
여기에 질문 내용을 남겨주세요.

v5 코드를 작성했을 때, 아래와 같은 에러가 발생해서

Description:

Parameter 0 of constructor in hello.advanced.app.v5.OrderRepositoryV5 required a bean of type 'hello.advanced.trace.callback.TraceTemplate' that could not be found.


Action:

Consider defining a bean of type 'hello.advanced.trace.callback.TraceTemplate' in your configuration.


Process finished with exit code 1

TraceTemplate 클래스에 @Component 애노테이션을 추가했는데요.

@Component
@RequiredArgsConstructor
public class TraceTemplate {
	private final LogTrace trace;

	public <T> T execute(String message, TraceCallback<T> callback) {
		TraceStatus status = null;

		try {
			status = trace.begin(message);

			T result = callback.call(); //로직 호출

			trace.end(status);
			return result;
		} catch (Exception e) {
			trace.exception(status, e);
			throw e;
		}
	}
}

pdf에는 빈 등록과 관련된 부분이 없는 것 같은데, 빈 등록을 하지 않아도 실행이 되어야 하는 것인가요?

스프링 부트 3.1.7 버전 사용하고 있습니다.

감사합니다.

spring 디자인-패턴

답변 1

0

김영한

안녕하세요. gooroom님

제 생각에 생성자 코드가 잘못된 것 같아요. 다음 생성자의 두번째 매개변수가 LogTrace입니다. 그리고 생성자 내부에서 new TraceTemplate(trace)로 되어 있습니다. 이 부분을 다시 확인해주세요.

@RestController
public class OrderControllerV5 {

    private final OrderServiceV5 orderService;
    private final TraceTemplate template;

    public OrderControllerV5(OrderServiceV5 orderService, LogTrace trace) {
        this.orderService = orderService;
        this.template = new TraceTemplate(trace);
    }
}

감사합니다.

1

gooroom

말씀해주신 부분 수정해서 해결하였습니다.

감사합니다!

어드바이스 순서 디폴트 기준이 궁금합니다.

0

55

1

AspectV1 예제를 @Configuration 수동 등록으로도 가능한가요?

0

81

2

구체 클래스를 상속받아 확장한 형태도 클래스패턴/데코레이터 패턴이라고 칭하나요?

0

57

1

TraceTemplate 을 미리 빈으로 등록해서 사용할때 이렇게 설정하는게 맞는건가요?

0

54

1

Decorator 에서 추상메서드로 뺄때 질문 있습니다.

0

56

1

대상 클래스에 기본 생성자가 없을 때

0

76

1

스프링 부트 버전 4.0 aop 의존성 명칭 변경

1

361

2

final 키워드 사용 관련 질문

0

78

1

안녕하세요

0

65

1

ThradLocal 실무 사례

0

98

2

실무에서의 동시성 문제

0

63

1

로그 등 부가 기능에 대한 테스트코드

0

50

1

ProceedingJoinPoint와 MethodInvocation에 대하여

0

67

1

실무 멀티스레딩에 대한 궁금증

0

70

1

안녕하세요 질문있습니다

0

45

1

AspectV3 aop 실행 순서 문의 드립니다

0

38

1

MDC vs AOP 중에 고민중입니다.

0

76

1

순환참조

0

161

2

this를 단독으로 사용할때랑 파라미터 바인딩 할때 차이

0

78

1

빈 후처리에 등록 질문 있습니다.

0

77

1

AppConfig 설정하는 설명중에 이해가 안되는게 있습니다.

0

90

1

ThreadLocal을 지역변수로 선언하면 remove가 필요할까요?

0

118

2

@Aspect 어노테이션으로 생성된 Advisor의 Bean 저장 여부

0

69

1

ThreadLocal 사용시 부작용이 있을수 있을까요? (ThreadLocal.remove()를 잘한다고 해도..)

0

73

2