Spring/개념정리

AOP 용어 정리

Itchild 2024. 7. 4. 11:40
728x90
반응형

 

 

1. Advice (어드바이스)

 

횡단 관심 == 공통 로직 이라는 뜻

우리가 만드려는 것은 로그 횡단 관심

모든 Advice (어드바이스)는 동작시점을 설정할 수 있다.(정할 수 있다. )

=> 비즈니스 메서드를 기준으로 전/후/언제 할지 ...등등

 

보통 이미 조합이 완료된 서비스를 가져오는 것을 선호 !

컨트롤러에서 로그 Advice (어드바이스) 를 안찍는다.

 

어드바이스라는 횡단 관심사를 만든다.

Advice 클래스를 생성한다.

 

BoardServiceImpl 에 Advice(어드바이스)를 넣으려면 NEW(컴파일 ,객체화) 해야 한다.

어드바이스 류를 NEW 하기

 

 

 

2. PointCut (포인트 컷) : CRUD

 

핵심관심, 핵심로직 , 비즈니스 메서드, CRUD << 같은 단어들

 

<aop:config> 내부에 작성해야 하며

expression 내부에는 메서드 시그니처 순서대로 !

output function name ( *Impl 류에 둘다 결합할 예정) input

----> input 은 *(..) 왜 이렇게 표현할까 ? 인자가 여러개 올 수 있기 때문 !

 

pointcut 의 표현식은 메소드의 실행이라는 의미인 execution으로 시작하고,

메소드의 시그니처를 비교하는 방법을 주로 이용합니다.

 

3) Aspect (애스펙트)(Advisor)

 

결합할땐 동작시점을 결정 할 수 있다.

 

- xml 설명

1. 나 aop 설정 할거야 핵심로직으로는 (* com.spring.biz..*Impl.*(..)) 준비 했어

2. 포인트컷 설정할거야 핵심로직 설정할거야 *Impl 에 대해 설정 얘를 앞으로 aPointcut 이라 할거야

3. 얘가 호출되면 결합시켜줘 이 로그 어드바이스를

4. 언제 결합 시켜줘 ? 누구 언제 ? 에이포인트 컷 수행 후에

5. 프린트 로그 메서드 호출해줘 !

 

항상 후(after)에 호출 되는 모습 확인 가능하다.

 

관심을 분리 했기때문에 자바 파일만 보일 수 있는 장점이 있다.

근데 설정을 알려면 xml 설정을 들여다 봐야 한다는 단점이 있다.

xml을 들여다 보지 않으면 모를 수도 있다.

 

전에 나오게도 설정 할 수 있다.

XML after -> before 로 바꾸기

 

4. Weaving (위빙)

 

포인트 컷으로 지정한 핵심 관심 메서드가 호출 될때,

어드바이스에 해당하는 횡단 관심 메서드가 삽입되는 과정 그 자체를 의미한다.

스프링은 런타임 위빙 방식을 사용한다.

 

5) JoinPoint (조인 포인트)

 

before, after, around,after-returning, after-throwing 등등

포인트 컷 후보, 포인트컷이 될수 있는 대상들을 말한다.

 

before - 비즈니스 전에

 

after - 비즈니스 이후

 

after-returning - 비즈니스 아웃풋이 있을때 아웃풋 다음

 

afrer-throwing - 예외 이후 발생 예외가 발생하지 않았다면 동작 하지 않음

 

around - 비즈니스 메서드 수행하기 전 , 후에 호출된다.

비즈니스 메서드 수행하기 전에 1번 수행후 1번 이게 아니다 xxx

around가 진행되는 동안에 비즈니스 메서드가 내부에서 호출되는 것임

ex) 결제하기 할때 트랜잭션에서 around를 사용 .

 

✔️ 추가 내용

 

포인트컷을 여러개 등록할 수 있다

CUD는 DB에 변화를 줄 수 있다

데이터에 대한 확실한 검증이 필요함

상대적으로 보안, 유효성 검사, 트랜잭션,.. 등이 많이 필요함

그러나 R은 DB에 변화가 없음

보려는 데이터에 접근할 수 있는 권한이 있는지만 확인 하면 된다.

상대적으로 공통 로직이 적게 필요하다.

 

내가 select 에만 포인트 컷을 지정하면 selectAll, One 할때만 로그가 나타날수 있다.

일부 포인트컷에만 어드바이스 (공통로직, 횡단 관심)가 동작할 수 있도록 설정가능 !


이제 우리는 이 문장을 이해 할 수 있다 !

 

=> 로그 어드바이스가 있었는데 b 포인트 컷이랑 애스팩트를 했는데 위빙이 안돼 !

로그를 찍는 기능의 횡단 관심이 있었는데

이름이 bPointcut인 CRUD 랑 결합설정을 했는데

실행을 시켜도 결합이 안돼 !

 

- 이제 추측할 수 있는 부분

설정 (xml)에 오타있었거나, bean이 안되어있지 않았거나, 메모리에 쓸 객체가 적재(loading) 가 안되었거나

 

xml이 오타를 인식안해줘서 코드를 주의깊게 보면서 사용 해야 한다.

 

728x90
반응형