集群下处理请求的时序问题

一、环境介绍

所述软件为WEB产品,为一个整体解决方案的中间层,具体为同一套软件部署在多台服务器,相互之间可以组成集群,以共同处理用户请求。对上层调用者来说,其中有一台为主,其余为备。对下层中的某一个被管理者来说,该集群中某一台为主控,其他服务器可以是它的备控,上层和下层认为的主不一定相同。

二、问题描述

本次的问题出在被管理单位的主控和备控之间。

在主控上发出请求时,业务处理流程为:
    1.清空本服务器的缓存
    2.清空集群的共享缓存
    3.下发请求指令给下层被管理者
    4.在此下发略作改动的请求指令给下层
    5.下层被管理者将按指令处理后的结果给共享缓存
    6.从共享缓存中取出结果,返回用户
需要说明的是:
    本服务器的缓存,为本服务器所有实例共享,所以每一个新的请求都应清空该缓存
    集群的共享缓存,为该集群内所有服务器共享,具体有数据同步的模块负责。对于新的请求也应清理该缓存

在被控上走此流程时出现异常:
    只有改动后的请求指令对应的结果,没有改动前对应的结果

三、定位问题

主控与被控部署在两台服务器上,但使用的是同一套软件。当请求传给备控时,备控无法直接将指令下发给下层设备,必须通过主控间接得到结果。
原流程中的步骤3和4具体逻辑为:判断是否是主控,若是,直接处理,若不是,将数据重新封装为一个实体,通过调用主控中同样的对外接口,将请求转交给主控,主控处理后将结果再封装,返回给备控。
简单以线程说明:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值