一、环境说明

在一台服务器上安装一个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.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配置中端口信息

转载于:https://blog.51cto.com/wangxiaoqiang/1355308

apache+tomcat小记相关推荐

  1. Apache Tomcat 7.0.93 发布,开源 Java Web 应用服务器

    Apache Tomcat 7.0.93 已发布,Tomcat 是 Java Servlet.JavaServer Pages.Java 表达式语言和 Java WebSocket 技术的开源实现,是 ...

  2. apache+tomcat 搭建负载均衡系统

    apache+tomcat+mod_jk 搭建负载均衡系统. 0.os系统采用centos6.8 x64 2.6.32-642.el6.x86_64 1.首先安装好jdk环境本次采用jdk-8u111 ...

  3. Apache Tomcat 7.x 概述

    前言 Tomcat 一直是Java web程序的首选应用服务器,现在已经更新到7.x版本了.如果你还使用老版本,那么你赶快更新到最新版本吧,他改善了不性能,修复了很多BUG.下面我从官网,简单翻译了一 ...

  4. org.apache.tomcat.util.bcel.classfile.ClassFormatException: Invalid byte tag in constant pool: 19

    启动项目: 问题描述 严重: Unable to process Jar entry [module-info.class] from Jar [jar:file:/D:/.m2/myboot/org ...

  5. Target runtime Apache Tomcat 6.0 is not defined

    在problems中显示错误是:Target runtime Apache Tomcat 6.0 is not defined. 在网上查了一下终于找到解决方法.方法是:在工程目录下的.setting ...

  6. 在Linux下进行Apache+tomcat整合

    今天为大家介绍如何在Linux下进行Apache+tomcat整合,虚拟机版本是Redhat5,ip地址为192.168.1.12,实验步骤如下: 一 安装Jdk 二 安装Apache 三 安装tom ...

  7. Linux下Apache+Tomcat 负载均衡

    众所周知,Apache处理动态页面的能力非常稳定,而且由于apache发展早,社区活跃,Linux SA青睐使用Apache来均衡Tomcat,处理JSP动态语言. 而我们熟知的Nginx Web服务 ...

  8. Apache + Tomcat 负载均衡 session复制

    转自:http://blog.csdn.net/cssmhyl/article/details/8455400 http://snowolf.iteye.com/blog/743611 Apache  ...

  9. confluence中org.apache.tomcat.util.net.NioEndpoint$Acceptor.run Socket accept failed的解决方法

    confluence中org.apache.tomcat.util.net.NioEndpoint$Acceptor.run Socket accept failed的解决方法 参考文章: (1)co ...

最新文章

  1. 零基础linux安装hadoop步骤,hadoop的Linux下简单安装步骤
  2. OpenCV 图像加载和显示
  3. Windows下Socket库的初始化和关闭
  4. VTK:几何对象之TextActor
  5. 雷死人不偿命-----六年级小学生的字条
  6. KnowIME: A System to Construct a Knowledge Graph for Intelligent Manufacturing Equipment-学习笔记
  7. 详解varint编码原理
  8. 最长回文串之中心扩散法
  9. libz.so.1: cannot open shared object file: No such file or directory
  10. (顺序表的应用5.4.2)POJ 1591 M*A*S*H(约瑟夫环问题的变形——变换步长值)
  11. ps3本服务器维修中,PS3大拆解图文详解!降低成本为目的
  12. php源码安装教程宝塔,宝塔版-源码安装教程
  13. 微博开放平台-发微博测试
  14. C++开发 一个壁纸小软件
  15. 你可能不知道,Diffusion现在有多火
  16. 如何看待阿里云成立新零售事业部?
  17. 手机屏幕取词翻译软件哪个比较好?快看这篇文章,它能告诉你
  18. 数据的导出Excel表
  19. 程序 卡塔_我想念微软恩卡塔
  20. Springboot 自定义全局异常处理

热门文章

  1. java属性绑定_java基础:10.1 Java FX与属性绑定
  2. mysql显示表已存在_「Docker系列」 如何在Docker中部署MySQL数据库?
  3. gtp怎么安装系统_UEFI+GTP模式下使用GHO文件安装WIN7或WIN8图文教程
  4. python系统信息_Python获得操作系统信息
  5. R语言 神经网络与深度学习(二)
  6. 91年转行前端开发,是不是不该转,有啥风险?
  7. 动态调整linux分区大小,GParted 动态调整Linux分区大小
  8. maven java jar_如何去maven仓库下载jar包
  9. python中math函数库矩阵_Python中矩阵库Numpy基本操作详解
  10. 计算机英语 TCP IP什意思,TCP/IP是什么意思?