본문으로 건너뛰기

3. Tomcat 설치

약 7 분TomcatJava

3. Tomcat 설치

  • 설치파일 받기
  • 윈도우에 설치하기
  • 유닉스/리눅스에 설치하기
  • 설치 후 작업
  • 디렉토리 구조

설치되는 톰캣의 최상위 경로는 $CATALINA_HOME 으로 표현합니다.

3.1 설치파일 받기

설치파일은 톰캣 홈페이지open in new window에서 좌측의 Downloads에서 설치하고자 하는 버전을 선택하면 우측에 Binary와 Source Code 두가지 형태로 받을 수 있습니다. Binary는 OS플랫폼에 맞게 미리 준비된 설치파일로서 Core에 해당하는 파일을 받습니다. 종류는 여섯가지로 나뉘어 있습니다.

zip과 tar.gz는 Unix/Linux환경에서 사용할 압축된 형태의 파일이고 나머지 네가지는 CPU 아키텍쳐에 맞게 컴파일된 zip 형태의 압축 파일과 서비스에 등록할수 있는 형태의 인스톨러로 구성되어 있습니다. 설치하고자 하는 OS와 CPU 아키텍처에 맞는 설치파일을 받아 준비합니다.

3.2 윈도우에 설치하기

Windows에는 압축파일을 풀어 설치하는 방법과 서비스 등록을 위한 인스톨러 두가지 방식이 있었습니다. 압축파일 형태의 경우 압축을 풀기만하면 바로 실행이 가능합니다. 서비스 인스톨러의 경우 서비스에 등록하기 위한 설치 경로와 같은 정보를 입력하여 진행합니다.

압축파일로 설치한 경우 %CATALINA_HOME%\bin에 위치한 startup.bat으로 시작하고 shutdown.bat으로 종료합니다.

서비스로 설치한 경우 윈도우 서비스 관리 유틸리티에서 서비스의 '시작/종료'를 사용하거나 net start (서비스이름) 또는 net stop (서비스이름)을 사용하여 서비스의 시작과 종료가 가능합니다.

3.3 유닉스/리눅스/맥 에 설치하기

Unix/Linux의 binary 설치파일은 압축을 풀어 설치합니다.

$CATALINA_HOME/bin에 위치한 startup.sh으로 시작하고 shutdown.sh으로 종료합니다.

3.4 설치 후 작업

설치 방법은 매우 간단하나 설치 후 꼭 해야할 작업이 있습니다. Java Home을 설정하고 성능을 위한 Native library를 설치하는 작업 입니다.

Java Home의 경우 앞서 JDK를 OS에 설치하였다면 톰캣에서 이를 사용할 수 있도록 경로를 잡아주는 과정입니다. OS자체의 PATH나 환경변수로 지정하는 방법도 있고 톰캣의 스크립트에 변수로 넣어주는 방법이 있습니다. OS자체의 PATH로 설정하는 경우 해당 OS에 설치된 모든 Java 실행환경이 영향을 받게 됩니다. 따라서 일관된 서비스, 일관된 톰캣 운영 환경인 경우 같은 Java Home이 설정되는 장점이 있습니다. 이와달리 스크립트에 Java Home을 설정하면 해당 톰캣에서만 관련 설정의 영향을 받습니다. OS내에 서로 다른 JDK로 동작하는 서비스나 어플리케이션이 있다면 스크립트를 이용하는 방법을 사용할 수 있습니다.

3.4.1 Java Home 설정하기

OS 환경에 Java Home을 설정하는 방법은 다음과 같습니다. (Java Home은 JDK의 bin 디렉토리를 포함한 상위 디렉토리 입니다.)

3.4.1.1 환경변수로 지정

Unix/Linux/OSX

계정 루트의 .profile (bash 쉘의 경우 .bash_profile)에 다음을 설정

# .bash_profile
export JAVA_HOME=/usr/java/jre1.8.0_241

3.4.1.2 스크립트에 추가

스크립트에 Java_Home을 설정하는 경우 catalina.sh(bat)JAVA_HOME 으로 지정하는 경우가 있습니다. 추가로 setenv.sh(bat)을 생성하여 해당 스크립트에 설정하는 방법을 권장합니다.

Unix/Linux/OSX
# setenv.sh
JAVA_HOME="/usr/java/jre1.8.0_241"

Windows환경에서 Java를 C:\Program Files에 설치하는 경우 중간에 공백이 있기 때문에 C:\Progra~1로 표현함에 주의합니다.

3.4.2 Native Library 적용하기 (옵션)

톰캣의 Native Library를 적용하지 않고도 충분히 톰캣을 실행하고 사용할 수 있습니다. 다만 톰캣의 콘솔 로그에 다음의 메시지가 걸리적(?)거리게 발생합니다.

The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path

굳이 필요하지 않다면 적용하지 않아도 되지만 Native Library가 주는 이점은 다음과 같습니다.

  • Non-blocking I/O for Keep-Alive requests (between requests)
  • Uses OpenSSL for TLS/SSL capabilities (if supported by linked APR library)
  • FIPS 140-2 support for TLS/SSL (if supported by linked OpenSSL library)

결국 NIO(Non-Blocking I/O)를 지원하는 것과 SSL관련 설정을 지원합니다. OpenSSL을 사용하지 않아도 NIO를 사용하는 성능상의 이점을 제공합니다.

Native Library를 사용하기 위해서는 APR과 Tomcat Native 소스 파일이 필요합니다. APR은 Apache 2.0 이상 버전이 설치되어있다면 해당 설치 경로의 $APACHE_HOME/bin/apr-1-config과 같이 존재하나 없는 경우 별도의 APR을 설치합니다.

(Apache APR 홈페이지 : http://apr.apache.org/open in new window)

APR 홈페이지에서 받은 apr-x.x.x.tar.gz 파일은 다음의 순서를 따라 설치를 진행하며, 예제와 같이 /usr/local에 설치하는 경우 root 계정이 필요합니다.

$ gzip -d apr-1.5.1.tar.gz
$ tar -xvf apr-1.5.1.tar
$ configure --prefix=/usr/local/apr-1.5.1
$ make
$ make install

일반적인 경우 Tomcat이 설치되면 설치된 경로의 "$CATALINA_HOME/bin" 위치에 tomcat-native.tar.gz 형태로 설치 파일이 존재하나 없는 경우, 혹은 높은 버전을 설치하고 싶은 경우 별도로 다운로드 받아 진행합니다. Native의 다운로드는 톰켓 홈페이지의 좌측 Downloads의 하위에 Tomcat Nativeopen in new window로 존재합니다. 관련 링크를 클릭하면 우측에 OS플랫폼에 맞게 소스를 받을 수 있는 링크가 제공됩니다.

Native Library는 다음과 같이 설치를 진행합니다.

$ gzip -d tomcat-native.tar.gz
$ tar -xvf tomcat-native.tar
$ configure --prefix=$CATALINA_HOME --with-apr=/usr/local/apr-1.5.1/bin/apr-1-config  --with-java-home=$JAVA_HOME
$ make
$ install

소스의 컴파일과 설치가 완료되면 "$CATALINA_HOME/lib"에서 libtcnative 관련 파일의 확인을 할 수 있습니다.

Native Library가 해당 플랫폼 환경에 맞게 생성되었다면 Shared Library로 설정하여 적용하며 적용방법은 앞서 Java Home을 설정하는 방법을 이용합니다. Shared Library 환경변수명은 OS마다 상이함에 주의하며 setenv.shopen in new window(bat)에 적용하는 방법은 다음과 같습니다.

# setenv.sh(bat)
LD_LIBRARY_PATH "$CATALINA_HOME/lib"
OSShared Library Path
WindowsPATH
SolarisLD_LIBRARY_PATH
HP-UXSHLIB_PATH
AIXLIBPATH,LD_LIBRARY_PATH
LinuxLD_LIBRARY_PATH
OS/2LIBPATH
OSXLD_LIBRARY_PATH

적용된 Native Library는 톰캣의 콘솔 로그 "$CATALINA_HOME/logs/catalina.out(log)"에서 다음의 메시지를 확인 할 수 있습니다.

Info: Loaded APR based Apache Tomcat Native library 1.1.31.