[ 
https://issues.apache.org/jira/browse/HBASE-5974?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13479609#comment-13479609
 ] 

Anoop Sam John commented on HBASE-5974:
---------------------------------------

bq.Do you foresee the sequencing being used other than in scanners (Its 
implemented in ScannerCallable only at moment)? If NOT, would 
OutOfOrderNextException or OutOfOrderScannerNextException be a better name than 
CallSequenceOutOfOrderException? If you do this, would suggest changing param 
names from callSeq to nextSeq? The former is generic.
Issues in which a retry from client as a result of timeout can come in other 
client API like increment() also I guess. It can increment 2 times or may be 
more.. Here in this particular case the names you suggested better than mine.. 
Sorry I am not good at naming :(

bq.Is CallSequenceOutOfOrderException an exception that will bubble up into the 
application or is the client its intended audience? If so, should we annotate 
it @InterfaceAudience.Private as Abortable is for instance?
Yes you are correct. I will change

bq.Would it make sense testing ! DoNotRetryIOException rather than calling out 
the two exceptions above? Would that be too broad? Otherwise, wondering if 
these two exceptions should inherit from a common base class given they are 
getting this special treatment. Not important. Just a thought.
Here 3 exceptions getting the special treatment. !DoNotRetryIOException I can 
try.. Didnt want to change this key area..But at the time of this patch 
preperation I felt like why this is been written this way. I had to add my new 
Exception out here to make thing work.. May be will keep the code the current 
way as in the patch. Will open up a new jira where we can discuss about making 
a common base class or other changes. I think your suggestion makes sense for 
maintainability

bq.Check your comments. You seem to be saying 'scan' when you mean 'next'.
Yes I need do changes here. Will do

Will continue in next comment....
                
> Scanner retry behavior with RPC timeout on next() seems incorrect
> -----------------------------------------------------------------
>
>                 Key: HBASE-5974
>                 URL: https://issues.apache.org/jira/browse/HBASE-5974
>             Project: HBase
>          Issue Type: Bug
>          Components: Client, regionserver
>    Affects Versions: 0.90.7, 0.92.1, 0.94.0, 0.96.0
>            Reporter: Todd Lipcon
>            Assignee: Anoop Sam John
>            Priority: Critical
>             Fix For: 0.96.0
>
>         Attachments: 5974_94-V4.patch, 5974_trunk.patch, 5974_trunk-V2.patch, 
> HBASE-5974_0.94.patch, HBASE-5974_94-V2.patch, HBASE-5974_94-V3.patch
>
>
> I'm seeing the following behavior:
> - set RPC timeout to a short value
> - call next() for some batch of rows, big enough so the client times out 
> before the result is returned
> - the HConnectionManager stuff will retry the next() call to the same server. 
> At this point, one of two things can happen: 1) the previous next() call will 
> still be processing, in which case you get a LeaseException, because it was 
> removed from the map during the processing, or 2) the next() call will 
> succeed but skip the prior batch of rows.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators
For more information on JIRA, see: http://www.atlassian.com/software/jira

Reply via email to