ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • Apache와 Tomcat의 차이?
    Web/HTML5 웹 프로그래밍 입문 2020. 4. 3. 00:28

     

    정적 자원은 Apache에서 처리하고 Tomcat 은 AWS로서 동적 자원을 처리한다는 것은 잘 알려져 있다.

     

    하지만 JAVA에서 Tomcat은 정적 자원과 동적 자원을 동시에 처리하는 것으로 알고 있으며 Apache는 쓰지 않는 이유와

     

     Tomcat 앞에 아파치 웹 서버(Httped)를 두어서 처리하는 게 성능이 좋다는 글도 있기에 아리송한 개념을 정리해 보려고 한다.

     

     

    1. Apache

     

    Apache 서버는 오픈소스 라이선스에 따라 배포되어 마음대로 쓸 수 있는 Http 웹 서버이다.

     

    데이터의 정적인 데이터들 (html, css 이미지, 파일 등)에 대한 클라이언트의 요청을 데이터로 만들어서 응답한다.

     

    2. TomCat

     

    웹 서버와 웹 컨테이너의 결합

     

    다양한 기능을 컨테이너에 구현해 다양한 역할을 수행한다. 

     

    예를 들어 서블릿 컨테이너에서 서블릿의 생명 주기를 스펙에 기반하여 관리, 세션 관리, 네트워크 서비스 등

     

    웹 컨테이너는 클라이언트의 요청이 있을 시 내부 프로그램을 통해 결과를 만들고 다시 클라이언트에게 돌려준다.

     

     

    그렇다면 둘의 차이점은?

     

    웹 컨테이너의 유무로서 웹 서버는 정적인 데이터를 처리하는 곳에 쓰이며 단순 html, 이미지 등은 웹 서버가 적당하고

     

    빠르며 안정적이다.

     

    WAS는 동적인 데이터를 처리하는 서버, DB 연결, 데이터 조작 등의 처리는 WAS를 활용해야 한다.

     

     

     

    +) 그렇다면 왜 톰캣을 아파치 톰캣이라고 부르나? 아파치 톰캣 = 아파치 + 톰캣?

     

    톰캣을 그냥 톰캣이라고 하면 되지, 왜 헷갈리게 아파치 톰캣이라고 하느냐?

    톰캣에서 아파치의 기능(웹서비스 데몬, Httpd)을 포함하고 있기 때문에. 그렇지만 톰캣이 아파치의 모든 기능을 포함하고 있는 것은 아니다.

     

     

     

    +) 보통 현업에서는 톰캣 앞에 아파치를 놓는다 그 이유는? (by 토비)

     

    많은 개발자들이 애플리케이션 서버로 톰캣을 사용하는 경우에 스태틱 파일(css, js, html, 이미지)은 톰캣 앞에 아파치 웹 서버(Httped)를 두어서 처리하게 하는 것이 좋다고 생각한다. 외부 요청은 일단 Apache Httpd가 받고, 톰캣 내에서 처리할 자바 애플리케이션만 톰캣으로 다시 전달해서 처리하고 그 외의 리소스는 Apache Httpd가 직접 처리하게 만들어야 성능이 좋다고 생각한다. 자바로 만든 서버인 톰캣은 스태틱 파일 처리에서 Apache Httpd만 못하다는 것이 그 이유이다.

     

    하지만 톰캣과 Httped의 개발자에 따르면 이는 개발자들이 잘못 알고 있는 미신이다. 아직도 톰캣 3을 사용하고 있는 것이 아니라면 말이다.

    톰캣은 5.5부터 Httpd의 native모듈을 사용해서 스태틱 파일을 처리하는 기능을 제공한다. 이 경우 Httpd와 톰캣이 같은 모듈을 사용하는 셈이니 성능에서 차이가 날 이유가 없다. 실제 테스트한 결과를 봐도 톰캣에서 아파치 Native 모듈을 사용하는 것이 순수하게 아파치 Httpd만 사용하는 것과 비교해서 성능이 전혀 떨어지지 않는다. 

     

     따라서 단지 스태틱 파일 처리의 성능만을 위해서라면 굳이 톰캣 앞에 Apache Httpd를 두는 것은 불필요하다. 오히려 메모리만 많이 먹고 관리부 담은 커지고, 불필요한 부하만 걸릴 뿐이다.

     

     물론 Httpd의 다른 기능이나 모듈을 사용해야 할 필요가 있다면 그때는 Httpd를 앞에 두고 사용해야겠지만. 

     

    예를 들어 하나의 서버에서 PHP 애플리케이션과 자바 애플리케이션을 함께 사용하거나, Httpd 서버를 간단한 로드밸런싱을 위해서 사용해야 하는 경우라면 Httpd를 앞에 두고 톰캣을 연결해서 사용하도록 하면 될 것이다.

     

Designed by Tistory.