dubbo thrift和原生态thrift的怎么实现信息互通
1个回答
展开全部
重写exchange,主要涉及到HeaderExchangeChannel,HeaderExchangeClient,HeaderExchangeServer,HeaderExchanger,HeartBeatTask,Request,凡是涉及到发request的地方,都要重写,假设重写后的请求叫Request2,在发请求的时候,发Request2。主要原因是想用requestId代替TMessage里seqId,但是Request的id是long型的,如果强转为int,那么当id增长到大于int的最大值时,到客户端处理时,拿到的Response的id是long型强转后的int值,在DefaultFuture里就找不到自己的future,可以在客户端这边做缓存,当Request的id大于int型的最大值,或小于int型的最小值时,把long型的RequestId和强转后的int值关联,但是觉得这样不太优雅,而且不及时删除这个缓存有可能引起内存泄露。所以自己就重写了Request2,把里面的INVOKER_ID改为AtomicInteger,其他的都没改,这样的话,Request的id就一直是int型,也可以直接替换TMessage里的seqId。涉及到发送Request的地方全都改成Request2。
Storm代理
2023-07-25 广告
2023-07-25 广告
StormProxies是一家可靠的代理服务提供商,提供原生IP(住宅原生IP)和高匿名代理服务。以下是关于StormProxies的原生IP服务的一些信息:1. 住宅原生IP:StormProxies提供的住宅原生IP是指从真实的家庭或企...
点击进入详情页
本回答由Storm代理提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询