본문 바로가기
5.Linux

6. [CentOS7] 아파치와 톰캣 연동하기 (mod_jk) & 로드밸런스 설정

by 갓대희 2018. 1. 25.
반응형

[CentOS7] 아파치와 톰캣 연동하기 (mod_jk)


안녕하세요. 갓대희 입니다. 이번 포스팅은 [ 로드 밸런싱 설정 해보기 ] 입니다. :) 



▶ 아파치와 톰캣을 연동하는 이유

 - Tomcat 서버는 본연의 임무인 서블릿 컨테이너의 역할만 하고, Apache HTTP Server는 웹서버의 역할을 하도록 각각의 기능을 분리하기 위해 연동을 할 수 있다.

 - Apache HTTP Server에서 제공하는 편리한 기능을 사용하기 위해서 연동을 할수 있다.

 - 대규모 사용자가 사용하는 시스템을 구축할 때 웹 서버인 아파치와 연동을 하면 부하 분산의 효과를 가질 수 있다. mod_jk의 Load Balancing과 FailOver 기능을 사용하여 안정적으로 운영 할 수 있다.

 - 아파치 내에서만 설정할 수 있는 부분이 있고, 아파치에서 제공하는 유용한 모듈들을 톰캣에서 사용할 수 없기 때문이다.


▶ 아파치 톰캣 연동하는 방법들 (참고)

Apache httpd web server 와 tomcat 을 연계하는 방법은 세 가지가 있다. 


예전부터 많이 쓰던 방법은 tomcat connector(mod_jk)를 사용하는 방법이고 다른 하나는 mod_proxy를 사용하여 reverse proxy 기능을 사용하는 방법, 마지막은 mod_proxy_ajp 를 사용하여 AJP Protocol을 reverse proxy 로 사용하는 방법이다. 


mod_proxy 가 mod_jk 에 비해 설정이 간편하고 AJP 같은 특정 WAS 의존적인 프로토콜을 사용하지 않으므로  성능이 더 좋다고 하지만 mod_jk 가 오랫동안 써왔고 친숙해서 mod_jk 를 많이 사용하는 편


▶ 연동원리

아파치와 톰캣이 연동하기 위해선 AJP를 통해 서로 통신을 하여야 한다.

AJP란 아파치가 웹서버와 외부 서비스(톰캣 등)과 연동하기 위해 정한 규약(프로토콜) 이다. 


아파치는 이를 사용하여 80포트로 들어오는 요청은 자신이 받고, 이 요청중 서블릿을 필요로 하는 요청은 톰캣에 접속하여 처리한다.

1) 아파치 웹서버의 httpd.conf 에 톰캣 연동을 위한 설정을 추가하고 톰캣에서 처리할 요청을 지정

2) 사용자의 브라우저는 아파치 웹서버(보통 80포트)에 접속해 요청

3) 아파치 웹서버는 사용자의 요청이 톰캣에서 처리하도록 지정된 요청인지 확인. 요청을 톰캣에서 처리해야 하는 경우

   아파치 웹서버는 톰캣의 AJP포트(보통 8009포트)에 접속해 요청을 전달

4) 톰캣은 아파치 웹서버로부터 요청을 받아 처리한 후, 처리 결과를 아파치 웹서버에 되돌려줌

5) 아파치 웹서버는 톰캣으로부터 받은 처리 결과를 사용자에게 전송



▶ mod_jk 모듈 설치 및 설정

 - 다운로드 및 설치


1. http://www.apache.org/dist/tomcat/tomcat-connectors/jk/

에서 직접 다운로드 FTP 전송



# wget http://mirror.apache-kr.org/tomcat/tomcat-connectors/jk/tomcat-connectors-1.2.42-src.tar.gz

# tar xvfz tomcat-connectors-1.2.42-src.tar.gz

# mv tomcat-connectors-1.2.42-src/ /usr/local/src

 

# yum -y install autoconf libtool

# cd /usr/local/src/ tomcat-connectors-1.2.42-src/native/

# ./buildconf.sh

# ./configure --with-apxs=/usr/local/apache2/bin/apxs

# make && make install

# find / -name "mod_jk.so"

 - 이때 파일이 검색 되면 제대로 설치된 것임.

 - /etc/httpd/modules/ 경로의 파일안에 추가 되어있을 것임.

# cd /usr/local/src/tomcat-connectors-1.2.42-src/native/apache-2.0/

# cp mod_jk.so /usr/local/apache2/modules/

 


 - 설정


 # vi /etc/httpd/conf/httpd.conf



vi에디터 창에서  / 를 누르고 LoadModule을 찾아(엔터후 n버튼을 누르면 다음찾기가 된다.) 그 아래쪽에 다음의 내용을 추가합니다.

VirtualHost 쪽은 아직 못해봤다. 참고.



LoadModule jk_module modules/mod_jk.so


<VirtualHost *:80>

ServerName localhost

# 확장자 jsp, json, xml, do를 가진 경로는 woker tomcat으로 연결하는 구문.

JkMount /*.jsp tomcat

JkMount /*.json tomcat

JkMount /*.xml tomcat

JkMount /*.do tomcat

</VirtualHost>


<ifModule jk_module>

# 워커 설정파일 위치

JkWorkersFile conf/workers.properties

# 로그 위치

JkLogFile logs/mod_jk.log

# 로그레벨 설정

JkLogLevel info

# 로그 포맷에 사용할 시간 형식을 지정한다.

JkLogStampFormat "[%y %m %d %H:%M:%S] "

# Our JK shared memory file

JkShmFile logs/mod_jk.shm

JkMountFile conf/uriworkermap.properties

</ifModule>

 





 # vi /usr/local/apache2/conf/workers.properties



다음 내용 추가



worker.list=instance1,instance2

 

worker.instance1.port=8009

worker.instance1.host=localhost

worker.instance1.type=ajp13

worker.instance1.lbfactor=1

 

worker.instance2.port=8109

worker.instance2.host=localhost

worker.instance2.type=ajp13

worker.instance2.lbfactor=1




worker 이름: worker 이름은 정하기 나름이지만 각각 뒷단의 Tomcat 서버를 구분할 수 있는 이름이여야 한다. 이 worker 이름은 나중에 로드밸런싱을 할때에 Tomcat 에도 적용되어지는 이름이기에 잘 설정해야 한다.

worker port: 여기서 말하는 port 는 뒷단 Tomcat 서버의 AJP 포트를 말한다.

worker type: 이건 ajp13 으로 설정하면 된다.

worker lbfactor: 부하분산을 위한 설정으로 뒷단 Tomcat  서버들에 연결 무게를 설정해준다.




▶ 로드밸런스 설정


앞선 작업들은 로드밸런스 설정과는 관계가 없다. 로드밸런스라고 하면 instance1 인스턴스가 응답하지 않을 경우에 다른 서버들이 그 역활을 대신하는 것을 말한다. 이를 위해서는 woker 설정을 변경해주고 urlworkermap 설정을 추가해주어야 한다.




 # vim /usr/local/apache2/conf/uriworkermap.properties



다음 내용 추가


/*=balancer



로드밸런스는 특정 인스턴스가 죽었을 경우에 다른 서버가 그 역활을 대신하는 것이다. 이를 위해서 로드밸런스 역활을 위한 worker 이름을 정의하고 그 worker 에 로드밸런스를 위한 worker 이름을 정의해주면 된다. 기존의 worker 파일에 다음과 같이 로드밸런스 내용을 추가하면 된다.



 # vi /usr/local/apache2/conf/workers.properties



다음 노란색 구문 추가



worker.list=balancer

 

worker.instance1.port=8009

worker.instance1.host=localhost

worker.instance1.type=ajp13

worker.instance1.lbfactor=1

 

worker.instance2.port=8109

worker.instance2.host=localhost

worker.instance2.type=ajp13

worker.instance2.lbfactor=1


worker.balancer.type=lb

worker.balancer.balance_workers=instance1,instance2

worker.balancer.sticky_session=TRUE




한가지 더, Tomcat 인스턴스들에게 설정을 해줘야 한다. JvmRoute 설정이라고 하는데, 이 설정을 위한 방법은 두가지가 있다. 첫째는 System.property 를 이용한 방법이고 두번째는 server.xml 을 편집하는 방법이다.


첫번째 방법은 Tomcat 인스턴스 구동시에 커맨드라인으로 값을 넣어주는 것으로 다음과 같이 해주면 된다.


System.property



JVM_OPTS=" ${JVM_OPTS} -DjvmRoute=instance1"




보통 Tomcat 의 시작 스크립트는 JVM_OPTS 옵션을 인식한다. 위와같이 Tomcat 인스턴스의 시작 스크립트에 커맨드 라인 옵션으로 jvmRoute 이름을 주면 인식하게 된다.


두번째는 server.xml 파일을 다음과 같이 편집하는 것이다.




<Engine name="Catalina" defaultHost="localhost" jvmRoute="instance1">



위와같이 설정해주면 된다.


만일 두가지 설정을 모두 했을 경우에는 server.xml 파일 설정이 우선되어 적용된다.



 - HTTP 접속 포트 끄기

이렇게 Apache – Tomcat 연동을 하고나면 반드시 Tomcat 인스턴스의 HTTP 접속 포트를 Disable 해주는걸 잊지 말아야 한다.

<!--

    <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

 -->





반응형

댓글1