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