windows环境下JSP环境搭建:Apache2.4+tomcat8.0动静分离,负载均衡

【第一种连接方式:mod_jk】

一、首先说明一下什么是mod_jk?

Apache自身是用来加载静态页面的,如果要加载动态页面比如jsp,还要做与Tomcat的整合,mod_jk就是整合Apache2.4与Tomcat的连接器。三者关系如下:

**Apache:**这里指的是httpd,Web服务器,用来处理静态文件。

**tomcat:**应用服务器,是servlet、jsp(jsp在后面其实也是被解释成servlet)的运行容器,可以处理servlet、jsp这些动态文件,当然也可以处理静态文件,但是性能不如Apache、nginx这些web服务器性能好。虽然一般还是单独使用web服务器来处理静态文件,应用服务器处理动态文件。

**mod_jk:**是tomcat提供的、用来连接Apache与tomcat的一个插件,默认下载的tomcat中是没有的,需要单独下载。

二、mod_jk的下载地址 

http://archive.apache.org/dist/tomcat/tomcat-connectors/jk/binaries/windows/

选择合适的版本,Apache2.4就选择如下图所示:

三、JK的配置最关键的三个文件:

  1. httpd.conf:Apache服务器的配置文件,用来加载JK模块以及指定JK配置文件信息
  2. workers.properties :到Tomcat服务器的连接定义文件
  3. uriworkermap.properties:URI映射文件,用来指定哪些URL由Tomcat处理,你也可以直接在httpd.conf中配置这些URI,但是独立这些配置的好处是JK模块会定期更新该文件的内容,使得我们修改配置的时候无需重新启动Apache服务器。

四、配置Apache2.4与Tomcat的连接

1、将下载的mod_jk.so文件放到Apache24\modules目录下。

2、打开Apache24\conf\httpd.conf,在最后一行加入下方代码:

1# 加载mod_jk模块 2LoadModule jk_module modules/mod_jk.so 3 4# 指定tomcat监听配置文件地址(加载集群中的workers) 5JkWorkersFile conf/workers.properties 6JkMountFile conf/uriworkermap.properties 7 8# 指定日志存放位置 9JkLogFile logs/mod_jk.log 10JkLogLevel warn 11 12#指定哪些请求交给tomcat处理,"DLOG4J"为在 workers.propertise里指定的负载分配控制器名 所有的请求都交给 control 13JkMount /*.* DLOG4J 14

3、在Apache24\conf\目录下新建两个文件分别是 workers.properties、uriworkermap.properties。这两个文件的内容大概如下:

workers.properties

1# 2# 1.首先我们配置了两个类型为ajp13的worker分别是s1和s2,它们指向同一台服务器上运行在两个不同端口8109和8209的Tomcat上。 3# 2.接下来我们配置了一个类型为lb(也就是负载均衡的意思)的worker,它的名字是DLOG4J,这是一个逻辑的worker,它用来管理前面配置的两个物理连接s1和s2。 4# 3.最后还配置了一个类型为status的worker,这是用来监控JK本身的模块。有了这三个worker还不够,我们还需要告诉JK,哪些worker是可用的,所以就有worker.list = DLOG4J, status 这行配置。 5# 6 7# list the workers by name 8 9worker.list=DLOG4J, status 10 11# localhost server 1 12# ------------------------ 13worker.tomcat1.port=8109 14worker.tomcat1.host=localhost 15worker.tomcat1.type=ajp13 16 17# localhost server 2 18# ------------------------ 19worker.tomcat2.port=8209 20worker.tomcat2.host=localhost 21worker.tomcat2.type=ajp13 22worker.tomcat2.stopped=1 23 24#负载均衡分发控制器(server名为DLOG4J,用于负载均衡) 25worker.DLOG4J.type=lb 26#重试次数 27worker.retries=3 28worker.DLOG4J.balanced_workers=tomcat1, tomcat2 29#粘性Session(默认是打开的) 当该属性值=True(或1)时,代表Session是粘性的, 即session粘着。若设置true,则同一个浏览器的请求(cookie相同)将会被分发到同一个tomcat(节点) 30#即同一Session在集群中的同一个节点上处理,Session不跨越节点。在集群环境中,一般将该值设置为False 31worker.DLOG4J.sticky_session=1 32 33worker.status.type=status 34

uriworkermap.properties 

1# 指定哪些链接是由Tomcat处理的,哪些是由Apache直接处理的 2# 所有的请求都由DLOG4J这个worker进行处理,但是有几个例外,/jkstatus请求由status这个worker处理。 3# 另外这个配置中每一行数据前面的感叹号表示接下来的URI不要由JK进行处理,也就是Apache直接处理所有的图片、css文件、js文件以及静态html文本文件。 4 5/*=DLOG4J 6/jkstatus=status 7 8!/*.gif=DLOG4J 9!/*.jpg=DLOG4J 10!/*.png=DLOG4J 11!/*.css=DLOG4J 12!/*.js=DLOG4J 13!/*.htm=DLOG4J 14!/*.html=DLOG4J 15

4、Tomcat 8.0/conf/server.xml添加站点host,代码如下:

1<Host name="www.456.com" appBase="webapps" unpackWARs="true" autoDeploy="true"> 2 <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" 3 prefix="localhost_access_log." suffix=".txt" 4 pattern="%h %l %u %t "%r" %s %b" /> 5 <Alias>456.com</Alias> 6 <Context docBase="D:\wwwroot" path=""></Context> 7</Host> 8

5、Tomcat配置文件Service.xml主要注意两个地方,一个是Engine节点需要增加节点标识jvmRoute,另一个是把Cluster节点的注释去掉,具体如下:

1<!--jvmRoute在各个Tomcat配置中不能重复且要与worker.properties文件中的名称一致--> 2<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1"> 3<!--把Cluster节点的注释去掉,表示打开session--> 4<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/> 5

6、Tomcat 8.0/conf目录下,web.xml 最后增加 一句:

1<!--允许该tomcat实行session的复制黏贴--> 2<distributable/> 3

7、以上配置ok后,直接运行Apache和Tomcat 8.0即可

8、apache无法启动报错: The request operation has failed ,进入Apache24\bin目录下,使用cmd命令输入:httpd -t,会显示报错原因,如下:

【第二种连接方式:http_proxy】 

利用Apache自带的mod_proxy模块使用代理技术来连接Tomcat。在配置之前请确保是否使用的是2.2.x版本以上的Apache服务器。因为2.2.x以上版本对这个模块进行了重写,大大的增强了其功能和稳定性。

(1)、Apache24\conf\httpd.conf加载以下模块(把前面的#号去掉)

1LoadModuleproxy_module modules/mod_proxy.so 2LoadModuleproxy_http_module modules/mod_proxy_http.so 3LoadModule rewrite_module modules/mod_rewrite.so 4LoadModule proxy_connect_module modules/mod_proxy_connect.so 5LoadModule proxy_balancer_module modules/mod_proxy_balancer.so 6LoadModule slotmem_shm_module modules/mod_slotmem_shm.so 7

(2)、**Apache24\conf\extra\httpd-vhosts.conf 文件里,配置ProxyPass **

1<VirtualHost *:88> 2 # 邮箱地址 3 ServerAdmin admin@qq.com 4 # 网站所在目录 5 DocumentRoot "D:\wwwroot" 6 # 网站域名 7 ServerName www.456.com 8 ServerAlias 456.com 9 # 日志地址 10 ErrorLog "logs/456.com-error.log" 11 CustomLog "logs/456.com.log" common 12 # 转发地址 13 ProxyPass / http://www.456.com:8090/ 14 ProxyPassReverse / http://456.com:8090/ 15</VirtualHost> 16

(3)、Tomcat 8.0/conf/server.xml添加站点host,代码如下:

1<Host name="www.456.com" appBase="webapps" unpackWARs="true" autoDeploy="true"> 2 <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs" 3 prefix="localhost_access_log." suffix=".txt" 4 pattern="%h %l %u %t "%r" %s %b" /> 5 <Alias>456.com</Alias> 6 <Context docBase="D:\wwwroot" path=""></Context> 7</Host> 8

 (4)、配置好之后,直接运行Apache和Tomcat 8.0就可以了。

代码交流 2021