apache+tomcat配置负载均衡,实现http与websocket接口分压
一、应用场景
在生产环境中,应用服务器(此文以tomcat为例)不免面临高访问量的压力,相比而言web服务器(此文以apache为例)能够承担更大的并发量。Apache本身带有一些模块,可以完成对应用服务器访问流量分流分压的功能。这里就以apache+tomcat配置负载均衡的方式,实现http与websocket接口分压的效果。
二、系统环境
服务器:阿里云ECS服务器;
操作系统:ubuntu 14;
应用服务器:tomcat 8.5+;
Web服务器:apache 2.4+;
三、Tomcat配置
从tomcat官网下载压缩包,解压为两个tomcat实例(分别为tomcat-8080与tomcat-8082)。
a) 修改tomcat-8080的配置文件(conf/server.xml)
<Connector port=”8080″ protocol=”HTTP/1.1″
connectionTimeout=”20000″
redirectPort=”8443″ URIEncoding=”UTF-8″ />
<Connector port=”8010″ protocol=”AJP/1.3″
redirectPort=”8443″ URIEncoding=”UTF-8″ />
<Engine name=”Catalina” defaultHost=”localhost”jvmRoute=”jvm8080″>
四、修改tomcat-8082的配置文件(conf/server.xml)
<Connector port=”8082″ protocol=”HTTP/1.1″
connectionTimeout=”20000″
redirectPort=”8443″ URIEncoding=”UTF-8″ />
<Connector port=”8012″ protocol=”AJP/1.3″
redirectPort=”8443″ URIEncoding=”UTF-8″ />
<Engine name=”Catalina” defaultHost=”localhost”jvmRoute=”jvm8082″>
五、Apache配置
a) 开启模块
a2enmod proxy*
a2enmod lbmethod*
a2enmod xml2enc
b) 配置vhost
i. 在site-enabled下创建文件balance.conf
ii. 在ports.conf开启代理端口(此处以82为例)
iii. 内容编辑如下:websocket的负载均衡要在ajp的负载均衡之前。
#配置端口
<VirtualHost *:82>
ServerAdmin webmaster@localhost
DocumentRoot /var/www/html
###########负载均衡配置开始###########
ProxyRequests Off
ProxyPass /balancer-manager !
###一、配置websocket的负载均衡###
<Proxy balancer://wscluster>
BalancerMember ws://localhost:8080
BalancerMember ws://localhost:8082
</Proxy>
#代理项目的weboscket接口
ProxyPass /project/wsApi balancer://wscluster/project/wsApi
ProxyPassReverse /project/wsApi balancer://wscluster/project/wsApi
###二、配置常规负载均衡###
<Proxy balancer://tomcatcluster>
BalancerMember ajp://127.0.0.1:8010 route=jvm8080
BalancerMember ajp://127.0.0.1:8012 route=jvm8082
ProxySet lbmethod=byrequests stickysession=JSESSIONID|jsessionid nofailover=On scolonpathdelim=On
</Proxy>
#代理websocket接口外的其他请求
ProxyPass / balancer://tomcatcluster/
ProxyPassReverse / balancer://tomcatcluster/
ErrorLog ${APACHE_LOG_DIR}/error.log
CustomLog ${APACHE_LOG_DIR}/access.log combined
#展示负载均衡的管理页面
<Location /balancer-manager>
SetHandler balancer-manager
</Location>
###########负载均衡配置结束###########
</VirtualHost>
c) 启动与查看
启动tomcat,启动apache
通过ip:82/balancer-manager,可以查看配置是否成功,与分流效果。
来自:李德涛博客
apache+tomcat配置负载均衡,实现http与websocket接口分压的更多相关文章
- Apache+Tomcat部署负载均衡(或集群)
本来只打算写Tomcat集群部署,简化Apache和Tomcat整合过程的.后来想了想,这样不便于没有用过Apache的朋友来学习本文内容.于是干脆加大篇幅,让对Apache不了解的朋友能对Apach ...
- 简单的 Nginx+Tomcat 配置负载均衡集群
简单 Nginx+Tomcat 配置负载均衡集群 前期准备 解压两个tomcat,修改端口号 server1:8081 server:8082 同时启动 nginx官网下载解压版nginx 创建一个简 ...
- Apache和Tomcat 配置负载均衡(mod-proxy方式)-无session共享、无粘性session
转:https://blog.csdn.net/wangjunjun2008/article/details/38268483 mod-proxy方式实现负载均衡是利用了Apache 2.x版本自带的 ...
- Apache+Tomcat实现负载均衡
反向代理负载均衡 (Apache2+Tomcat7/8) 使用代理服务器可以将请求转发给内部的Web服务器,让代理服务器将请求均匀地转发给多台内部Web服务器之一上,从而达到负载均衡的目的.这种代理方 ...
- 基于Apache+Tomcat实现负载均衡
1.基于Apache和tomcat实现负载均衡 准备三个虚拟机一个安装Apache两个安装Tomcat 关闭防火墙 systemctl stop firewalld Iptabled -F Seten ...
- Apache +Tomcat的负载均衡与集群配置
实验拓扑图: 一.搭配环境 (1).Tomcat的安装和配置 Tomcat_a的ip:192.168.55.229 Tomcat_b的ip:192.168.55.231 Tomcat的需要安装jdk和 ...
- Apache和Tomcat 配置负载均衡(mod-proxy方式)-粘性session
Tomcat集群配置后端Tomcat Server为支持AJP的独立服务,前端Apache配置为粘性会话(sticky-session),Tomcat不配置Cluster配置和Session复制. 配 ...
- Apache+Tomcat+mod_jk负载均衡
一.需要的软件 1.jdk1.5以上 2.Tomcat6以上 3.Apache2.2以上 ,地址http://apache.dataguru.cn//httpd/binaries/win32/ ,名称 ...
- centos6.5 apache+tomcat结合 负载均衡
一. 负载均衡:根据 uri 表达式把请求分发给各个服务器处理.如:/*.jsp = lb_s 就是说把所有jsp请求交给lb_s , 当然它是个Tomcat. 二. 安装配置mod_jk m ...
随机推荐
- MySql常见的错误
一些MySql运行中遇到的错误总结,大家也可以留言进行我进行汇总. 一.Unknown error 1146 com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxEr ...
- CF1173X
CF1173C 由于牌堆只能从最后插牌,所以插牌方法非常显然 首先特判一下牌堆有没有一个合法的后缀,如果有的话再判断一下手中的牌和合法后缀之前的牌的排列顺序能不能有效的继续续下去 然后排除了以上情况就 ...
- MockServer
基于Flask实现的一个简易Mock平台,使用标准json结构体编写Mock Api https://github.com/yinquanwang/MockServer Key Features ...
- css3属性 -webkit-filter
css3属性 -webkit-filter -webkit-filter是css3的一个属性,Webkit率先支持了这几个功能,感觉效果很不错.下面咱们就学习一下filter这个属性吧. 现在规范中支 ...
- 1、Spring MVC的web.xml配置详解(转)
版权声明:本文为博主原创文章,转载请注明出处http://blog.csdn.net/u010796790 1.spring 框架解决字符串编码问题:过滤器 CharacterEncodingFilt ...
- python_django_上传文件
存储路径: 存储在服务器的项目的static/upfile(你说了算的文件名,但是一般俺们叫这个)文件中 配置: 配置settings.py文件 MDEIA_ROOT = os.path.join(B ...
- express 路由能力
demo var express=require("express"); var app=express(); app.get("/",function(req ...
- java_monitor
转载自http://blog.sina.com.cn/s/blog_9385f6d90101dbqy.html java会为每个object对象分配一个monitor,当某个对象的同步方法(synch ...
- OS: 生产者消费者问题(二) ---- 系统V IPC通信-信号量和共享内存
在上一篇“OS: 生产者消费者问题(多进程+共享内存+信号量)”中提到的方法二: 如果进程之间并没有父子关系,但是协商好了共享存储的 KEY , 那么在每个进程中,就可以通过 KEY 以及 shmge ...
- 关于swiper动态更改,无法更新的悖论
关于swiper动态更改,无法更新的悖论 以前都觉得swiper的使用很简单,那是因为使用swiper时都是写的数据,按照官网上介绍直接初始化swiper,随便丢一个地方初始化就ok了,但是在很多需求 ...