设为首页 收藏本站
查看: 726|回复: 0

[经验分享] Apache + Tomcat 负载均衡与集群配置

[复制链接]

尚未签到

发表于 2017-1-6 08:33:23 | 显示全部楼层 |阅读模式
Apache + Tomcat 负载均衡与集群配置
-------------------------------------
1. 准备
下载 Apache Http Server
http://labs.renren.com/apache-mirror//httpd/binaries/win32/httpd-2.2.19-win32-x86-no_ssl.msi
下载 Tomcat
http://apache.etoak.com/tomcat/tomcat-6/v6.0.32/bin/apache-tomcat-6.0.32-windows-x86.zip
2. 安装 Apache Http Server
安装完成后, 配置 conf/httpd.conf
2.1 配置HTTP端口:
Listen 80

2.2 配置负载均衡, 去掉注释符#:

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
LoadModule proxy_scgi_module modules/mod_proxy_scgi.so


2.3 配置虚拟主机, 去掉注释符#:
Include conf/extra/httpd-vhosts.conf
2.3 配置首页
<IfModule dir_module>
DirectoryIndex index.htm index.html index.jsp
</IfModule>

2.4 配置负载均衡, 在最后面加上:

ProxyRequests Off
<proxy balancer://cluster>
BalancerMember ajp://127.0.0.1:8009 loadfactor=1 route=tomcat1
BalancerMember ajp://127.0.0.1:9009 loadfactor=1 route=tomcat2
ProxySet lbmethod=byrequests timeout=15
</proxy>


2.5 配置 conf/extra/httpd-vhosts.conf
2.5.1 注释所有虚拟主机节点:
2.5.2 添加虚拟主机, 注意格式:

<VirtualHost *:80>
ServerAdmin amos_tl@126.com
ServerName localhost
ServerAlias localhost
ProxyPass / balancer://cluster/ stickysession=JSESSIONID|jsessionid nofailover=Off
ProxyPassReverse / balancer://cluster/
</VirtualHost>


3. 安装 Tomcat
解压后, 将目录取名 tomcat1, 再复制一份取名tomcat2.
3.1 配置tomcat1:
配置 tomcat1/conf/server.xml
3.1.1 配置负载均衡路由, 增加 jvmRoute="tomcat1" :

<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat1">

3.1.2 配置集群, 去掉集群节点的注释符
3.1.3 配置端口, 去掉注释符:

<!-- See proxy documentation for more information about using this. -->
<Connector port="8082"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" acceptCount="100" connectionTimeout="20000"
proxyPort="80" disableUploadTimeout="true" />


3.2 配置tomcat2:
配置 tomcat2/conf/server.xml
3.2.1 配置负载均衡路由, 增加 jvmRoute="tomcat2" :

<Engine name="Catalina" defaultHost="localhost" jvmRoute="tomcat2">

3.2.2 配置集群, 去掉集群节点的注释符, 修改Cluster|Receiver|tcpListenPort为4002.

<Receiver
className="org.apache.catalina.cluster.tcp.ReplicationListener"
tcpListenAddress="auto"
tcpListenPort="4002"
tcpSelectorTimeout="100"
tcpThreadCount="6"/>


3.2.3 修改相关端口,避免与tomcat1 端口冲突:

<Server port="9005" shutdown="SHUTDOWN">
<!-- Define a non-SSL HTTP/1.1 Connector on port 8080 -->
<Connector port="9080" maxHttpHeaderSize="8192"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" />
<!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="9009"
enableLookups="false" redirectPort="9443" protocol="AJP/1.3" />
<!-- Define a Proxied HTTP/1.1 Connector on port 8082 -->
<!-- See proxy documentation for more information about using this. -->
<Connector port="9082"
maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
enableLookups="false" acceptCount="100" connectionTimeout="20000"
proxyPort="80" disableUploadTimeout="true" />


4. ADSL 用户, 断开ADSL连接
5. 部署测试应用 到 tomcat1, tomcat2 webapps目录:
5.1 test.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<%@ page import="java.util.Enumeration, java.util.Date" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>负载均衡</title>
</head>
<body>
Server Info:
<%
out.println(request.getLocalAddr() + " : " + request.getLocalPort()+"<br>");
%>
<%
out.println("<br> ID " + session.getId()+"<br>");
String dataName = request.getParameter("dataName");
if (dataName != null && dataName.length() > 0)
{
String dataValue = request.getParameter("dataValue");
session.setAttribute(dataName, dataValue);
}  
out.print("<b>Session 列表</b><br />");  
Enumeration e = session.getAttributeNames();
while (e.hasMoreElements())
{
String name = (String)e.nextElement();
String value = session.getAttribute(name).toString();
out.println( name + " = " + value+"<br>");
System.out.println( name + " = " + value);
}
%>
<form action="test.jsp" method="POST">
名称:<input type=text size=20 name="dataName">
<br />
值:<input type=text size=20 name="dataValue">
<br />
<input type=submit>
</form>
<%
System.out.println(new Date());
%>
</body>
</html>



5.2 配置应用 WEB-INF/web.xml, 增加<distributable />
web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID" version="2.5">
<display-name>cluster</display-name>
<distributable />
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
</web-app>


6. 测试
3.1 启动tomcat1, tomcat2, 然后启动apache.
6.2 打开测试页面:
http://localhost/cluster/test.jsp
6.3
输入aa aa 提交
输入bb bb 提交
输入cc cc 提交
输入dd dd 提交
输入ee ee 提交
输入ff ff 提交
结果:
DSC0000.bmp

可以看到, 请求分别轮流由tomcat1, tomcat2处理, 负载均衡成功,同时session 进行了复制,说明集群配置成功.

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-324465-1-1.html 上篇帖子: Apache + Tomcat集群配置详解(2) 下篇帖子: (转)Apache_Commons_DbUtils_快速上手
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表