天天看點

(一)整合apache+tomcat排程

 一、 環境說明

 在一台伺服器上安裝一個apache作為web server,多個tomcat作為應用的容器,此時我們便可以使用apache來作為一個排程員将使用者發來的請求發送到不同的tomcat。在此我使用192.168.0.3作為apache和tomcat的伺服器,192.168.0.4作為另一台tomcat應用伺服器。

拓撲如下:

<a target="_blank" href="http://blog.51cto.com/attachment/201112/122511271.jpg"></a>

二、 原理

 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 &amp;&amp; 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

在/usr/local/apache2/modules/ 下會産生mod_jk.so

(同樣在192.168.0.4上也要安裝jdk和tomcat)

四、 配置Apache

1.修改apache配置檔案

NameVirtualHost *:80

&lt;VirtualHost *:80&gt;

    ServerName  www.baiying21.com

    JkMountFile conf/mount_baiying21.properties

&lt;/VirtualHost&gt;

    ServerName  www.baiying23.com

    JkMountFile conf/mount_baiying23.properties

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

&lt;Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /&gt;   //我們使用預設端口8009

修改baiying23的tomcat調用端口

&lt;Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /&gt;  

五、 建立jsp測試頁面

在baiying21的tomcat安裝路徑下建立目錄test

mkdir /usr/local/tomcat/webapps/ROOT/test/

vi index.jsp

&lt;html&gt;

&lt;title&gt;

baiying21 jsp

&lt;/title&gt;

&lt;%

   String showMessage="Oh My God baiying21!";

   out.print(showMessage);

%&gt;

&lt;/html&gt;

----------------------------

在baiying23的tomcat安裝路徑下建立目錄test

baiying23 jsp

   String showMessage="Oh My God baiying23!";

修改用戶端的hosts檔案

192.168.0.3 www.baiying21.com

192.168.0.3 www.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配置中端口資訊 

本文轉自 baiying 51CTO部落格,原文連結:http://blog.51cto.com/baiying/739793,如需轉載請自行聯系原作者