본문 바로가기
Web Development/Design Patterns

[Design Patterns] 구조 패턴(Structural Patterns) | 프록시 (Proxy) 패턴

by Krystal K 2023. 12. 12.

구조 패턴(Structural Patterns) | 프록시 (Proxy) 패턴 

[index]
1.프록시 (Proxy) 패턴이란?
2. 프록시 (Proxy)  패턴의 장점
3. 프록시 (Proxy) 패턴의 단점
4. 프록시 (Proxy) 패턴 적용 예시
5. 마무리


+ 디자인 패턴이 무엇인지 모른다면?
https://reveur1996.tistory.com/149

[디자인 패턴] 디자인 패턴이란?

디자인 패턴이란? 1. 디자인 패턴이란? 2. 디자인 패턴 구조 3. 왜 디자인 패턴을 알아야할까? 4. 디자인 패턴에 대한 부정적인 시각 5. 디자인 패턴의 분류 6.마무리 1. 디자인 패턴이란? 패턴은 알

reveur1996.tistory.com

 

1. 프록시 (Proxy) 패턴이란?

프록시(Proxy) 패턴은 어떤 다른 객체를 대신하여 그 객체에 대한 접근을 제어하거나 조작하기 위한 구조적인 패턴입니다. 이 패턴은 클라이언트와 실제 서비스 객체 사이에 중간 매개체로서의 프록시 객체를 도입함으로써 특정 제어를 추가하거나 객체에 대한 접근을 간접적으로 관리할 수 있게 합니다. 프록시 객체로 쓰이기도 하지만 프록시 서버로도 활용합니다. 
 
프록시 패턴은 보안, 로깅, 캐싱, 지연 로딩, 원격 객체 접근 등 다양한 시나리오에서 활용될 수 있으며, 객체 간의 간접적인 상호작용을 통해 시스템의 유연성과 확장성을 향상시킵니다.
 
프록시 서버
서버와 클라이언트 사이에서 클라이언트가 자신을 통해 다른 네트워크 서비스에 간집적으로 접속할 수 있게 접속할 수 있게 해주는 컴퓨터 시스템이나 응용 프로그램을 가리킵니다. 
 

 

프록시 패턴의 구성 요소

  1. Subject(주체)
    프록시가 대표하는 실제 객체에 대한 인터페이스를 정의합니다. 이는 프록시와 실제 서비스 객체가 동일한 인터페이스를 공유하여 클라이언트가 프록시를 실제 객체로 간주하게 합니다.

  2. RealSubject(실제 주체)
    실제 서비스를 제공하는 실제 객체를 나타냅니다. 이 객체가 클라이언트의 요청을 처리하고, 프록시가 간접적으로 접근하는 대상이 됩니다.

  3. Proxy(프록시)
    실제 서비스 객체에 대한 접근을 제어하고, 추가적인 기능을 제공하기 위한 객체입니다. 프록시는 주체와 동일한 인터페이스를 구현하면서, 클라이언트가 실제 서비스 객체에 직접 접근하는 것을 막고, 필요한 경우 클라이언트 요청을 가로채서 추가적인 작업을 수행할 수 있습니다.

 

프록시 패턴의 활용

  • 보안 제어
    프록시를 사용하여 실제 서비스 객체에 대한 접근을 제어할 수 있습니다. 클라이언트의 요청을 검증하거나, 특정 권한이 있는 경우에만 실제 객체에 접근을 허용할 수 있습니다.

  • 로깅
    프록시를 이용하여 클라이언트의 요청 및 서비스 객체의 응답을 로깅할 수 있습니다. 이를 통해 시스템 동작을 기록하고 디버깅하는 데 도움을 줍니다.

  • 캐시
    프록시를 사용하여 이전에 수행된 요청의 결과를 캐싱하고, 동일한 요청이 들어올 경우 캐시된 결과를 반환할 수 있습니다. 이는 성능 향상을 도모할 수 있습니다.

  • 지연 로딩
    특히 대용량 데이터베이스와 관련된 작업에서 프록시는 데이터를 실제로 필요한 시점에만 로딩하여 성능을 최적화할 수 있습니다.

  • 원격 객체 접근
    프록시를 사용하여 원격지에 위치한 서비스 객체에 접근할 수 있습니다. 클라이언트는 로컬에서 마치 로컬 객체에 접근하는 것처럼 사용할 수 있고, 프록시가 원격 서비스 객체와의 통신을 관리합니다.

  • 복잡한 객체 생성
    실제 객체가 생성하기 어려운 복잡한 객체의 경우, 프록시를 사용하여 필요한 시점에 객체를 생성하고 초기화할 수 있습니다.

 

2. 프록시 (Proxy) 패턴의 장점

  1. 보안 제어
    프록시를 사용하면 실제 서비스 객체에 대한 접근을 제어할 수 있습니다. 특정 권한을 가진 클라이언트만이 실제 객체에 접근할 수 있도록 보안 검사를 수행할 수 있습니다.

  2. 로깅 및 감시
    프록시를 이용하여 클라이언트의 요청과 실제 서비스 객체의 응답을 기록하고 감시할 수 있습니다. 이를 통해 시스템 동작을 추적하고 디버깅하는 데 도움을 줍니다.

  3. 캐싱
    프록시를 활용하여 이전에 수행된 요청의 결과를 캐싱함으로써 성능을 향상시킬 수 있습니다. 동일한 요청이 여러 번 수행되면 캐시된 결과를 반환하여 불필요한 계산을 방지합니다.

  4. 원격 서비스 접근
    프록시는 클라이언트에게 로컬 객체처럼 보이게 하면서, 실제로는 원격에 위치한 객체와 통신할 수 있습니다. 이를 통해 네트워크를 통한 서비스 호출이 가능해집니다.

  5. 지연 로딩
    특히 대용량 데이터의 경우, 프록시를 사용하여 데이터를 실제로 필요한 시점에 로딩함으로써 성능을 최적화할 수 있습니다. 사용자가 특정 데이터를 요청할 때까지 데이터를 로딩하지 않습니다.

 

3. 프록시 (Proxy패턴의 단점

  1. 복잡성 증가
    프록시를 도입하면 코드의 복잡성이 증가할 수 있습니다. 실제 서비스 객체와 프록시 객체 간에 인터페이스 및 관련 로직을 추가해야 하므로 코드가 더 복잡해질 수 있습니다.

  2. 성능 저하
    프록시 패턴은 추가적인 중간 계층을 도입하므로 성능 저하가 발생할 수 있습니다. 특히 프록시에 추가된 로깅, 보안 검사, 캐싱 등의 로직이 처리되어야 하기 때문입니다.

  3. 유지보수 어려움
    프록시 객체와 실제 서비스 객체 간의 동기화를 유지하는 것이 중요합니다. 이 두 객체 간의 일관성을 유지하려면 유지보수가 어려울 수 있습니다.

  4. 추가적인 클래스 도입
    프록시 패턴은 프록시 객체를 추가로 도입하므로 클래스의 수가 늘어나게 됩니다. 이로 인해 클래스의 계층이 복잡해지고, 코드베이스의 크기가 증가할 수 있습니다.

  5. 중복된 코드
    프록시 객체에서 실제 서비스 객체로의 호출을 전달하는 코드는 일종의 중복 코드가 될 수 있습니다. 이러한 중복은 유지보수를 어렵게 할 수 있습니다.

 

4. 프록시 (Proxy) 패턴 적용 예시

// 실제 서비스 객체
class RealService {
  request() {
    console.log('실제 서비스 요청 처리');
  }
}

// 프록시 객체
class ProxyService {
  constructor(realService) {
    this.realService = realService;
  }

  request() {
    console.log('프록시에서 요청 전 처리');
    this.realService.request();
    console.log('프록시에서 요청 후 처리');
  }
}

// 클라이언트 코드
const realService = new RealService();
const proxyService = new ProxyService(realService);

// 클라이언트는 프록시를 통해 서비스에 접근
proxyService.request();

 
이 예시에서 RealService는 실제 서비스를 나타내고, ProxyService는 프록시 역할을 하는 클래스입니다. 프록시 객체는 실제 서비스 객체를 감싸고, 특정 로그를 출력하는 기능을 추가하고 있습니다. 클라이언트는 프록시 객체를 통해 서비스에 접근하게 됩니다.
이렇게 프록시 패턴을 사용하면 클라이언트는 실제 서비스 객체를 직접 다루지 않고 프록시를 통해 간접적으로 접근함으로써 특정 기능을 추가하거나 제어할 수 있습니다.
 

5. 마무리

프록시 패턴은 현대 소프트웨어 아키텍처에서 중요한 역할을 하는 디자인 패턴 중 하나로, 애플리케이션과 외부 서비스 간의 통신을 효과적으로 관리하고 제어하는 데 사용됩니다. 이 패턴은 보안, 성능 최적화, 로깅 등 다양한 측면에서 이점을 제공합니다.
 
프록시 패턴을 적용함으로써, 애플리케이션은 외부 서비스에 직접적으로 접근하는 것이 아니라 프록시를 통해 간접적으로 통신합니다. 이를 통해 애플리케이션은 외부 서비스의 변경에 대응하기 쉬워지며, 보안 상의 이점도 얻을 수 있습니다. 또한, 프록시는 요청과 응답을 중간에서 가로채어 필요에 따라 수정하거나 로깅하는 등의 작업을 수행할 수 있습니다. 이를 통해 데이터의 가공이나 보안 정책의 적용 등이 가능하며, 디버깅이나 성능 최적화에도 도움이 됩니다.
 
종합적으로, 프록시 패턴은 복잡한 시스템에서 모듈 간의 유연한 통신을 지원하고, 유지보수성과 확장성을 향상시키는 데 기여합니다. 이는 현대 소프트웨어 개발에서 필수적인 구조 중 하나로 자리 잡고 있습니다. 프록시 패턴을 효과적으로 활용함으로써 안정성과 보안성을 강화하며, 더 나은 소프트웨어 아키텍처를 구축할 수 있을 것입니다.
 
 


참고문헌
https://dev.to/jsmanifest/the-power-of-proxy-pattern-in-javscript-6fp
https://velog.io/@lesh/Javascript%EC%97%90%EC%84%9C%EC%9D%98-Proxy-Pattern%EA%B3%BC-Proxy%EA%B0%9D%EC%B2%B4-3njz2d5vl1
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Proxy
https://javascriptpatterns.vercel.app/patterns/design-patterns/proxy-pattern
https://davidwalsh.name/javascript-proxy
https://patterns-dev-kr.github.io/design-patterns/proxy-pattern/
https://www.dofactory.com/javascript/design-patterns/proxy
https://www.patterns.dev/vanilla/proxy-pattern/

728x90