티스토리 뷰

dev_note/TIL

프록시

jjoylee 2021. 7. 10. 17:08

프록시

  • 대리자
  • 다른 무언가와 이어지는 인터페이스의 역할을 하는 클래스

프록시 패턴

  • 프록시 객체를 통해 실제 객체(Real Subject)에 접근하는 패턴(흐름 제어를 위해 사용)
  • 클라이언트에서는 프록시 클래스를 통해 간접적으로 실제 객체(Real Subject)를 사용한다.
  • 실제 객체에 대한 정보를 클라이언트로부터 은닉시킨다.
  • 중요 포인트 : 프록시 클래스와 실제 객체 클래스는(Real Subject)는 같은 인터페이스를 구현한다.
  • Client -> Subject Interface -> Proxy Class(implements Subject Interface) -> RealSubject Class(Implements Subject Interface)
  • 토비 스프링 트랜잭션 프록시 : UserService 사용하는 메소드 -> UserService Interface -> UserServiceTx -> UserServiceImpl
  1. Client는 프록시 객체 생성
  2. Client에서 Proxy Class의 메소드 호출(인터페이스 메소드 구현한 것)

// Client
public class HelloClient {
    public static void main(String[] args){
        IHello hello = new ProxyHello(); // 프록시 객체 생성
        hello.hello(); // 프록시 객체의 메소드 호출(다형성) 
        // hello는 ProxyHello 클래스에서 IHello 인터페이스의 hello 메소드를 구현한 것 

        // 실행 결과
        //ProxyHello Called
        //RealHello Called
        //RealHello End
        //ProxHello End
    }
}
  1. Proxy Class의 메소드 구현에서 RealSubject Class의 메소드 호출(인터페이스 메소드 구현한 것)

// Subject Interface
public interface IHello {
    void hello();
}

// Proxy Class( implements IHello interface )
public class ProxyHello implements IHello{
    @Override
    public void hello() {
        System.out.println("ProxyHello Called");
        new RealHello().hello(); // RealHello(RealSubject Class) 클래스의 메소드 호출
        System.out.println("ProxHello End");
    }
}

// RealSubject Class( implements IHello interface )
public class RealHello implements IHello{
    @Override
    public void hello() {
        System.out.println("RealHello Called");
        System.out.println("RealHello End");
    }
}

종류

  1. 가상 프록시 : 필요로 하는 시점까지 객체 생성을 연기하고, 해당 객체가 생성된 것처럼 동작하도록 만들고 싶을 떄 사용. 인스턴스가 필요한 시점에 생성, 초기화.
  2. 원격 프록시 : 네트워크가 연결된 상황에서 원격으로 로컬 객체릉 원격 객체처럼 사용할 수 있게 해준다.
  3. 보호 프록시 : 엑세스 제한 설정. 객체에 대해 액세스 권한 부여

장점

  • 객체들의 역할을 분리해서 개별적으로 수정할 수 있다. 유지보수가 용이하다.
  • 쉽게 추가적인 기능을 삽입할 수 있다. (ex. transaction, 접근 제어)
  • 실제 객체의 public, protected 메소드들을 숨기고 인터페이스를 통해 노출시킬 수 있다. (은닉)
  • 원래 객체의 접근에 대해서 사전처리를 하거나, 캐싱할 수 있다.

단점

  • 빈번한 객체 생성이 필요할 경우 성능이 저하될 수 있다.
  • 로직이 난해해져 가독성이 떨어질 수 있다.

Reference


https://coding-factory.tistory.com/711
https://lee1535.tistory.com/101
https://limkydev.tistory.com/79

'dev_note > TIL' 카테고리의 다른 글

SQL 레벨업  (0) 2021.07.11
웹 개발자를 위한 웹을 지탱하는 기술  (0) 2021.07.11
데코레이터 패턴  (0) 2021.07.10
(최근본상품2)Problem Solving  (0) 2019.02.23
(최근 본 상품1) 쿠키에 데이터 넣기  (0) 2019.02.23
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/05   »
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
글 보관함