`

ubuntu apache tomcat负载均衡 , apache tomcat负载均衡 ,linux apache tomcat负载均衡

阅读更多

ubuntu下apache+tomcat+jk配置负载均衡

环境:

ubuntu 9.04

apache 2.2.11

tomcat 6.0.20

mod_jk mod_jk/1.2.26

负载均衡 ( Load Balance)

由于目前现有网络的各个核心部分随着业务量的提高,访问量和数据流量的快速增长,其处理能力和计算强度也相应地增大,使得单一的服务 器设备根本无法承担。在 此情况下,如果扔掉现有设备去做大量的硬件升级,这样将造成现有资源的浪费,而且如果再面临下一次业务量的提升时,这又将导致再一次硬件升级的高额成本投 入,甚至性能再卓越的设备也不能满足当前业务量增长的需求。

负载平衡:即把负载压力根据某种算法合理分配到集群中的每一台计算机上,以减轻主服务器的压力,降低对主服务器的硬件和软件要求。

 

目前比较常用的负载均衡技术主要有

  1. 基于DNS 的负载均衡

    通过DNS 服务中的随机名字解析来实现负载均衡,在DNS 服务器中,可以为多个不同的地址配置同一个名字,而最终查询这个名字的客户机将在解析这个名字 时得到其中一个地址。因此,对于同一个名字,不同的客户机会得到不同的地址,他们也就访问不同地址上的Web 服务器,从而达到负载均衡的目的

  2. 反向代理负载均衡 (如apache+JK2+Tomcatapache+proxy httpapache+proxy+ajp)

  使用代理服务器可以将请求转发给内部的Web 服 务器,让代理服务器将请求均匀地转发给多台内部Web 服务器之一 上,从而达到负载均衡的目的。这种代理方 式与普通的代理方式有所不同,标准代理方式是客户使用代理访问多个外部Web 服务器,而这种代理方式是多个客户使用它访问内部Web 服务器,因此也被称为 反向代理模式。

3. 基于NATNetwork Address Translation )的负载均衡技术 (如Linux Virtual Server ,简称LVS

网络地址转换为在内部地址和外部地址之间进行转换,以便具备内部地址的计算机能访问外部网络,而当外部网络中的计算机访问 地址转换网关拥有的某一外部地址 时,地址转换网关能将其转发到一个映射的内部地址上。因此如果地址转换网关能将每个连接均匀转换为不同的内部服务器地址,此后外部网络中的计算机就各自与 自己转换得到的地址上服务器进行通信,从而达到负载分担的目的。

 

 

 

下文主要描述apache+JK2+Tomcat

相比之下 jk2 http_proxy ajp_proxy 更稳定些,配置也更复杂一些

1 安装 apache 2tomcat

2 安装mod_jk

sudo apt-get install libapache2-mod-jk

查看一下在apache2 的启 动模块中是否有jk.load

$sudo ls /etc/apache2/mods-enabled/

3 配置

/etc/libapache2-mod-jk/workers.properties

 

worker.list = controller,tomcat1,tomcat2  #server 列表

#========tomcat1========

worker.tomcat1.port=8009         #ajp13 端口号,在tomcatserver.xml 配置, 默认8009
worker.tomcat1.host=localhost  #tomcat
的主机地址,如不为本机,请填写ip 地址
worker.tomcat1.type=ajp13
worker.tomcat1.lbfactor = 1   #server
的加权比重,值越高,分得的请求越多

#========tomcat2========

worker.tomcat2.port=8109       #ajp13 端口号,在tomcatserver.xml 配置, 默认8009
worker.tomcat2.host=localhost  #tomcat
的主机地址,如不为本机,请填写ip 地址
worker.tomcat2.type=ajp13
worker.tomcat2.lbfactor = 1   #server
的加权比重,值越高,分得的请求越多


#========controller,
负载均衡控制器========
worker.controller.type=lb
worker.controller.balanced_workers=tomcat1,tomcat2   #
指定分担请求的tomcat
worker.controller.sticky_session=1

 

对于业务系统

worker.controller.sticky_session_force=true 很必要

 

如果tomcat 配置不对jvmRoute

worker.controller.sticky_session_force=true

会出现访问不了系统

 

4 配置apache2.conf
/usr/share/doc/libapache2-mod-jk/httpd_example_apache2.conf
里的内容复制到 apache2.conf 的最后

# Sample mod_jk configuration

# for Apache 2

#

# for all commands/options available see the manual

# provided in libapache-mod-jk-doc package.

# The location where mod_jk will find the workers definitions

JkWorkersFile /etc/libapache2-mod-jk/workers.properties

# The location where mod_jk is going to place its log file

JkLogFile /var/log/apache2/mod_jk.log

# The log level:

# - info log will contain standard mod_jk activity (default).

# - warn log will contain non fatal error reports.

# - error log will contain also error reports.

# - debug log will contain all information on mod_jk activity

# - trace log will contain all tracing information on mod_jk activity

JkLogLevel info

# Assign specific URLs to Tomcat. In general the structure of a

# JkMount directive is: JkMount [URL prefix] [Worker name]

# send all requests ending in .jsp to ajp13_worker

JkMount /*.jsp controller

# send all requests ending /servlet to ajp13_worker

JkMount /*/servlet/ controller

# JkUnmount directive acts as an opposite to JkMount and blocks access

# to a particular URL. The purpose is to be able to filter out the

# particular content types from mounted context.

# do not send requests ending with .gif to ajp13_worker

#JkUnMount /servlet/*.gif controller

# JkMount / JkUnMount directives can also be used inside <VirtualHost>

# sections of your httpd.conf file.

5 修改 tomcat 配置文件 server.xml

如果你在不同电脑上安装tomcat,tomcat 的安装数量为一个,可以不必修改tomcat 配置文件

我这里是在同一台电脑上安装两个tomcat ,所以需要更改其中一个的设置

打开tomcat2/conf/server.xml 文 件

tomcat1

<Engine name="Catalina" defaultHost="localhost"> 修改为

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

 

tomcat2

<Engine name="Catalina" defaultHost="localhost"> 修改为

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

 

端口修改

<Server port="8005" shutdown="SHUTDOWN"> 修改为

<Server port="8105" shutdown="SHUTDOWN">

 

<Connector port="8080" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" URIEncoding="UTF-8" /> 修改为

<Connector port="8180" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" URIEncoding="UTF-8" />

 

 

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> 修改为

 

<Connector port="8109" protocol="AJP/1.3" redirectPort="8443" />

 

 

 

 

 

 

采用 proxy_http 的 配置
#httpd.conf(Apache
的配置文档,如果想了解Apache 相 关配置参数,请看参考文献)
#
载入重要的模块
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_http_module modules/mod_proxy_http.so
LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
#
设置负载均衡分配用的服务器
<Proxy balancer://apusicBalance>
    BalancerMember http://1.2.3.4:6888/ route=tomcat1 loadfactor=50
    BalancerMember http://1.2.3.5:6888/ route=tomcat2 loadfactor=50
</Proxy>
#
设置代理服务器转发方式,stickysession 就 是会话保持,JSESSIONID 就是Apusic 的会话IDnofailover 就是 说服务器没有做集群
ProxyPass / balancer://apusicBalance stickysession=JSESSIONID nofailover=On
ProxyPassReverse / balancer://apusicBalance

 

 

 

采用的是 ajp_proxy 的 配置。
 
其中 apache 的配置如下:

 # 引入ajp 模块

  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    


ProxyPass /test  balancer://mycluster stickysession=JSESSIONID

 

   BalancerMember ajp://localhost:8009/test route=tomcat1 loadfactor=50

   BalancerMember ajp://localhost:9009/test route=tomcat2 loadfactor=50

 

 

需要注意的几个地方

1 Session 黏性 需要tomcatserver.xml 配置

<Engine name="Catalina" defaultHost="localhost"> 修改为

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

这样在用户请求中 的sessionId 会是 uuid.tomcat1 70C011A23F79A154D8002FBFBABD4A82.tomcat1 这样就知道你请求上次请求到那个服务器。

2 测试JSP

 

<%@ page contentType="text/html; charset=UTF-8" %>

<%@ page import="java.util.*" %>

<html><head><title>Cluster App Test</title></head>

<body>

<%

System.out.println("SessionID:" + session.getId());

%>

Server Info:

<%

out.println(request.getServerName() + " : " + request.getServerPort()+"<br>");%>

<%

out.println("<br> ID " + session.getId()+"<br>"); // 如果有新的 Session 属性设置

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="index2.jsp" method="POST">

名称:<input type=text size=20 name="dataName">

<br>

数值:<input type=text size=20 name="dataValue">

<br>

<input type=submit>

</form>

</body>

</html>



信息来源:
发布时间: 2010-02-02

分享到:
评论

相关推荐

    ubuntu linux下apache与tomcat的整合.txt

    ### Ubuntu Linux 下 Apache 与 Tomcat 的整合 在 Ubuntu Linux 环境中,Apache 和 Tomcat 的整合是一项常见的任务,旨在实现静态内容通过 Apache 服务器进行高效分发,而动态内容(如 Java 应用)则通过 Tomcat ...

    Apache+tomcat实现负载均衡

    本篇文章将详细介绍如何使用Apache和Tomcat实现负载均衡。 负载均衡的核心思想是将来自用户的请求分发到多个服务器上,以避免单一服务器过载。在Apache与Tomcat的组合中,Apache通常作为前端负载均衡器,通过HTTP...

    Apache2.2和Tomcat7集成负载均衡(软件和教程)

    【Apache2.2和Tomcat7集成负载均衡】 在现代Web应用环境中,为了提供高可用性和性能优化,经常需要将HTTP服务器(如Apache)与应用服务器(如Tomcat)进行集成,并实现负载均衡。Apache2.2和Tomcat7的集成能够充分...

    Apache负载均衡

    在本场景中,我们关注的是Apache2.2与Tomcat7的集成,用于实现Web应用的负载均衡。Apache通常作为反向代理服务器,接收来自客户端的请求,并根据预设的策略将这些请求分发到后端的Tomcat应用服务器集群。 Apache的...

    nginx+tomcat实现负载均衡1

    在IT行业中,构建高效、可扩展的Web服务是至关重要的,而"nginx+tomcat实现负载均衡1"的主题就是探讨如何通过Nginx反向代理和Tomcat应用服务器结合,来提升系统的性能和稳定性。这一组合是业界常用的一种架构模式,...

    最新版linux apache-tomcat-10.0.0-M7.tar.gz

    在这个最新的Linux版本“apache-tomcat-10.0.0-M7.tar.gz”中,我们看到了Tomcat的第十个主要版本的预发布版。 Tomcat 10.0.0-M7是迈向10.0.0稳定版的一个中间里程碑,这个版本通常包含了新功能、性能改进以及bug...

    apache-tomcat-8.5.27.tar.gz

    在Linux环境下,这个版本的Tomcat可以无缝集成到各种Linux发行版中,如Ubuntu、CentOS或Debian。 部署Apache Tomcat 8.5.27的步骤如下: 1. **下载与解压**:首先从Apache官方网站下载"apache-tomcat-8.5.27.tar....

    apache-tomcat-9.0.22 linux centos ubuntu 安装包

    apache-tomcat-9.0.22 linux centos ubuntu 安装包apache-tomcat-9.0.22 linux centos ubuntu 安装包apache-tomcat-9.0.22 linux centos ubuntu 安装包apache-tomcat-9.0.22 linux centos ubuntu 安装包apache-...

    apache tomcat linux

    9. **负载均衡与集群**:在高流量环境中,可以使用Apache HTTPD或其它负载均衡器(如Nginx)实现Tomcat实例的负载均衡,以提升系统可用性和容错性。 10. **监控与故障排查**:使用工具如JMX(Java Management ...

    apache2.2+tomcat6.0负载均衡配置软件

    Apache 2.2 和 Tomcat 6.0 的负载均衡配置是提高Web应用程序性能和可扩展性的重要技术。在高流量环境下,通过将工作负载分散到多个Tomcat实例上,可以确保服务的稳定性和响应速度,同时避免单一服务器过载。下面我们...

    Apache 负载均衡的环境搭建 (使用Tomcat作为web server)

    在本场景中,我们将探讨如何在Apache上搭建一个负载均衡环境,利用它将请求分发到多个Tomcat实例,从而实现高可用性和性能优化。Tomcat是一款流行的Java Servlet容器,常用于部署Java Web应用。 **一、Apache ...

    基于Xen虚拟机实现Apache tomcat 集群搭建

    6. mod_jk的安装与配置:mod_jk是Apache的一个模块,用于连接Apache HTTP Server与Tomcat服务器,实现负载均衡功能。它通过AJP(Apache JServ Protocol)与Tomcat通信,分散客户端请求到不同的Tomcat实例上。 7. ...

    apache+tomcat整合配置

    如果需要更高可用性,可以将多个Tomcat实例配置成集群,通过Apache的mod_proxy_balancer模块进行负载均衡。这将提高服务的容错能力和扩展性。 8. **日志管理** 考虑将Apache和Tomcat的日志分开管理,以便更好地...

    ubuntu14.04用apache-tomcat-8.0.15.tar.gz

    在本场景中,我们关注的是在Ubuntu 14.04操作系统上安装和配置Apache Tomcat 8.0.15的过程。这个过程涉及到几个关键步骤,包括下载、解压、配置环境变量、启动服务以及进行基本的故障排查。 首先,我们需要从官方...

    ubuntu安装tomcat需要的jdk-8u221-linux-x64.tar.gz apache-tomcat-8.5.43.tar.gz

    在Ubuntu系统上安装Apache Tomcat通常需要先安装Java Development Kit (JDK)。在这个场景中,我们使用的是JDK 8u221的Linux 64位版本,即`jdk-8u221-linux-x64.tar.gz`。JDK是Java编程语言和Java平台标准版(Java SE...

    apache包和tomcat安装包(Linux系统)

    在Linux系统中,Apache HTTP Server和Tomcat是两个...通过上述步骤,你可以在Linux环境中成功安装并配置Apache和Tomcat。如果遇到问题,可以参考链接中的博客文章或在线社区寻求帮助。记得定期更新软件以保持安全性。

    ubuntu mysql apache2 tomcat 安装配置

    ubuntu mysql apache2 tomcat 安装配置

    ubuntu下安装tomcat

    在Ubuntu Linux系统下安装Tomcat是一项常见的任务,尤其对于那些希望在基于Linux的环境中部署Java Web应用程序的开发者来说。本文将详细阐述如何在Ubuntu下安装并配置Tomcat,包括必要的JDK安装步骤以及Tomcat环境...

    apache-tomcat-8.5.14.zip

    在Linux系统中部署Apache Tomcat 8.5.14,首先需要确保你的系统已经安装了Java Development Kit (JDK)。因为Tomcat需要JDK来编译和执行Java代码。你可以通过命令行检查JDK是否已安装,如果未安装,可以使用包管理器...

Global site tag (gtag.js) - Google Analytics