fucongwang created ROCKETMQ-301:
-----------------------------------

             Summary: Async callback timeout
                 Key: ROCKETMQ-301
                 URL: https://issues.apache.org/jira/browse/ROCKETMQ-301
             Project: Apache RocketMQ
          Issue Type: Improvement
          Components: rocketmq-remoting
    Affects Versions: 4.1.0-incubating, 4.0.0-incubating
            Reporter: fucongwang
            Assignee: vongosling
             Fix For: 4.2.0-incubating


Motivation:
          I found that  ResponseFuture used some tips to keep future callback 
from being called multiple and keep semaphoreAsync from being released 
multiple, I think it was not elegant, and scanResponseTable would scan the 
on-going request list, it was too heavy.

Modification:

        *  ScheduleExecutor replaces Timer, to issue per callback timeout. when 
timeout, check future is done? if not , clear responseTable item and invoke 
callback, if done, just clear responseTable item. 

         * ResponseFuture add isDone method, to check if future is done.

         
                 
         



--
This message was sent by Atlassian JIRA
(v6.4.14#64029)

Reply via email to