分布式服务实现细节-服务端响应流程

本文详细阐述了服务端响应请求的过程,从监听远程连接、解析请求报文、获取本地代理,到调用本地服务并返回结果的完整流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

服务端响应请求的流程是:
     1.在固定的端口,监听远程连接socket,采用长连接方式,准对每个客户端都保留有一个处理对象。socket缓存在处理对象中,对该客户端一直打开着
     2. 处理对象 按照请求报文格式解析请求报文,解析完后,将他们封装到新的session对象中,立马换另外一个线程取下一条,而自己则调用session对象继续处理业务逻辑。采用的是领导者跟随者模式,减少线程切换。
        领导者线程获取一个完整请求后,把socket返回给线程池继续调度,自己继续执行业务逻辑。
     3.session对象将解析出来的服务名 通过服务中心 获取到本地服务器对象的本地代理,
     4.本地代理根据请求解析出来的方法id 通过对目标服务的方法缓存中取出方法服务对象
     5.本地代理将解析出来的参数调用本地服务对象,取得结果,如异常了,返回异常结果
     6.将结果序列化成流,连同请求传过来的请求头信息(特别是sessionid), 写出到输出流中

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值