네트워크

Apache HTTP Server와 WAS를 연동하여 사용하는 이유

dev_SiWoo 2023. 10. 19. 20:35

일전에 회사에서 다른 솔루션 회사의 제품에 대해서 교육을 들을 기회가 있었다.

 

해당 솔루션은 통합 메시징시스템 솔루션이였는데 Apache Server와 WAS를 연동해서 사용하고 있었다.

 

 문득 나는 Tomcat만 설치해도 Tomcat 자체가 웹 서버 기능을 제공하는데

왜 굳이 Apache Server를 별도로 설치해서 Apache Server랑 Tomcat  두 녀석을 연동해주는 귀찮은 일을

도대체 왜하는 걸까? 라는 의문이 있었다.

 

이러한 의문에 해답은 아래와 같다.

 

1. 성능과 확장성

 Apache HTTP Server 같은 웹 서버들은 정적 컨텐츠를 효율적으로 처리하는 데 최적화되어 있다.

동적 컨텐츠 처리는 WAS에게 맡기고, 정적 컨텐츠는 웹 서버에서 처리하도록 함으로 시스템 전체의 부하를 줄이고

성능을 향상시킬 수 있다고 한다.

 

2. 보안의 측면

웹 서버와 WAS를 분리하여 운영하면, 웹 서버를 DMZ (Demilitarized Zone)와 같은 보안 영역에 배치하고, WAS는 내부 네트워크에 위치시켜 추가적인 보안 계층을 구성할 수 있다.

 

보통 위 도식과 같이 DMZ의 앞뒤로 방화벽을 설치한다.

 

웹 서버는 사용자의 요청을 받아 처리하는 곳이기 때문에 공격자로부터 쉽게 노출된다.

이러한 웹 서버를 DMZ에 두면, 외부 공격자가 웹 서버를 통해 내부 네트워크에 접근하는 것을 막을 수 있다.

 

웹 서버가 공격 당하더라도, DMZ 설정으로 인해 내부 네트워크로의 접근은 제한되므로, 중요한 데이터나 시스템들은 추가적인 보호조치를 취할 수 있기 때문이다.


3. 유연성

웹 서버는 여러 WAS와 연동될 수 있기 때문에, 서로 다른 기술 스택을 가진 여러 애플리케이션을 하나의 웹 서버 아래에서 운영할 수 있습니다.

 

4. 로드벨런싱

 Apache HTTP Server나 Nginx와 같은 웹 서버들은 리버스 프록시 및 로드 밸런서로서의 역할도 할 수 있다.

이를 통해 여러 대의 WAS 서버로 트래픽을 분산시키는 로드 밸런싱을 구현할 수 있어, 대규모 트래픽을 효과적으로 처리하는데 도움이 된다고 한다.

 

 위와 같은 내용들이 필요하기 때문에 웹서버랑 WAS 2개 모두 설치해서 연동하는 것이지만
굳이굳이 간단한 웹 애플리케이션이라거나 또는 개발/테스트 환경일 경우에는 그냥

Apache Tomcat만을 사용하여도 충분하다.