Apache负载均衡与Tomcat集群配置学习(Windows环境)

最后的话

无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!

部分截图:
在这里插入图片描述

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

4、安装Apache,目标盘符:D:\Program Files\Apache Software Foundation\Apache2.2,默认端口80。

注:1、有些大牛的文章说,在安装的时候如果IIS处于运行状态,则安装可能不会成功,强调关闭IIS服务,本人安装过程中,IIS一直处于运行状态,但是安装成功了,估计可能跟版本有关吧;

2、打开http:10.10.141.40进行测试,如果能看到一个"It works!",证明安装成功。

三、Apache+JK+Tomcat集群配置

1、Apache----2.2.22版本已经集成了mod_jk功能,故不必配置繁琐的worker.properties文件什么的,配置过程很方便了。

2、利用编辑器打开D:\Program Files\Apache Software Foundation\Apache2.2\conf\httpd.conf文件,找到如下代理块(proxy):

#LoadModule proxy_module modules/mod_proxy.so

#LoadModule proxy_ajp_module modules/mod_proxy_ajp.so

#LoadModule proxy_balancer_module modules/mod_proxy_balancer.so

#LoadModule proxy_connect_module modules/mod_proxy_connect.so

#LoadModule proxy_ftp_module modules/mod_proxy_ftp.so

#LoadModule proxy_http_module modules/mod_proxy_http.so

3、去掉这些代理块的注释“#”符号,Apache在启动的过程中将加载上述代理(proxy)。

4、找到#Include conf/extra/httpd-vhosts.conf位置,并去掉“#”符号,结束后关闭httpd.conf文件。

5、利用编辑器打开D:\Program Files\Apache Software Foundation\Apache2.2\conf\extra\httpd-vhosts.conf文件,配置虚拟站点,在文件结束添加

<VirtualHost *:80>

ServerAdmin 管理员邮箱

ServerName 域名(没有可用IP地址代替)

ServerAlias localhost

ProxyPass / balancer://cluster/ stickysession=JSESSIONID(大写很重要) nofailover=On

ProxyPassReverse / balancer://cluster/

ErrorLog “logs/lbtest-error.log”

CustomLog “logs/lbtest-access.log” common

本人的配置实例:

<VirtualHost *:80>

ServerAdmin limingzhong1985@gmail.com

ServerName 10.10.141.40                   ServerAlias localhost

ProxyPass / balancer://cluster/ stickysession=jsessionid nofailover=On

ProxyPassReverse / balancer://cluster/

ErrorLog “log/error.log”

CustomLog “log/access.log” common

注:1、balancer://是告诉Apache需要进行负载均衡的代理;

2、后面的cluster是集群名,可以随意取;

3、两个日志引擎ErrorLog负责记 录错误,CustomLog负责记录所有的http访问以及返回状态,日志名可以自己取。

6、再次打开D:\Program Files\Apache Software Foundation\Apache2.2\conf\httpd.conf,文件结束处添加如下代码:

ProxyRequests Off

<proxy balancer://cluster>

BalancerMember ajp://10.10.141.39:8009 loadfactor=1 route=jvm1

BalancerMember ajp://10.10.141.40:8009 loadfactor=1 route=jvm2

注:1、ProxyRequests Off 是告诉Apache需要使用反向代理;

2、<proxy balancer://cluster>用于配置工作在集群中的节点列表,这里的“cluster”必须与上面的集群名保持一致;

3、Apache通过ajp协议与tomcat进行通信,ip地址和端口唯一确定了tomcat节点和配置的ajp接受端口;

4、loadfactor是负载因 子,Apache会按负载因子的比例向后端tomcat节点转发请求,负载因子越大,对应的tomcat服务器就会处理越多的请求,如两个tomcat都 是1,Apache就按1:1的比例转发,如果是2和1就按2:1的比例转发;

5、route参数对应后续tomcat配置中的引擎路径 (jvmRoute)。

7、重新启动Apache服务,在浏览器中访问:http:10.10.141.40,你会发现得到了一个503的错误,内容如下:

Service Temporarily Unavailable

The server is temporarily unable to service your request due to maintenance downtime orcapacityproblems. Please try again later

打开刚刚配置的错误文件,我们会发现如下信息:

[Mon Jun 18 17:59:16 2012] [error] (OS 10061)由于目标机器积极拒绝,无法连接。  : proxy: AJP: attempt to connect to 10.10.141.40:8009 (10.10.141.40) failed

[Mon Jun 18 17:59:16 2012] [error] ap_proxy_connect_backend disabling worker for (10.10.141.40)

[Mon Jun 18 17:59:16 2012] [error] proxy: AJP: failed to make connection to backend: 10.10.141.40

[Mon Jun 18 17:59:23 2012] [error] (OS 10060)由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败。

: proxy: AJP: attempt to connect  to 10.10.141.39:8009 (10.10.141.39) failed

[Mon Jun 18 17:59:23 2012] [error] ap_proxy_connect_backend disabling worker for (10.10.141.39)

[Mon Jun 18 17:59:23 2012] [error] proxy: AJP: failed to make connection to backend: 10.10.141.39

从上面的信息我们可以知道:连接 10.10.141.40 和 10.10.141.39 两台服务器失败,原因是还没有启动Tomcat造成的。

8、配置Tomcat----server.xml文件

8.1、如果是2个Tomcat处于不同的机器上,就不需要修改任何端口;只是需要把注释符放开,同时将注释掉;

8.2、对于10.10.141.40的机器,将改为,怎么知道要改成这样呢,看下面的配置:

ProxyRequests Off

<proxy balancer://cluster>

BalancerMember ajp://10.10.141.39:8009 loadfactor=1 route=jvm1

BalancerMember ajp://10.10.141.40:8009 loadfactor=1 route=jvm2

在我的配置中,10.10.141.40对应的是:route=jvm2 ;

注:jvmRoute对应Apache httpd.conf中BalancerMember中配置的route参数。        8.3、对于Tomcat安装在同一台机器上的情况,则需要做端口修改工作,同时上面的配置可以修改为如下情形:

ProxyRequests Off

<proxy balancer://cluster>

BalancerMember ajp://localhost:8009loadfactor=1 route=jvm1

BalancerMember ajp://localhost:9009loadfactor=1 route=jvm2

接下来修改<Connector port=“8009” protocol=“AJP/1.3” redirectPort=“8443” />,将jvm2对应的Tomcat配置修改为<Connector port=“9009” protocol=“AJP/1.3” redirectPort=“8443” />。

注:端口对应 Apache httpd.conf中BalancerMember中配置的ajp连接端口。

8.4、将的注释放开,目的是可以在集群中的所有tomcat节点间共享会话(Session)。

8.5、配置Connector的端口,把jvm2设置为在9080端口侦听,保证2个Tomcat的监听端口的不同。

8.6、server.xml文件配置完毕后,我们放入一个简单的java项目应用测试,两个目的:

a:测试session信息是否丢失,即同一个请求在不同刷新过程中是否改变,如果改变则配置失败,反之配置成功;

b:测试session是否在集群中的各个节点中成功复制,复制成功则才能实现集群的目的:负载均衡;                 在此引用一个网络上的测试session的例子:

在每个Tomcat的webapps目录下新建test目录,在test目录下新建test.jsp文件,代码如下:

[java]  view plain copy print ? 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传 外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  1. <%@ page contentType=“text/html; charset=GBK” %>

  2. <%@ page import=“java.util.*” %>

  3. Cluster App Test

  4. Server Info:

  5. <%

  6. out.println(request.getLocalAddr() + " : " + request.getLocalPort()+“
    ”);%>

  7. <%

  8. out.println(“
     ID " + session.getId()+”
    ");

  9. String dataName = request.getParameter(“dataName”);

  10. if (dataName != null && dataName.length() > 0) {

  11. String dataValue = request.getParameter(“dataValue”);

  12. session.setAttribute(dataName, dataValue);

  13. }

  14. out.print(“Session 列表”);

  15. Enumeration e = session.getAttributeNames();

  16. while (e.hasMoreElements()) {

  17. String name = (String)e.nextElement();

  18. String value = session.getAttribute(name).toString();

  19. out.println( name + " = " + value+“
    ”);

  20. System.out.println( name + " = " + value);

  21. }

  22. %>

  23. <form action=“test.jsp” method=“POST”>

  24. 名称:<input type=text size=20 name=“dataName”>


最后

看完上述知识点如果你深感Java基础不够扎实,或者刷题刷的不够、知识不全面

小编专门为你量身定制了一套<Java一线大厂高岗面试题解析合集:JAVA基础-中级-高级面试+SSM框架+分布式+性能调优+微服务+并发编程+网络+设计模式+数据结构与算法>

image

针对知识面不够,也莫慌!还有一整套的<Java核心进阶手册>,可以瞬间查漏补缺

image

全都是一丢一丢的收集整理纯手打出来的

更有纯手绘的各大知识体系大纲,可供梳理:Java筑基、MySQL、Redis、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~

image

image

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

更有纯手绘的各大知识体系大纲,可供梳理:Java筑基、MySQL、Redis、并发编程、Spring、分布式高性能架构知识、微服务架构知识、开源框架知识点等等的xmind手绘图~

[外链图片转存中…(img-EMFR9E97-1715810763831)]

[外链图片转存中…(img-1AG68KOf-1715810763831)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 22
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值