Apache和Tomcat整合(一个Apache 不同域名处理多个不同业务)
一、简介
在项目中,几乎任何一个项目都包括静态资源和动态请求两大部分。特别对于门户网站这样的项目,静态内容资源会更多,我们使用一般的 Tomcat 部署时,Tomcat 对静态资源的处理能力比较慢,至少比 Apache 要慢很多。
为了提高项目的访问速度,降低服务器负载提高性能,我们使用Apache来处理静态资源,把动态资源和请求交给 Tomcat 处理。
当然,在单纯处理并发和静态资源指标方面,Nginx要比Apache好,至于Nginx和Apache的具体区别,以及什么项目使用Nginx、什么项目适合用Apache,异或是使用Nginx加Apache一起使用…… 这个不是本文要探讨的范围,这两个开源项目各有优缺点,大家可以针对自己项目选择合适的方案。
本文就简单的对Apache和Tomcat如何集成,进行实际配置进行说明:
apache与tomcat负载集群集成方法有3种jk、jk_proxy、http_proxy
二、mod_proxy 和 mod_jk 的比较
那么什么时候使用哪一个呢?这依赖于你的架构。如果你已经有了或者需要apache 2.2的功能,那么你可以再mod_proxy和mod_jk直接选择。mod_jk在apache2.2上允许得很好。关键看你需要什么样的功能:
mod_proxy
--------------
优势:
不需要编译和维护一个对立的模块。mod_proxy,mod_proxy_http,mod_proxy_ajp,mod_proxy_balancer已经是apache 2.2+的标准集成部分;
可以使用http、https和AJP协议,即便是在同一个balancer中。
劣势:
mod_proxy_ajp不支持大于8k的数据包;
只有最基本的负载均衡器;
不支持域模型集群(domain model clustering)
mod_jk
--------------
优势:
先进的负载均衡器;
先进的节点失败侦察功能;
支持大型AJP 数据包
劣势:
需要单独维护一个独立的模块;
我个人建议是如果有能力维护mod_jk模块的二进制版本,尽量使用mod_jk。mod_proxy一直在更新但还缺少一些mod_jk的功能。但是,如果你需要https和一个简单的负载均衡就是用mod_proxy.
三、实践
1、下载安装 Apache (本文忽略)
2、下载安装 Tomcat (本文忽略)
3、下载 mod_jk 安装包
下载连接Apache和Tomcat(mod_jk) 的包 tomcat-connectors-1.2.41-src.tar.gz
官网下载地址:http://tomcat.apache.org/download-connectors.cgi
4、安装 mod_jk
5、配置Apache相关参数文件
1) 配置 mod_jk 模块
刚刚安装了mod_jk 模块,也已经拷贝到Apache的模块目录中,下面就是让Apache来支持它。
需要在Apache的conf目录下新建配置文件:
workers.properties #定义Tomcat工作的的配置文件
mod_jk.conf #定义mod_jk 的配置文件
# cd /usr/local/apache2/conf/
# vi mod_jk.conf
# vi workers.properties
<span style="font-size:12px;">#指定需要工作的tomcat节点,如多个用“,”分割
worker.list=worker_web,worker_wap
####################################################################
worker.worker_web.type=ajp13 #指定worker_web使用ajp13协议与Tomcat进程通讯
worker.worker_web.host=localhost #指定worker_web的位置,如果不是本机,就配置IP地址
worker.worker_web.port= #指定worker_web的工作端口
worker.worker_web.socket_keepalive= #此配置项为当Apache和Tomcat之间有防火墙时,让os每隔多久想未激活的连接发送KEEP_ALIVE信息,防止防火墙切断未激活的网络连接
worker.worker_web.socket_timeout= #指定worker_web上的连接在未激活的状况下持续多久,Apache将主动切断 ####################################################################
worker.worker_wap.type=ajp13
worker.worker_wap.host=localhost
worker.worker_wap.port=
worker.worker_wap.socket_keepalive=
worker.worker_wap.socket_timeout=</span>
2) 修改 Apache 的主配置文件 httpd.conf 配置多个虚拟主机
a) 找到 Include conf/extra/httpd-vhosts.conf 去掉前面的 “#”
b) vi conf/extra/httpd-vhosts.conf
<span style="font-size:12px;">########################################################
LoadModule jk_module modules/mod_jk.so
Include conf/mod_jk.conf
########################################################
<VirtualHost *:>
#ServerAdmin webmaster@dummy-host.example.com
DocumentRoot "/svcroot/runtime/webstatic/shanhyweb"
ServerName shanhyweb.example.com
#ServerAlias www.shanhyweb.example.com
ErrorLog "logs/shanhyweb-error_log"
CustomLog "logs/shanhyweb-access_log" common
<IfModule mod_jk.c>
#日志输出文件(其他配置也可以重写mod_jk.conf里面的配置)
JkLogFile logs/mod_jk_shanhyweb.log
#指URL指向如果有servlet,则让worker_web去处理
JkMount /servlet/* worker_web
#指URL为/*.jsp的页面,让worker_web去处理
JkMount /*.jsp worker_web
#指URL为/*.do的页面,让worker_web去处理
JkMount /*.do worker_web
#指URL为/*.json的页面,让worker_web去处理
JkMount /*.json worker_web
</IfModule>
<Directory "/svcroot/runtime/webstatic/shanhyweb">
Options FollowSymLinks
AllowOverride None
Require all granted
</Directory>
</VirtualHost> <VirtualHost *:80>
#ServerAdmin webmaster@dummy-host.example.com
DocumentRoot "/svcroot/runtime/webstatic/shanhywap"
ServerName shanhywap.example.com
#ServerAlias www.shanhywap.example.com
ErrorLog "logs/shanhywap-error_log"
CustomLog "logs/shanhywap-access_log" common
<IfModule mod_jk.c>
#日志输出文件(其他配置也可以重写mod_jk.conf里面的配置)
JkLogFile logs/mod_jk_shanhywap.log
#指URL指向如果有servlet,则让worker_wap去处理
JkMount /servlet/* worker_wap
#指URL为/*.jsp的页面,让worker_wap去处理
JkMount /*.jsp worker_wap
#指URL为/*.do的页面,让worker_wap去处理
JkMount /*.do worker_wap
#指URL为/*.json的页面,让worker_wap去处理
JkMount /*.json worker_wap
</IfModule>
<Directory "/svcroot/runtime/webstatic/shanhywap">
Options FollowSymLinks
AllowOverride None
Require all granted
</Directory>
</VirtualHost></span>
配置文件中 /svcroot/runtime/webstatic/shanhyweb 和 /svcroot/runtime/webstatic/shanhywap 分别为web和wap的静态资源目录
配置文件中 worker_web 和 worker_wap 为我们2个处理不同业务的 Tomcat
6、 配置web的Tomcat 和wap 的Tomcat
我在/app/webserver 目录下放了2个tomcat,分别是 apache-tomcat-7.0.63-wap 和 apache-tomcat-7.0.63-web
修改 apache-tomcat-7.0.63-wap/conf/server.xml 中的ajp 端口为8109,http端口为 8180,server 端口为8105
在 apache-tomcat-7.0.63-wap/conf/server.xml 的最下面的 </Host> 上面一行添加:
<Context path="" docBase="/svcroot/runtime/webinterface/shanhywap" reloadable="true" distributable="true"/>
在 apache-tomcat-7.0.63-web/conf/server.xml 的最下面的 </Host> 上面一行添加:
<Context path="" docBase="/svcroot/runtime/webinterface/shanhyweb" reloadable="true" distributable="true"/>
7、重启相关服务
重启Apache 服务,并启动web和wap的tomcat 服务。
8、测试
修改本机 C:\Windows\System32\drivers\etc 目录下的 hosts 文件,在最后添加:
192.168.19.130 shanhyweb.example.com
192.168.19.130 shanhywap.example.com
其中 192.168.19.130 为我们上面配置的Linux 服务的IP地址。
服务器上静态资源文件:
/svcroot/runtime/webstatic/shanhywap/index.html 内容为 This is my page. ShanhyWap-Static.
/svcroot/runtime/webstatic/shanhyweb/index.html 内容为 This is my page. ShanhyWeb-Static.
服务器上2个Tomcat 配置的项目中的 jsp 测试文件:
/svcroot/runtime/webinterface/shanhywap/test.jsp 内容为 ShanhyWap Content.
/svcroot/runtime/webinterface/shanhyweb/test.jsp 内容为 ShanhyWeb Content.
访问地址测试:
访问:http://shanhywap.example.com 后网页显示 This is my page. ShanhyWap-Static.
访问:http://shanhyweb.example.com 后网页显示 This is my page. ShanhyWeb-Static.
访问:http://shanhywap.example.com/test.jsp 后网页显示 ShanhyWap Content.
访问:http://shanhywap.example.com/test.jsp 后网页显示 ShanhyWeb Content.
9、相关文件
最后列出本问整合涉及到的相关文件目录位置:
apache 安装目录 /usr/local/apache2
apache 相关配置文件:
/usr/local/apache2/conf/httpd.conf
/usr/local/apache2/conf/mod_jk.conf
/usr/local/apache2/conf/workers.properties
/usr/local/apache2/conf/extra/httpd-vhosts.conf
webserver 的2个Tomcat 目录:
/app/webserver/apache-tomcat-7.0.63-wap
/app/webserver/apache-tomcat-7.0.63-web
webinterface 程序目录(2个Tomcat分别对应的项目工程) :
/svcroot/runtime/webinterface/shanhyweb
-- test.jsp
/svcroot/runtime/webinterface/shanhywap
-- test.jsp
webstatic 静态资源目录
/svcroot/runtime/webstatic/shanhyweb
-- index.html
/svcroot/runtime/webstatic/shanhywap
-- index.html
************************************************************************
题外话说一下我的目录归类,我的 /svcroot 目录目录结构如下:
/svcroot
-- runtime
-- standalone(存放Java程序)
-- webinterface(存放Tomcat对应的项目工程)
-- webstatic(存放项目工程的静态资源)
-- workspace
-- build(hudson custom 目录,SVN 代码)
-- shanhyweb-source
-- shanhywap-source
-- shanhyAndroid-source
-- dist(build编译后的文件目录,待发布)
-- logs(项目相关logs)
--------------------------
(完)
转载地址:http://blog.csdn.net/catoop/article/details/47974773
访问:http://shanhywap.example.com 后网页显示 This is my page. ShanhyWap-Static.
访问:http://shanhyweb.example.com 后网页显示 This is my page. ShanhyWeb-Static.
Apache和Tomcat整合(一个Apache 不同域名处理多个不同业务)的更多相关文章
- Apache与Tomcat整合
Apache与Tomcat整合 一 Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache ...
- Apache与Tomcat整合(转)
一 Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache只是作为一个转发,对jsp的处理是由 ...
- [WebServer] Linux下Apache与Tomcat整合的简单方法
Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache只是作为一个转发,对jsp的处理是由to ...
- linux下apache和tomcat整合
一 Apache与Tomcat比较联系 apache支持静态页,tomcat支持动态的,比如servlet等. 一般使用apache+tomcat的话,apache只是作为一个转发,对jsp的处理是由 ...
- Apache 与 Tomcat 整合
目标 1.同一台机器上,不同的域名指向,访问不同的项目,即: (1)one.test.com 访问 project_one (2) two.test.com 访问 project_two 2.将T ...
- debian下Apache和tomcat整合(使用apt工具)
最近部署web系统,需要使用tomcat处理和Apache整合使用,tomcat处理JSP,Apache处理静态资源.开始不知道怎么操作,在网上查阅资料走了很多弯路.完成时候,发现其实很简单,现将配置 ...
- apache 和 php 整合、apache配制虚拟机
如何 把apache 和 php 整合起来 ? (关闭防火墙或在防火墙内添加80端口,关闭selinux) 修改:apache的配制文件:/usr/local/apache2.4/conf/h ...
- Apache与Tomcat整合的配置
下载jk连接器地址:http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/windows/ 把jk连接器即“mod_j ...
- windows平台整合Apache与tomcat
Apache与Tomcat整合的好处 Apache主要用来解析静态文本,如html.Tomcat虽然也有此功能,但Apache效率大大高于Tomcat,尤其是对于并发数较大的企业级应用,能更好的显示A ...
随机推荐
- 【Conclusion】MySQL使用
MySQL使用 因为数据库实验用到了MySQL,这里对现在已经涉及到的MySQL部分操作做一个简单的小结. 1.安装MySQL 上MySQL的官网下载对应自己OS平台的MySQL安装文件,有在线安装和 ...
- java实现excel和数据的交互
1. 环境要求 本文环境为: 数据库为oracle,jdk为jdk7,依赖jar包为ojdbc6-11.2.0.4.0.jar+poi-3.14.jar 2.POI 使用 1. 建立工作空间 2. 获 ...
- ACM学习之路___HDU 2066 一个人的旅行
Description 虽然草儿是个路痴(就是在杭电待了一年多,居然还会在校园里迷路的人,汗~),但是草儿仍然很喜欢旅行,因为在旅途中 会遇见很多人(白马王子,^0^),很多事,还能丰富自己的阅历,还 ...
- 学习率 Learning Rate
本文从梯度学习算法的角度中看学习率对于学习算法性能的影响,以及介绍如何调整学习率的一般经验和技巧. 在机器学习中,监督式学习(Supervised Learning)通过定义一个模型,并根据训练集上的 ...
- windows7下MongoDB(V3.4)的使用及仓储设计
简单的介绍一下,我使用MongoDB的场景. 我们现在的物联网环境下,有部分数据,采样频率为2000条记录/分钟,这样下来一天24*60*2000=2880000约等于300万条数据,以后必然还会增加 ...
- Temperature hdu 3477
Temperature Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- 1042 数字0-9的数量 1050 循环数组最大子段和 1062 序列中最大的数 1067 Bash游戏 V2 1092 回文字符串
1042 数字0-9的数量 基准时间限制:1 秒 空间限制:131072 KB 分值: 10 难度:2级算法题 给出一段区间a-b,统计这个区间内0-9出现的次数. 比如 10-19,1出现11次 ...
- 管中窥豹——从OVS看SDN
网络虚拟化是当前云计算最重要的特点之一,打通租户网络之间互通以及访问控制策略,最重要的是满足租户之间的网络隔离,这才是云计算网络的特点.而SDN的产生则是在网络虚拟化中,将控制面和业务面分离,控制面只 ...
- 【转】Python实现修改Windows CMD命令行输出颜色(完全解析)
用Python写命令行程序的时候,单一的输出颜色太单调.其实我们可以加些色彩,比如用红色表示警告,绿色表示结果正常等.网上也有几篇类似的帖子,但是没有把问题讲清楚,贴的代码也不是太清晰.这里,对Win ...
- ZOJ2345Gold Coins 简单分块
昨天做过一样的题: 平方和公式:n*(n+1)*(2n+1) #include<cstdio> #include<cstdlib> #include<iostream&g ...