集群原理
Web集群分成两个方面:
负载分发
一方面是水平扩展,通过接入代理进行负载分发,分发到后台多个实际的业务处理逻辑单元上。这种接入代理可以是nginx,Apache等软件负载,也可以是类似F5等硬件负载。具体方式参见nginx负载或Apache负载等。
Session处理
另一方面就是多个业务逻辑单元之间的Session处理,处理方式有两种,一种是Session sticky模式,另外一种是Session共享模式。
Session处理方式 |
Session Sticky |
Session共享 |
处理逻辑 |
把同一个用户的Session一直发送到同一个逻辑单元处理 |
所有的后端处理逻辑单元共享Session或者Session更新时通知其它逻辑单元 |
主要实现方式 |
指定负载的分发组件(如Apache),把请求中包含特定属性的请求发到同一个连接,如指定jsessionid一致的请求到同一个请求,或者在负载组件中给每个响应增加一个头部属性,指定下次的分发目的地 |
1. 各自维护Session,当请求处理结束后,通知其它组件单元更新Session,包括异步和同步模式 2. 统一维护Session,如把Session放在memcached或者共享文件系统中,可以在容器级别或者应用级别做这个事情 3. 利用cache server |
优势 |
本地维护Session,不需要访问网络存取或者通知其它处理单元变更 |
完全的随机分发,可以根据服务忙闲调整分发策略,高可用性 |
劣势 |
一台服务器宕机后,当前Session断掉 |
网络存取操作等耗时,影响处理效率(根据选用的策略不同造成影响不同) |
搭建步骤
本文档所阐述场景:使用Apache modproxy模式进行负载分发,Session使用Session Sticky模式。
安装部署Tomcat
略。
注意:多台Tomcat之间毫无关联,不需要做任何配置。
安装Apache HttpServer
略。
注意:Apache需要使用2.2以上的版本,支持mod proxy模式。
配置负载分发
以下配置修改都是在Apache的conf/httpd.conf配置文件中完成
1. 修改加载mod proxy需要的模块
找到配置中被注释掉的几行,删除注释,使Apache在启动的时候加载如下模块
LoadModule proxy_module modules/mod_proxy.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 headers_module modules/mod_headers.so
LoadModule status_module modules/mod_status.so
2. 给HTTP请求头部添加路由标识
直接在loadModule模块下面增加即可
Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
3. 配置负载均衡后端的业务逻辑单元处理地址
注意本步骤标红的需要与上面步骤中的ROUTEID一致。
<Proxy balancer://mycluster>
BalancerMember http://192.168.77.213:9005 route=1
BalancerMember http://192.168.77.213:9004 route=2
BalancerMember http://192.168.77.213:9002 route=3
BalancerMember http://192.168.77.213:9003 route=4
ProxySet stickysession=ROUTEID
</Proxy>
4. 配置mod proxy路由规则
ProxyPass / balancer://mycluster/
注意“/”不要少加,mycluster与上面的后端处理集群的名字一致。这里的意思是把所有的请求都转发给上面的集群进行处理
5. 2,3,4步骤的最终配置如下:
Header add Set-Cookie "ROUTEID=.%{BALANCER_WORKER_ROUTE}e; path=/" env=BALANCER_ROUTE_CHANGED
<Proxy balancer://mycluster>
BalancerMember http://192.168.77.213:9005 route=1
BalancerMember http://192.168.77.213:9004 route=2
BalancerMember http://192.168.77.213:9002 route=3
BalancerMember http://192.168.77.213:9003 route=4
ProxySet stickysession=ROUTEID
</Proxy>
ProxyPass / balancer://mycluster/
验证
打开地址http://192.168.13.242:7080/smsshall/welcome.do进行验证(注意Apache是监听192.168.13.242:7080地址的)。
使用firebug查看cookies信息,多次刷新,cookies中的ROUTEID是一致的。
重新打开多个浏览器,刷新,尝试,看ROUTEID,同一个浏览器的ROUTEID是不会变化的。
相关推荐
Tomcat和Apache集群和负载均衡配置 Tomcat版本:apache-tomcat-7.0.26 Apache版本:Apache2.2.25 jre版本:1.6.0_26 集群和负载均衡配置已整好,解压后,只要点击run.bat一键启动,即可看到集群效果。 运行成功后,...
NULL 博文链接:https://acooly.iteye.com/blog/1377732
7 apache 整合tomcat 1)modules目录下添加模块:jk mod_jk-1.2.26-httpd-2.2.4.so 2)修改conf/httpd.conf 最后一行添加: include conf/mod_jk.conf 3)在conf目录下创建mok_jk.conf 内容: ...
2.修改每台tomcat的conf目录下得context.xml文件或者server.xml文件,在其中加入如下任意一段代码(注意:当使用多台tomcat时,一定要使用non-sticky模式): ... memcachedNodes="n1:host1.yourdomain....
(2) session cluster:delta session manager 基于tomcat集群会话保持 分析:tomcat自身带的机制 session cluster,基于组播的方式,一个tomcat 被用户登录访问,记录session;通过组播给集群中的其他机器复制一份...
tomcat-redis-session-manager-tomcat-7 Redis-backed non-sticky session store for Apache Tomcat
在不包含Sticky Notes 便签的操作系统中手动安装Sticky Notes 便签,windows server2016测试通过;包含x86及x64; 方法:1、新建 C:\Program Files\Sticky Notes 2、拷贝 en-US、slc.dll、StickyNotes.exe 至 C:\...
nginx sticky是nginx的module,可以实现基于cookie的负载均衡。 下载后,在编译安装nginx时,用--add-module选项,指到sticky所在目录。类似命令如下: ./configure --prefix=/usr/local/nginx-1.6.0 --add-module=...
tomcat用redis共享session需要的jar
tomcat使用memcached保存session所需的jar包 tomcat版本:7.0.68 memcached版本:1.4.31 修改tomcat/conf/context.xml文件,增加如下内容: memcachedNodes="n1:192.168.1.107:11111 n2:192.168.1.108:11111" ...
sticky模块,可用于最新版本的nginx编译,原来的sticky模块只有1.1版本的,没有更新了。
WP-Sticky插件的使用方法: 安装成功后,当你发布新文章的时候,会看到页面的右下方出现一个“Post Sticky Status”,除了Normal和Sticky外,还有一个Announcement的选项,此三者的差别如下: Announcement:这个...
微信小程序sticky吸顶效果.zip
sticky note source code. Using C sharp and .Net programming
(f)Nginx sticky模块不能与ip_hash同时使用 sticky [name=route] [domain=.foo.bar] [path=/] [expires=1h] [hash=index|md5|sha1] [no_fallback] [secure] [httponly]; [name=route] 设置用来记录会话的cookie...
Ubuntu14.04.2下nginx1.6和sticky1.1模块的安装与简单配置,包括像文档和支持包
nginx-sticky 编译不报错版
用户的屏幕越来越大,而页面太宽的话会不宜阅读,所以绝大部分网站的主体宽度和之前相比没有太大的变化,于是浏览器中就有越来越多的空白区域,所以你可能注意到很多网站开始在滚动的...position:sticky为此而生,接下来
vuejs-sticky-directive 在纯js和vue上支持顶部和底部粘性。...使用sticky-*属性定义其选项 Sticky元素将找到最接近其具有sticky-container属性的元素,或者如果失败则将找到其父节点作为相对元素。 <