一、環境說明

在一臺服務器上安裝一個apache作為web server,多個tomcat作為應用的容器,此時我們便可以使用apache來作為一個調度員將用戶發來的請求發送到不同的tomcat。在此我使用192.168.0.3作為apache和tomcat的服務器,192.168.0.4作為另一臺tomcat應用服務器。

拓撲如下:


122511271.jpg

二、原理

tomcat 為一個jsp的容器,apache為一個web server,兩者之間通信通過worker進行(由Tomcat使用Server.xml文件中Connector的標簽來定義其端口和協議),通過 mod_jk的模塊(由web服務器像apache、iis等使用)和Web Server通信。整個過程其實就是讓apache的httpd.conf文件調用mod_jk.conf,mod_jk.conf調用workers.properties,最后配置虛擬主機。
文件說明
mod_jk.conf
主要定義mod_jk模塊的位置以及mod_jk模塊的連接日志設置,還有定義worker.properties文件的位置。
worker.properties
定義worker的參數,主要是連接tomcat主機的地址和端口信息。如果Tomcat與apache不在同一臺機器上,或者需要做多臺機器上tomcat的負載均衡只需要更改workers.properties文件中的相應定義即可。
三、安裝軟件
1.先安裝了所需的程序庫
yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel
2.Apache 安裝:
tar zxvf httpd-2.2.8.tar.gz
cd httpd-2.2.8
./configure --prefix=/usr/local/apache2 --enable-modules=so --enable-so
make && make install
3.JDK的安裝
chmod 755 jdk-6u26-linux-i586-rpm.bin
./jdk-6u26-linux-i586-rpm.bin
mv /usr/java/jdk1.6.0_26 /usr/local/
到/usr/bin目錄下,把原用的java,javac文件刪除:
rm -rf /usr/bin/{java,javac}
在/usr/bin 下建立 軟連接 java
ln -s /usr/local/jdk1.6.0_26/bin/java /usr/bin/java
ln -s /usr/local/jdk1.6.0_26/bin/javac /usr/bin/javac
javac -version
為了方便下在的工作建立兩個軟鏈接:
ln -s /usr/local/jdk1.6.0_26/ ?/usr/local/jdk
ln -s /usr/local/jdk1.6.0_26/jre /usr/local/jre
4.Tomcat的安裝
tar -zxvf apache-tomcat-7.0.16.tar.gz
mv apache-tomcat-7.0.16 /usr/local/tomcat
5.設置環境變量:
vi .bash_profile
JAVA_HOME=/usr/local/jdk
export JAVA_HOME
JRE_HOME=/usr/local/jre
export JRE_HOME
CLASSPATH=/usr=/usr/local/tomcat/lib/:/usr/local/jdk/lib:/usr/local/jre/lib
export CLASSPATH
PATH=$PATH:/usr/local/tomcat/bin/:/usr/local/apache/bin:/usr/local/jdk/bin:/usr/local/jre/bin
export PATH
TOMCAT_HOME=/usr/local/tomcat
export TOMCAT_HOME
source .bash_profile ?//使環境變量立即生效
6.JK 安裝 (整合apache tomcat)
tar zxvf tomcat-connectors-1.2.27-src.tar.gz
cd tomcat-connectors-1.2.27-src/native
./configure --with-apxs=/usr/local/apache2/bin/apxs --with-java-home=/usr/local/jdk
sleep 3
make && make install
在/usr/local/apache2/modules/ 下會產生mod_jk.so
(同樣在192.168.0.4上也要安裝jdk和tomcat)
四、配置Apache
1.修改apache配置文件
NameVirtualHost *:80
<VirtualHost *:80>
ServerName ?www.baiying21.com
JkMountFile conf/mount_baiying21.properties
</VirtualHost>
<VirtualHost *:80>
ServerName ?www.baiying23.com
JkMountFile conf/mount_baiying23.properties
</VirtualHost>
include conf/mod_jk.conf
2.調度器JK的配置
建立JK配置文件:
vi /usr/local/apache2/conf/workers.properties
worker.list=jvm_baiying21,jvm_baiying23
#========jvm_baiying21========
worker.jvm_baiying21.type=ajp13
worker.jvm_baiying21.port=8009 ? ? ? ? ? ? ? ? ? ? ? //第6步會配置此端口
worker.jvm_baiying21.host=localhost
worker.jvm_baiying21.lbfactor=1
#========jvm_baiying23========
worker.jvm_baiying23.type=ajp13
worker.jvm_baiying23.port=8010
worker.jvm_baiying23.host=192.168.0.4
worker.jvm_baiying23.lbfactor=1
3.vi /usr/local/apache2/conf/mod_jk.conf
LoadModule jk_module modules/mod_jk.so
JkWorkersFile conf/workers.properties
JkLogFile logs/mod_jk.log
JkShmFile logs/mod_jk.shm
JkLogLevel info
JkLogStampFormat "[%a %b %d %H:%M:%S %Y] "
JkOptions +ForwardKeySize +ForwardURICompat -ForwardDirectories
JkRequestLogFormat "%w %V %T"
#JkMount /* controller
4.vi /usr/local/apache2/conf/mount_baiying21.properties
/*=jvm_baiying21
5.vi /usr/local/apache2/conf/mount_baiying23.properties
/*=jvm_baiying23
6.修改baiying21的tomcat調用端口
vi /usr/local/tomcat/conf/server.xml
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> ? //我們使用默認端口8009
修改baiying23的tomcat調用端口
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> ?
五、創建jsp測試頁面
在baiying21的tomcat安裝路徑下建立目錄test
mkdir /usr/local/tomcat/webapps/ROOT/test/
vi index.jsp
<html>
<title>
baiying21 jsp
</title>
<%
String showMessage="Oh My God baiying21!";
out.print(showMessage);
%>
</html>
----------------------------
在baiying23的tomcat安裝路徑下建立目錄test
mkdir /usr/local/tomcat/webapps/ROOT/test/
vi index.jsp
<html>
<title>
baiying23 jsp
</title>
<%
String showMessage="Oh My God baiying23!";
out.print(showMessage);
%>
</html>
修改客戶端的hosts文件
192.168.0.3www.baiying21.com
192.168.0.3www.baiying23.com
在客戶端瀏覽器分別輸入www.baiying21.com/test/index.jsp、www.baiying23.com/test/index.jsp驗證apache是否調度成功。
錯誤總結:
在未正確配置tomcat調用端口時,日志報錯如下錯誤信息,因為之前我把調度器JK的配置中的tomcat調用端口配置成了8080,而tomcat默認的ajp借口為8009
# tail -f access_log
192.168.0.1 - - [24/Aug/2011:14:14:15 +0800] "GET /favicon.ico HTTP/1.1" 404 209
192.168.0.1 - - [24/Aug/2011:15:08:20 +0800] "GET / HTTP/1.1" 503 323
192.168.0.1 - - [24/Aug/2011:15:16:23 +0800] "GET /test/index.jsp HTTP/1.1" 502 232
192.168.0.1 - - [24/Aug/2011:15:17:42 +0800] "GET / HTTP/1.1" 502 232
192.168.0.1 - - [24/Aug/2011:15:17:52 +0800] "GET / HTTP/1.1" 502 232
# tail -f mod_jk.log
[Wed Aug 24 15:53:52 2011] [25050:3086759680] [info] jk_handler::mod_jk.c (2678): Service error=0 for worker=jvm_chanjet21
[Wed Aug 24 15:54:01 2011] [25050:3086759680] [error] ajp_connection_tcp_get_message::jk_ajp_common.c (1296): wrong message format 0x4854 from 127.0.0.1:8080
[Wed Aug 24 15:54:01 2011] [25050:3086759680] [error] ajp_get_reply::jk_ajp_common.c (2118): (jvm_chanjet21) Tomcat is down or refused connection. No response has been sent to the client (yet)
[Wed Aug 24 15:54:01 2011] [25050:3086759680] [info] ajp_service::jk_ajp_common.c (2607): (jvm_chanjet21) sending request to tomcat failed (recoverable), because of protocol error (attempt=1)
還可以通過netstat ?-anp | grep java查看java使用的jk配置中端口信息