Apache tomcat 负载平衡配置

2024-02-18 22:38

本文主要是介绍Apache tomcat 负载平衡配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以前做企业应用的时候,都只用tomcat部署项目,从没接触过apache,apache在脑海里只是个战斗机的名称。


现在做网站,网站的部署是用apache + tomcat来实现的。自然而然也慢慢了解了apache,上次迁移网站的服务器,装过一


次apache,就简单的configure , make ,make install 三步曲搞定,配置文件都用的以前服务器上apache的,至于那些配


置是啥子含义,完全不懂。最近网站出了问题,问题出在apache身上,所以花了点时间来了解apache 和tomcat的配置。


“整合 Apache Http Server 和 Tomcat 可以提升对静态文件的处理性能、利用 Web 服务器来做负载均衡以及容错、无缝


的升级应用程序。本文介绍了三种整合 Apache 和 Tomcat 的方式。”  这句话概括了为啥要用apache的原因。简单的说就


是把一些静态资源给apache处理,比如:css,html, images。 而动态的东西通过apache转给tomcat来处理,jsp, servlet


请求等等。


apache 和 tomcat 连接有三种方式 :1.JK ,2 .http_proxy ,3. ajp_proxy 。之前看到robbin在一个帖子里说


jk的连接方式已经淘汰了,貌似apache官网还是有jk的更新,由于我们网站之前用的是jk, 所以暂时还是用jk的方式。


有机会可以测试下jk 和ajp_proxy到底哪种方式更好些。


根据这几天对apache的了解,我记录下JK的连接方式。


装完apache和tomcat后,把mod_jd.so文件拷贝到apache/modules目录下,在httpd.conf中加一句


LoadModule jk_module modules/mod_jk.so,告诉服务器装载jk模块。


准备两个配置文件,workers.properties和uriworkermap.properties ,分别放在conf目录下。


在httpd.conf里指明这两个文件的位置:


   <IfModule jk_module>

   JkWorkersFile conf/workers.properties

   JkMountFile conf/uriworkermap.properties

   JkLogFile logs/mod_jk.log

   </IfModule>



workers.properties文件的内容如下:



worker.list=loadbalancer

worker.balaweb54_1.port=2009

worker.balaweb54_1.host=localhost

worker.balaweb54_1.type=ajp13

worker.balaweb54_1.lbfactor=1

worker.balaweb54_1.socket_keepalive=1

worker.balaweb54_1.socket_timeout=0

worker.balaweb54_1.retries=3

worker.loadbalancer.type=lb

worker.retries=3

worker.loadbalancer.balance_workers=balaweb54_1

worker.loadbalancer.sticky_session=true

worker.loadbalancer.sticky_session_force=false



定义了一个名为balaweb54_1的worker,使用ajp13协议来通讯,apache连接tomcat的端口


是2009,host=localhost表示监听2009端口的主机是本机,lbfactor定义负载平衡的权


值,socket_keepalive这个值在web服务器和tomcat之间装有防火墙的时候需要用到,因为防火墙会丢掉处于


inactive状态的连接,如果设置了这个值为true(默认为false)的话,操作系统会不断的发KEEP_LIVE信息给这个连接,这


样的话,防火墙就不会丢掉这种处于inactive状态的连接,貌似这个属性对我们网站而言也用不上,用默认值就Ok了。


socket_timeout:就不介绍了。


上面还定义了一个type为lb的worker,表示有多个tomcat的时候,在多个tomcat之间均衡负载,这里只配置一个


tomcat,这负载全给这个tomcat , sticky_session官网的解释:Specifies whether requests with


SESSION ID's should be routed back to the same Tomcat worker. If sticky_session is


set to True or 1 sessions are sticky, otherwise sticky_session is set to False. Set


sticky_session to False when Tomcat is using a Session Manager which can persist


session data across multiple instances of Tomcat.


 sticky_session_force 的解释:Specifies whether requests with SESSION ID's for


workers that are in error state should be rejected. If sticky_session_force is set


to True or 1 and the worker that matches that SESSION ID is in error state, client will


receive 500 (Server Error). If set to False or 0 failover on another worker will be


issued with loosing client session. This directive is used only when you


set sticky_session=True.


“If set to False or 0 failover on another worker will be issued with loosing client session. This directive is used only when you set sticky_session=True.”

 这句话不是很明白。貌似这两个值在只有一台tomcat服务器的时候,用默认值就Ok了。


我觉得在只有一个tomcat的时候,这两个sticky的配置完全可以删掉。


uriworkermap.properties文件的内容如下:


/*.do=loadbalancer

/*.jsp=loadbalancer

/dwr/*=loadbalancer

/servlet/*=loadbalancer

!/*.shtml=loadbalancer

!/*.html=loadbalancer

!/*.js=loadbalancer

!/*.css=loadbalancer

!/*.jpg=loadbalancer

!/*.gif=loadbalancer


loadbalancer即workers文件里面定义的loadbalancer,/*.do ,/*.jsp , /dwr/* ,

/servlet/* 这几个表示这样的动态

请求交给loadbalancer处理,而shtml ,html ......这些不交给loadbalancer处理,即由

apache处理,这就验证了开始

说的,静态请求有apache处理,动态请求由tomcat处理,!/*.shtml=loadbalancer ,感

叹号!表示 "非"的意思。


apache的官方说明: http://tomcat.apache.org/connectors-doc/reference/printer/workers.html

 

这篇关于Apache tomcat 负载平衡配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/722674

相关文章

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

springboot的controller中如何获取applicatim.yml的配置值

《springboot的controller中如何获取applicatim.yml的配置值》本文介绍了在SpringBoot的Controller中获取application.yml配置值的四种方式,... 目录1. 使用@Value注解(最常用)application.yml 配置Controller 中

springboot中配置logback-spring.xml的方法

《springboot中配置logback-spring.xml的方法》文章介绍了如何在SpringBoot项目中配置logback-spring.xml文件来进行日志管理,包括如何定义日志输出方式、... 目录一、在src/main/resources目录下,也就是在classpath路径下创建logba

SpringBoot的内嵌和外置tomcat的实现方式

《SpringBoot的内嵌和外置tomcat的实现方式》本文主要介绍了在SpringBoot中定制和修改Servlet容器的配置,包括内嵌式和外置式Servlet容器的配置方法,文中通过示例代码介绍... 目录1.内嵌如何定制和修改Servlet容器的相关配置注册Servlet三大组件Servlet注册详

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

SpringBoot整合Apache Spark实现一个简单的数据分析功能

《SpringBoot整合ApacheSpark实现一个简单的数据分析功能》ApacheSpark是一个开源的大数据处理框架,它提供了丰富的功能和API,用于分布式数据处理、数据分析和机器学习等任务... 目录第一步、添加android依赖第二步、编写配置类第三步、编写控制类启动项目并测试总结ApacheS

2025最新版Android Studio安装及组件配置教程(SDK、JDK、Gradle)

《2025最新版AndroidStudio安装及组件配置教程(SDK、JDK、Gradle)》:本文主要介绍2025最新版AndroidStudio安装及组件配置(SDK、JDK、Gradle... 目录原生 android 简介Android Studio必备组件一、Android Studio安装二、A