开发者社区> 余二五> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

(一)整合apache+tomcat调度

简介:
+关注继续查看

 一、 环境说明

 在一台服务器上安装一个apache作为web server,多个tomcat作为应用的容器,此时我们便可以使用apache来作为一个调度员将用户发来的请求发送到不同的tomcat。在此我使用192.168.0.3作为apache和tomcat的服务器,192.168.0.4作为另一台tomcat应用服务器。

拓扑如下:

 

二、 原理

 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.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,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
apache 与 tomcat 整合
首先我们先介绍一下为什么要让 Apache 与 Tomcat 之间进行连接。事实上 Tomcat 本身已经提供了 HTTP 服务,该服务默认的端口是 8080,装好 tomcat 后通过 8080 端口可以直接使用 Tomcat 所运行的应用程序,你也可以将该端口改为 80。
866 0
Idea配置Tomcat服务器
我们都知道Idea的功能非常强大,插件很多,很多能帮助我们快速开发的东西都已经集成在idea内部了。假如我们做Java Web开发,需要配置Tomcat服务器。
1432 0
《精通Spring MVC 4》——1.8 嵌入式Servlet容器(Tomcat)的配置
可以将Spring Boot与Tomcat、tc-server、Jetty或者Undertow结合使用。服务器可以很容易地进行替换,只需将spring-boot-starter-tomcat JAR依赖移除掉,并将其替换为Jetty或Undertow对应的依赖即可。
2974 0
[原创]同一个Tomcat,配置多个context、多个Host
需求前提: 系统结束后,需要部署到服务器上。 目前只可以映射到一个固定IP的非80端口。 而server端和web端都要暴露到外网。 所以配置两个context,使得client应用不需要添加服务名,直接使用IP即可访问;server可以通过http://xxx/server进行访问。
1604 0
tomcat中关于websocket的性能优化配置
一、优化Connector http://www.aikaiyuan.com/8466.html tomcat的运行模式有3种 1)bio 默认的模式,性能非常低下,没有经过任何优化处理和支持. 2)nio 利用java的异步io护理技术,noblocking IO技术. 想运行在该模式下,直接修改server.xml里的Connector节点,修改protocol为 protocol=”org.apache.coyote.http11.Http11NioProtocol” 启动后,就可以生效。
2927 0
apache Tomcat 配置账户管理项目
介绍: 默认情况下我们会在tomcat中部署项目,一般情况我们会用eclipse 直接部署到tomcat进行调试,但是在正式的开发环境中会有很多不方便时候,项目有没有启动或者有没有假死的情况,更本不能判断到底项目有没有启动,那么我们就开配置一下tomcat用户名和密码,这样就可以登录tomcat后台,查看当前项目是否启动,并且可以管理启动和停止等等的操作功能 作用: 1、管理项目启动
1316 0
+关注
文章
问答
文章排行榜
最热
最新
相关电子书
更多
Apache Spark on Kubernetes
立即下载
《Apache RocketMQ 源码解析》
立即下载
Hive-Bucke in Apache Spark
立即下载