You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@hbase.apache.org by nd...@apache.org on 2020/09/21 18:05:57 UTC

svn commit: r41529 - /dev/hbase/2.3.2RC4/

Author: ndimiduk
Date: Mon Sep 21 18:05:57 2020
New Revision: 41529

Log:
Apache HBase 2.3.2RC4

Added:
    dev/hbase/2.3.2RC4/
    dev/hbase/2.3.2RC4/CHANGELOG.2.3.2.md
    dev/hbase/2.3.2RC4/RELEASENOTES.2.3.2.md
    dev/hbase/2.3.2RC4/api_compare_2.3.1_to_2.3.2RC4.html
    dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz   (with props)
    dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.asc
    dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.sha512
    dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz   (with props)
    dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.asc
    dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.sha512
    dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz   (with props)
    dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.asc
    dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.sha512

Added: dev/hbase/2.3.2RC4/CHANGELOG.2.3.2.md
==============================================================================
--- dev/hbase/2.3.2RC4/CHANGELOG.2.3.2.md (added)
+++ dev/hbase/2.3.2RC4/CHANGELOG.2.3.2.md Mon Sep 21 18:05:57 2020
@@ -0,0 +1,87 @@
+## Release 2.3.2 - Unreleased (as of 2020-09-20)
+
+
+
+### NEW FEATURES:
+
+| JIRA | Summary | Priority | Component |
+|:---- |:---- | :--- |:---- |
+| [HBASE-24776](https://issues.apache.org/jira/browse/HBASE-24776) | [hbtop] Support Batch mode |  Major | hbtop |
+
+
+### IMPROVEMENTS:
+
+| JIRA | Summary | Priority | Component |
+|:---- |:---- | :--- |:---- |
+| [HBASE-25066](https://issues.apache.org/jira/browse/HBASE-25066) | Use FutureUtils.rethrow in AsyncTableResultScanner to better catch the stack trace |  Major | Client, Scanners |
+| [HBASE-25069](https://issues.apache.org/jira/browse/HBASE-25069) |  Display region name instead of encoded region name in HBCK report page. |  Minor | hbck |
+| [HBASE-24991](https://issues.apache.org/jira/browse/HBASE-24991) | Replace MovedRegionsCleaner with guava cache |  Minor | . |
+| [HBASE-25057](https://issues.apache.org/jira/browse/HBASE-25057) | Fix typo "memeber" |  Trivial | documentation |
+| [HBASE-24831](https://issues.apache.org/jira/browse/HBASE-24831) | Avoid invoke Counter using reflection  in SnapshotInputFormat |  Major | . |
+| [HBASE-25006](https://issues.apache.org/jira/browse/HBASE-25006) | Make the cost functions optional for StochastoicBalancer |  Major | . |
+| [HBASE-24974](https://issues.apache.org/jira/browse/HBASE-24974) | Provide a flexibility to print only row key and filter for multiple tables in the WALPrettyPrinter |  Minor | wal |
+| [HBASE-24937](https://issues.apache.org/jira/browse/HBASE-24937) | table.rb use LocalDateTime to replace Instant |  Minor | shell |
+| [HBASE-24940](https://issues.apache.org/jira/browse/HBASE-24940) | runCatalogJanitor() API should return -1 to indicate already running status |  Major | . |
+| [HBASE-24569](https://issues.apache.org/jira/browse/HBASE-24569) | Get hostAndWeights in addition using localhost if it is null in local mode |  Minor | regionserver |
+| [HBASE-24913](https://issues.apache.org/jira/browse/HBASE-24913) | Refactor TestJMXConnectorServer |  Major | test |
+| [HBASE-24898](https://issues.apache.org/jira/browse/HBASE-24898) | Use EnvironmentEdge.currentTime() instead of System.currentTimeMillis() in CurrentHourProvider |  Major | tooling |
+| [HBASE-24928](https://issues.apache.org/jira/browse/HBASE-24928) | balanceRSGroup should skip generating balance plan for disabled table and splitParent region |  Major | Balancer |
+| [HBASE-24942](https://issues.apache.org/jira/browse/HBASE-24942) | MergeTableRegionsProcedure should not call clean merge region |  Major | proc-v2, Region Assignment |
+| [HBASE-24811](https://issues.apache.org/jira/browse/HBASE-24811) | Use class access static field or method |  Minor | . |
+| [HBASE-24686](https://issues.apache.org/jira/browse/HBASE-24686) | [LOG] Log improvement in Connection#close |  Major | Client, logging |
+| [HBASE-24912](https://issues.apache.org/jira/browse/HBASE-24912) | Enlarge MemstoreFlusherChore/CompactionChecker period for unit test |  Major | . |
+| [HBASE-24854](https://issues.apache.org/jira/browse/HBASE-24854) | Correct the help content of assign and unassign commands in hbase shell |  Minor | shell |
+
+
+### BUG FIXES:
+
+| JIRA | Summary | Priority | Component |
+|:---- |:---- | :--- |:---- |
+| [HBASE-24896](https://issues.apache.org/jira/browse/HBASE-24896) | 'Stuck' in static initialization creating RegionInfo instance |  Major | . |
+| [HBASE-24956](https://issues.apache.org/jira/browse/HBASE-24956) | ConnectionManager#locateRegionInMeta waits for user region lock indefinitely. |  Major | Client |
+| [HBASE-24481](https://issues.apache.org/jira/browse/HBASE-24481) | HBase Rest: Request for region detail of a table which doesn't exits is success(200 success code) instead of 404 |  Minor | . |
+| [HBASE-25047](https://issues.apache.org/jira/browse/HBASE-25047) | WAL split edits number is negative in RegionServerUI |  Minor | UI, wal |
+| [HBASE-25021](https://issues.apache.org/jira/browse/HBASE-25021) | Nightly job should skip hadoop-2 integration test for master |  Major | build, scripts |
+| [HBASE-25012](https://issues.apache.org/jira/browse/HBASE-25012) | HBASE-24359 causes replication missed log of some RemoteException |  Major | Replication |
+| [HBASE-25009](https://issues.apache.org/jira/browse/HBASE-25009) | Hbck chore logs wrong message when loading regions from RS report |  Minor | . |
+| [HBASE-25014](https://issues.apache.org/jira/browse/HBASE-25014) | ScheduledChore is never triggered when initalDelay \> 1.5\*period |  Major | . |
+| [HBASE-25016](https://issues.apache.org/jira/browse/HBASE-25016) | Should close ResultScanner in MetaTableAccessor.scanByRegionEncodedName |  Critical | master, meta |
+| [HBASE-24958](https://issues.apache.org/jira/browse/HBASE-24958) | CompactingMemStore.timeOfOldestEdit error update |  Critical | regionserver |
+| [HBASE-24995](https://issues.apache.org/jira/browse/HBASE-24995) | MetaFixer fails to fix overlaps when multiple tables have overlaps |  Major | hbck2 |
+| [HBASE-24719](https://issues.apache.org/jira/browse/HBASE-24719) | Renaming invalid rsgroup throws NPE instead of proper error message |  Major | . |
+| [HBASE-19352](https://issues.apache.org/jira/browse/HBASE-19352) | Port HADOOP-10379: Protect authentication cookies with the HttpOnly and Secure flags |  Major | . |
+| [HBASE-24971](https://issues.apache.org/jira/browse/HBASE-24971) | Upgrade JQuery to 3.5.1 |  Major | security, UI |
+| [HBASE-24968](https://issues.apache.org/jira/browse/HBASE-24968) | One of static initializers of CellComparatorImpl referring to subclass MetaCellComparator |  Major | . |
+| [HBASE-24916](https://issues.apache.org/jira/browse/HBASE-24916) | Region hole contains wrong regions pair when hole is created by first region deletion |  Major | hbck2 |
+| [HBASE-24892](https://issues.apache.org/jira/browse/HBASE-24892) | config 'hbase.hregion.memstore.mslab.indexchunksize' not be used |  Major | . |
+| [HBASE-24871](https://issues.apache.org/jira/browse/HBASE-24871) | Replication may loss data when refresh recovered replication sources |  Major | Replication |
+| [HBASE-24885](https://issues.apache.org/jira/browse/HBASE-24885) | STUCK RIT by hbck2 assigns |  Major | hbck2, Region Assignment |
+| [HBASE-24926](https://issues.apache.org/jira/browse/HBASE-24926) | Should call setFailure in MergeTableRegionsProcedure when isMergeable returns false |  Major | master, proc-v2 |
+| [HBASE-24884](https://issues.apache.org/jira/browse/HBASE-24884) | BulkLoadHFilesTool/LoadIncrementalHFiles should accept -D options from command line parameters |  Minor | . |
+
+
+### TESTS:
+
+| JIRA | Summary | Priority | Component |
+|:---- |:---- | :--- |:---- |
+| [HBASE-24979](https://issues.apache.org/jira/browse/HBASE-24979) | Include batch mutatations in client operation timeout tests |  Major | . |
+| [HBASE-24894](https://issues.apache.org/jira/browse/HBASE-24894) | [Flakey Test] TestStochasticLoadBalancer.testMoveCostMultiplier |  Major | Balancer, master, test |
+
+
+### SUB-TASKS:
+
+| JIRA | Summary | Priority | Component |
+|:---- |:---- | :--- |:---- |
+| [HBASE-24857](https://issues.apache.org/jira/browse/HBASE-24857) |  Fix several problems when starting webUI |  Minor | canary, UI |
+| [HBASE-24918](https://issues.apache.org/jira/browse/HBASE-24918) | Make RegionInfo#UNDEFINED IA.Private |  Major | . |
+| [HBASE-24876](https://issues.apache.org/jira/browse/HBASE-24876) | Fix the flaky job url in hbase-personality.sh |  Major | . |
+
+
+### OTHER:
+
+| JIRA | Summary | Priority | Component |
+|:---- |:---- | :--- |:---- |
+| [HBASE-25004](https://issues.apache.org/jira/browse/HBASE-25004) | Log RegionTooBusyException details |  Major | . |
+| [HBASE-14847](https://issues.apache.org/jira/browse/HBASE-14847) | Add FIFO compaction section to HBase book |  Major | documentation |
+
+

Added: dev/hbase/2.3.2RC4/RELEASENOTES.2.3.2.md
==============================================================================
--- dev/hbase/2.3.2RC4/RELEASENOTES.2.3.2.md (added)
+++ dev/hbase/2.3.2RC4/RELEASENOTES.2.3.2.md Mon Sep 21 18:05:57 2020
@@ -0,0 +1,50 @@
+# HBASE  2.3.2 Release Notes
+
+These release notes cover new developer and user-facing incompatibilities, important issues, features, and major improvements.
+
+
+---
+
+* [HBASE-24896](https://issues.apache.org/jira/browse/HBASE-24896) | *Major* | **'Stuck' in static initialization creating RegionInfo instance**
+
+1. Untangle RegionInfo, RegionInfoBuilder, and MutableRegionInfo static
+initializations.
+2. Undo static initializing references from RegionInfo to RegionInfoBuilder.
+3. Mark RegionInfo#UNDEFINED IA.Private and deprecated;
+it is for internal use only and likely to be removed in HBase4. (sub-task HBASE-24918)
+4. Move MutableRegionInfo from inner-class of
+RegionInfoBuilder to be (package private) standalone. (sub-task HBASE-24918)
+
+
+---
+
+* [HBASE-24956](https://issues.apache.org/jira/browse/HBASE-24956) | *Major* | **ConnectionManager#locateRegionInMeta waits for user region lock indefinitely.**
+
+<!-- markdown -->
+
+Without this fix there are situations in which locateRegionInMeta() on a client is not bound by a timeout. This happens because of a global lock whose acquisition was not under any lock scope. This affects client facing API calls that rely on this method to locate a table region in meta. This fix brings the lock acquisition under the scope of "hbase.client.meta.operation.timeout" and that guarantees a bounded wait time.
+
+
+---
+
+* [HBASE-24776](https://issues.apache.org/jira/browse/HBASE-24776) | *Major* | **[hbtop] Support Batch mode**
+
+HBASE-24776 added the following command line parameters to hbtop:
+\| Argument \| Description \| 
+\|---\|---\|
+\| -n,--numberOfIterations \<arg\> \| The number of iterations \|
+\| -O,--outputFieldNames \| Print each of the available field names on a separate line, then quit \|
+\| -f,--fields \<arg\> \| Show only the given fields. Specify comma separated fields to show multiple fields \|
+\| -s,--sortField \<arg\> \| The initial sort field. You can prepend a \`+' or \`-' to the field name to also override the sort direction. A leading \`+' will force sorting high to low, whereas a \`-' will ensure a low to high ordering \|
+\| -i,--filters \<arg\> \| The initial filters. Specify comma separated filters to set multiple filters \|
+\| -b,--batchMode \| Starts hbtop in Batch mode, which could be useful for sending output from hbtop to other programs or to a file. In this mode, hbtop will not accept input and runs until the iterations limit you've set with the \`-n' command-line option or until killed \|
+
+
+---
+
+* [HBASE-24892](https://issues.apache.org/jira/browse/HBASE-24892) | *Major* | **config 'hbase.hregion.memstore.mslab.indexchunksize' not be used**
+
+Remove the config "hbase.hregion.memstore.mslab.indexchunksize" which never used. And use "hbase.hregion.memstore.mslab.indexchunksize.percent" instead.
+
+
+

Added: dev/hbase/2.3.2RC4/api_compare_2.3.1_to_2.3.2RC4.html
==============================================================================
--- dev/hbase/2.3.2RC4/api_compare_2.3.1_to_2.3.2RC4.html (added)
+++ dev/hbase/2.3.2RC4/api_compare_2.3.1_to_2.3.2RC4.html Mon Sep 21 18:05:57 2020
@@ -0,0 +1,515 @@
+<!-- kind:binary;verdict:compatible;affected:0;added:3;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:0;method_problems_high:0;method_problems_medium:0;method_problems_low:0;checked_methods:6679;checked_types:577;tool_version:2.4 -->
+<!-- kind:source;verdict:compatible;affected:0;added:3;removed:0;type_problems_high:0;type_problems_medium:0;type_problems_low:0;method_problems_high:0;method_problems_medium:0;method_problems_low:0;checked_methods:6679;checked_types:577;tool_version:2.4 -->
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
+<head>
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+<meta name="viewport" content="width=device-width,initial-scale=1" />
+<meta name="keywords" content="hbase, compatibility" />
+<meta name="description" content="Compatibility report for the hbase library between rel/2.3.1 and 2.3.2RC4 versions" />
+<title>hbase: rel/2.3.1 to 2.3.2RC4 compatibility report</title>
+<style type="text/css">
+body {
+    font-family:Arial, sans-serif;
+    background-color:White;
+    color:Black;
+}
+hr {
+    color:Black;
+    background-color:Black;
+    height:1px;
+    border:0;
+}
+h1 {
+    margin-bottom:0px;
+    padding-bottom:0px;
+    font-size:1.625em;
+}
+h2 {
+    margin-bottom:0px;
+    padding-bottom:0px;
+    font-size:1.25em;
+    white-space:nowrap;
+}
+div.symbols {
+    color:#003E69;
+}
+div.symbols i {
+    color:Brown;
+}
+span.section {
+    font-weight:bold;
+    cursor:pointer;
+    color:#003E69;
+    white-space:nowrap;
+    margin-left:0.3125em;
+}
+span:hover.section {
+    color:#336699;
+}
+span.sect_aff {
+    cursor:pointer;
+    padding-left:1.55em;
+    font-size:0.875em;
+    color:#cc3300;
+}
+span.ext {
+    font-weight:normal;
+}
+span.jar {
+    color:#cc3300;
+    font-size:0.875em;
+    font-weight:bold;
+}
+div.jar_list {
+    padding-left:0.4em;
+    font-size:0.94em;
+}
+span.pkg_t {
+    color:#408080;
+    font-size:0.875em;
+}
+span.pkg {
+    color:#408080;
+    font-size:0.875em;
+    font-weight:bold;
+}
+span.cname {
+    color:Green;
+    font-size:0.875em;
+    font-weight:bold;
+}
+span.iname_b {
+    font-weight:bold;
+}
+span.iname_a {
+    color:#333333;
+    font-weight:bold;
+    font-size:0.94em;
+}
+span.sym_p {
+    font-weight:normal;
+    white-space:normal;
+}
+span.sym_pd {
+    white-space:normal;
+}
+span.sym_p span, span.sym_pd span {
+    white-space:nowrap;
+}
+span.attr {
+    color:Black;
+    font-weight:normal;
+}
+span.deprecated {
+    color:Red;
+    font-weight:bold;
+    font-family:Monaco, monospace;
+}
+div.affect {
+    padding-left:1em;
+    padding-bottom:10px;
+    font-size:0.87em;
+    font-style:italic;
+    line-height:0.9em;
+}
+div.affected {
+    padding-left:2em;
+    padding-top:10px;
+}
+table.ptable {
+    border-collapse:collapse;
+    border:1px outset black;
+    margin-left:0.95em;
+    margin-top:3px;
+    margin-bottom:3px;
+    width:56.25em;
+}
+table.ptable td {
+    border:1px solid Gray;
+    padding:3px;
+    font-size:0.875em;
+    text-align:left;
+    vertical-align:top;
+    max-width:28em;
+    word-wrap:break-word;
+}
+table.ptable th {
+    background-color:#eeeeee;
+    font-weight:bold;
+    color:#333333;
+    font-family:Verdana, Arial;
+    font-size:0.875em;
+    border:1px solid Gray;
+    text-align:center;
+    vertical-align:top;
+    white-space:nowrap;
+    padding:3px;
+}
+table.summary {
+    border-collapse:collapse;
+    border:1px outset black;
+}
+table.summary th {
+    background-color:#eeeeee;
+    font-weight:normal;
+    text-align:left;
+    font-size:0.94em;
+    white-space:nowrap;
+    border:1px inset Gray;
+    padding:3px;
+}
+table.summary td {
+    text-align:right;
+    white-space:nowrap;
+    border:1px inset Gray;
+    padding:3px 5px 3px 10px;
+}
+span.mngl {
+    padding-left:1em;
+    font-size:0.875em;
+    cursor:text;
+    color:#444444;
+    font-weight:bold;
+}
+span.pleft {
+    padding-left:2.5em;
+}
+span.color_p {
+    font-style:italic;
+    color:Brown;
+}
+span.param {
+    font-style:italic;
+}
+span.focus_p {
+    font-style:italic;
+    background-color:#DCDCDC;
+}
+span.ttype {
+    font-weight:normal;
+}
+span.nowrap {
+    white-space:nowrap;
+}
+span.value {
+    white-space:nowrap;
+    font-weight:bold;
+}
+.passed {
+    background-color:#CCFFCC;
+    font-weight:normal;
+}
+.warning {
+    background-color:#F4F4AF;
+    font-weight:normal;
+}
+.failed {
+    background-color:#FFCCCC;
+    font-weight:normal;
+}
+.new {
+    background-color:#C6DEFF;
+    font-weight:normal;
+}
+
+.compatible {
+    background-color:#CCFFCC;
+    font-weight:normal;
+}
+.almost_compatible {
+    background-color:#FFDAA3;
+    font-weight:normal;
+}
+.incompatible {
+    background-color:#FFCCCC;
+    font-weight:normal;
+}
+.gray {
+    background-color:#DCDCDC;
+    font-weight:normal;
+}
+
+.top_ref {
+    font-size:0.69em;
+}
+.footer {
+    font-size:0.8125em;
+}
+.tabset {
+    float:left;
+}
+a.tab {
+    border:1px solid Black;
+    float:left;
+    margin:0px 5px -1px 0px;
+    padding:3px 5px 3px 5px;
+    position:relative;
+    font-size:0.875em;
+    background-color:#DDD;
+    text-decoration:none;
+    color:Black;
+}
+a.disabled:hover
+{
+    color:Black;
+    background:#EEE;
+}
+a.active:hover
+{
+    color:Black;
+    background:White;
+}
+a.active {
+    border-bottom-color:White;
+    background-color:White;
+}
+div.tab {
+    border-top:1px solid Black;
+    padding:0px;
+    width:100%;
+    clear:both;
+}
+
+</style>
+<script type="text/javascript" language="JavaScript">
+<!--
+function sC(header, id)
+{
+    e = document.getElementById(id);
+    if(e.style.display == 'none')
+    {
+        e.style.display = 'block';
+        e.style.visibility = 'visible';
+        header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi, "[&minus;]");
+    }
+    else
+    {
+        e.style.display = 'none';
+        e.style.visibility = 'hidden';
+        header.innerHTML = header.innerHTML.replace(/\[[^0-9 ]\]/gi, "[+]");
+    }
+}
+function initTabs()
+{
+    var url = window.location.href;
+    if(url.indexOf('_Source_')!=-1 || url.indexOf('#Source')!=-1)
+    {
+        var tab1 = document.getElementById('BinaryID');
+        var tab2 = document.getElementById('SourceID');
+        tab1.className='tab disabled';
+        tab2.className='tab active';
+    }
+    
+    var sets = document.getElementsByTagName('div');
+    for (var i = 0; i < sets.length; i++)
+    {
+        if (sets[i].className.indexOf('tabset') != -1)
+        {
+            var tabs = [];
+            var links = sets[i].getElementsByTagName('a');
+            for (var j = 0; j < links.length; j++)
+            {
+                if (links[j].className.indexOf('tab') != -1)
+                {
+                    tabs.push(links[j]);
+                    links[j].tabs = tabs;
+                    var tab = document.getElementById(links[j].href.substr(links[j].href.indexOf('#') + 1));
+                    //reset all tabs on start
+                    if (tab)
+                    {
+                        if (links[j].className.indexOf('active')!=-1) {
+                            tab.style.display = 'block';
+                        }
+                        else {
+                            tab.style.display = 'none';
+                        }
+                    }
+                    links[j].onclick = function()
+                    {
+                        var tab = document.getElementById(this.href.substr(this.href.indexOf('#') + 1));
+                        if (tab)
+                        {
+                            //reset all tabs before change
+                            for (var k = 0; k < this.tabs.length; k++)
+                            {
+                                document.getElementById(this.tabs[k].href.substr(this.tabs[k].href.indexOf('#') + 1)).style.display = 'none';
+                                this.tabs[k].className = this.tabs[k].className.replace('active', 'disabled');
+                            }
+                            this.className = 'tab active';
+                            tab.style.display = 'block';
+                            // window.location.hash = this.id.replace('ID', '');
+                            return false;
+                        }
+                    }
+                }
+            }
+        }
+    }
+    
+    if(url.indexOf('#')!=-1) {
+        location.href=location.href;
+    }
+}
+
+if (window.addEventListener) window.addEventListener('load', initTabs, false);
+else if (window.attachEvent) window.attachEvent('onload', initTabs);
+
+-->
+</script>
+</head>
+<body><a name='Source'></a><a name='Binary'></a><a name='Top'></a><h1>API compatibility report for the <span style='color:Blue;'>hbase</span> library between <span style='color:Red;'>rel/2.3.1</span> and <span style='color:Red;'>2.3.2RC4</span> versions</h1>
+<br/><div class='tabset'>
+<a id='BinaryID' href='#BinaryTab' class='tab active'>Binary<br/>Compatibility</a>
+<a id='SourceID' href='#SourceTab' style='margin-left:3px' class='tab disabled'>Source<br/>Compatibility</a>
+</div>
+<div id='BinaryTab' class='tab'>
+<h2>Test Info</h2><hr/>
+<table class='summary'>
+<tr><th>Library Name</th><td>hbase</td></tr>
+<tr><th>Version #1</th><td>rel/2.3.1</td></tr>
+<tr><th>Version #2</th><td>2.3.2RC4</td></tr>
+<tr><th>Subject</th><td width='150px'>Binary Compatibility</td></tr>
+</table>
+<h2>Test Results</h2><hr/>
+<table class='summary'>
+<tr><th>Total Java Modules</th><td><a href='#Checked_Archives' style='color:Blue;'>13</a></td></tr>
+<tr><th>Total Methods / Classes</th><td>6679 / 577</td></tr>
+<tr><th>Compatibility</th>
+<td class='compatible'>100%</td>
+</tr>
+</table>
+<h2>Problem Summary</h2><hr/>
+<table class='summary'>
+<tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr>
+<tr><th>Added Methods</th><td>-</td><td class='new'><a href='#Binary_Added' style='color:Blue;'>3</a></td></tr>
+<tr><th>Removed Methods</th><td>High</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Methods</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+</table>
+
+<a name='Binary_Added'></a><h2>Added Methods <span class='new'>&nbsp;3&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.3.2.jar</span>, <span class='cname'>LockTimeoutException.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_1')">
+LockTimeoutException.LockTimeoutException&#160;<span class='sym_p'><span>(&#160;String <span class='color_p'>message</span></span>&#160;)</span></span>
+<br/>
+<div id="c_1" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/LockTimeoutException.&quot;&lt;init&gt;&quot;:(Ljava/lang/String;)V</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-mapreduce-2.3.2.jar</span>, <span class='cname'>TableRecordReaderImpl.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.mapreduce</span><br/>
+<span class="section" onclick="sC(this, 'c_2')">
+TableRecordReaderImpl.updateCounters&#160;<span class='sym_p'><span>(&#160;ScanMetrics <span class='color_p'>scanMetrics</span></span>, <span>long <span class='color_p'>numScannerRestarts</span></span>, <span>TaskAttemptContext <span class='color_p'>context</span></span>, <span>long <span class='color_p'>numStale</span></span>&#160;)</span> <span class='attr'>[static]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;void</span></span>
+<br/>
+<div id="c_2" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/mapreduce/TableRecordReaderImpl.updateCounters:(Lorg/apache/hadoop/hbase/client/metrics/ScanMetrics;JLorg/apache/hadoop/mapreduce/TaskAttemptContext;J)V</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.3.2.jar</span>, <span class='cname'>LoadIncrementalHFiles.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.tool</span><br/>
+<span class="section" onclick="sC(this, 'c_3')">
+LoadIncrementalHFiles.initialize&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;void</span></span>
+<br/>
+<div id="c_3" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/LoadIncrementalHFiles.initialize:()V</span><br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Checked_Archives'></a><h2>Java Archives <span class='gray'>&nbsp;13&nbsp;</span></h2>
+<hr/><div class='jar_list'>
+hbase-client-project-2.3.1.jar<br/>
+hbase-endpoint-2.3.1.jar<br/>
+hbase-examples-2.3.1.jar<br/>
+hbase-external-blockcache-2.3.1.jar<br/>
+hbase-hbtop-2.3.1.jar<br/>
+hbase-protocol-2.3.1.jar<br/>
+hbase-rest-2.3.1.jar<br/>
+hbase-rsgroup-2.3.1.jar<br/>
+hbase-shaded-client-byo-hadoop-2.3.1.jar<br/>
+hbase-shaded-client-project-2.3.1.jar<br/>
+hbase-shaded-mapreduce-2.3.1.jar<br/>
+hbase-shaded-testing-util-2.3.1.jar<br/>
+hbase-thrift-2.3.1.jar<br/>
+</div><br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<br/><br/><br/></div><div id='SourceTab' class='tab'>
+<h2>Test Info</h2><hr/>
+<table class='summary'>
+<tr><th>Library Name</th><td>hbase</td></tr>
+<tr><th>Version #1</th><td>rel/2.3.1</td></tr>
+<tr><th>Version #2</th><td>2.3.2RC4</td></tr>
+<tr><th>Subject</th><td width='150px'>Source Compatibility</td></tr>
+</table>
+<h2>Test Results</h2><hr/>
+<table class='summary'>
+<tr><th>Total Java Modules</th><td><a href='#Checked_Archives' style='color:Blue;'>13</a></td></tr>
+<tr><th>Total Methods / Classes</th><td>6679 / 577</td></tr>
+<tr><th>Compatibility</th>
+<td class='compatible'>100%</td>
+</tr>
+</table>
+<h2>Problem Summary</h2><hr/>
+<table class='summary'>
+<tr><th></th><th style='text-align:center;'>Severity</th><th style='text-align:center;'>Count</th></tr>
+<tr><th>Added Methods</th><td>-</td><td class='new'><a href='#Source_Added' style='color:Blue;'>3</a></td></tr>
+<tr><th>Removed Methods</th><td>High</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Data Types</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+<tr><th rowspan='3'>Problems with<br/>Methods</th><td>High</td><td>0</td></tr>
+<tr><td>Medium</td><td>0</td></tr>
+<tr><td>Low</td><td>0</td></tr>
+</table>
+
+<a name='Source_Added'></a><h2>Added Methods <span class='new'>&nbsp;3&nbsp;</span></h2><hr/>
+<span class='jar'>hbase-shaded-client-byo-hadoop-2.3.2.jar</span>, <span class='cname'>LockTimeoutException.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.client</span><br/>
+<span class="section" onclick="sC(this, 'c_4')">
+LockTimeoutException.LockTimeoutException&#160;<span class='sym_p'><span>(&#160;String <span class='color_p'>message</span></span>&#160;)</span></span>
+<br/>
+<div id="c_4" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/client/LockTimeoutException.&quot;&lt;init&gt;&quot;:(Ljava/lang/String;)V</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-mapreduce-2.3.2.jar</span>, <span class='cname'>TableRecordReaderImpl.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.mapreduce</span><br/>
+<span class="section" onclick="sC(this, 'c_5')">
+TableRecordReaderImpl.updateCounters&#160;<span class='sym_p'><span>(&#160;ScanMetrics <span class='color_p'>scanMetrics</span></span>, <span>long <span class='color_p'>numScannerRestarts</span></span>, <span>TaskAttemptContext <span class='color_p'>context</span></span>, <span>long <span class='color_p'>numStale</span></span>&#160;)</span> <span class='attr'>[static]</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;void</span></span>
+<br/>
+<div id="c_5" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/mapreduce/TableRecordReaderImpl.updateCounters:(Lorg/apache/hadoop/hbase/client/metrics/ScanMetrics;JLorg/apache/hadoop/mapreduce/TaskAttemptContext;J)V</span><br/><br/></div>
+
+<br/>
+<span class='jar'>hbase-shaded-testing-util-2.3.2.jar</span>, <span class='cname'>LoadIncrementalHFiles.class</span><br/>
+<span class='pkg_t'>package</span> <span class='pkg'>org.apache.hadoop.hbase.tool</span><br/>
+<span class="section" onclick="sC(this, 'c_6')">
+LoadIncrementalHFiles.initialize&#160;<span class='sym_p'>(&#160;)</span><span class='sym_p nowrap'> &#160;<b>:</b>&#160;&#160;void</span></span>
+<br/>
+<div id="c_6" style="display:none;">
+<span class='mngl'>org/apache/hadoop/hbase/tool/LoadIncrementalHFiles.initialize:()V</span><br/><br/></div>
+
+<br/>
+<a class='top_ref' href='#Top'>to the top</a><br/>
+<a name='Checked_Archives'></a><h2>Java Archives <span class='gray'>&nbsp;13&nbsp;</span></h2>
+<hr/><div class='jar_list'>
+hbase-client-project-2.3.1.jar<br/>
+hbase-endpoint-2.3.1.jar<br/>
+hbase-examples-2.3.1.jar<br/>
+hbase-external-blockcache-2.3.1.jar<br/>
+hbase-hbtop-2.3.1.jar<br/>
+hbase-protocol-2.3.1.jar<br/>
+hbase-rest-2.3.1.jar<br/>
+hbase-rsgroup-2.3.1.jar<br/>
+hbase-shaded-client-byo-hadoop-2.3.1.jar<br/>
+hbase-shaded-client-project-2.3.1.jar<br/>
+hbase-shaded-mapreduce-2.3.1.jar<br/>
+hbase-shaded-testing-util-2.3.1.jar<br/>
+hbase-thrift-2.3.1.jar<br/>
+</div><br/><a class='top_ref' href='#Top'>to the top</a><br/>
+<br/><br/><br/></div><hr/><div class='footer' align='right'><i>Generated by <a href='https://github.com/lvc/japi-compliance-checker'>Java API Compliance Checker</a> 2.4 &#160;</i></div><br/>
+</body></html>
\ No newline at end of file

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz
==============================================================================
Binary file - no diff available.

Propchange: dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.asc
==============================================================================
--- dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.asc (added)
+++ dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.asc Mon Sep 21 18:05:57 2020
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEEJKMPW+8OPec7XENEs9bAtByK39UFAl9nZ4sACgkQs9bAtByK
+39V99RAAmIdV53vMWhvEFNmJ7KryxoIJ2oXY9r2NS1WkJ8+L3NP97tatnHzUhIWr
+vqO4c8z8XfmvJfj8Or9tx8Li/OZzz/0NGGeQIhoYETFbjg+dNNHsRnQFkIk9zQPD
+Jt/1iGJXMhNF81vMqtW8/ysVCFUyfJ+FW4EAPm4hwWNP/AQnPBQnjcBscmc0r55d
+puMVR4CK2YbdDgq/xeJgRnvXYS/cqo6mLdb1/aMOWQ8YHq3t7gzx1HKiFd95L6wf
+OLnNeLqgLEHWfDMjcyl0szL7P5KMNavA34wdrTnbV19FCZ05VCQsVNSacbhR8+oH
+3LjCMd6VEK9iIqkE0qsS0Q9ne3hFhRycpb6IIX9scURrsUibE7R82Q+xzI2Ic4lb
+0BgyolVeGpw2Ti6/NFdsWms6cZ8YiWVT4tP3FcfpzuzyJQ8RFXhdrPhszmyr2TAB
+EiZYMTHvDyv3fjwmd7Tzl10Vo8CW1cK/CjeWXMz7g2s7rdh/lJot7WYglBCK0lMo
+UlroAy3xIcJxuoPrEkm66YLB17GEHWug8o6YGMyptHgPjA0gBYIgVIsuBeN1SNyc
+aDzCv+a/hSCl1vO4SsTw81Pj28KHJbcwtOpSSDZdSRT2/Ifi/HbM8+yUk1kfO5YE
+75UM8x5ZRUnAI88LYJjKXzNK/s2HF+tLge/wPz23dBCDLjAhqSg=
+=KXTj
+-----END PGP SIGNATURE-----

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.sha512
==============================================================================
--- dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.sha512 (added)
+++ dev/hbase/2.3.2RC4/hbase-2.3.2-bin.tar.gz.sha512 Mon Sep 21 18:05:57 2020
@@ -0,0 +1,3 @@
+hbase-2.3.2-bin.tar.gz: DB79A60B 632AE9DF BCD5B6A5 FEA6EF4A E317822C A4555FD7
+                        57E988C9 9D858B0B 1A2496B3 6CE8156C 6FA6B5DC 0617B492
+                        7E307469 CBE0F236 27D92AC6 0214AFAF

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz
==============================================================================
Binary file - no diff available.

Propchange: dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.asc
==============================================================================
--- dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.asc (added)
+++ dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.asc Mon Sep 21 18:05:57 2020
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEEJKMPW+8OPec7XENEs9bAtByK39UFAl9nZ40ACgkQs9bAtByK
+39VDKA//co9fM7MINMyIuCey0cxz5wVxXb5AiMBPul7XXGloIv9sqGifxOXfixJJ
+BJ73rnPOhzrMeC6l57oR7o+0k3Qs/55ifYp47Wvw7I5jhFj/0irbfCi++MlzE47i
+JhuAPRlhEEbK8pxRpgeh+kSRWUnf6A2P/ceqchAjQe+uGII+oMXz1q80j5mDt3N8
++JP+u+yeAxQSpcZMhRGD1/kBgNfgHifGTfaY20YNyNuuD3wWgWgPNYWgNg4MuWKL
+rITzIBmw/qfWeHGqceEaocNntGY8aoEz+h1geDZTdV2b8NwQMZhGgOEzmxqD567a
+R+MIXL1ExJ2pdKYDq7rDRdcMzwNWqwGJ+NhaJLJ9vYuGe8RoOtIkzb+8BXRiSW2N
+kk/hVNFYd6+R1hV/WhAd9rdK6RAIWyJPvt2IesnX0NAk5lIOdX4P1w4dh8WTtZ+u
+Q4SLIASxRz+X/Z7nAEl502lz5XQtGZER8ICMS5mMJJneklVH/ncGTX5dgOaEPQbq
+xD3L3aeO23G0tIT6iRMkO+WJobJI9RY7BWd6KmYurtggua4J5Oil+0d2v2jVj2sQ
+AjhQ+MEGHz261pPth2s9emzJfCDK2x0bwlboy5D536qTdkyp0Wdbwy/CEcpFZnff
+A2Q39QPZhEH+ql9YqqNZ+dspgIeQ3dqINbCnRQrkxjO66ZYvrYo=
+=nSXf
+-----END PGP SIGNATURE-----

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.sha512
==============================================================================
--- dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.sha512 (added)
+++ dev/hbase/2.3.2RC4/hbase-2.3.2-client-bin.tar.gz.sha512 Mon Sep 21 18:05:57 2020
@@ -0,0 +1,4 @@
+hbase-2.3.2-client-bin.tar.gz: C9BC54E6 D30E1CFF 9F81B85C 3A203373 9CE62488
+                               B5158FE5 1EAFCFE8 A21FFCF9 25A04F6A 1D69B14A
+                               CB6EFAE4 AE66B1E3 5358918B 4BFF8E47 23986B18
+                               A6A8810F

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz
==============================================================================
Binary file - no diff available.

Propchange: dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz
------------------------------------------------------------------------------
    svn:mime-type = application/octet-stream

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.asc
==============================================================================
--- dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.asc (added)
+++ dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.asc Mon Sep 21 18:05:57 2020
@@ -0,0 +1,16 @@
+-----BEGIN PGP SIGNATURE-----
+
+iQIzBAABCgAdFiEEJKMPW+8OPec7XENEs9bAtByK39UFAl9nVzAACgkQs9bAtByK
+39U7eg//X21DgY+v+Rml0JEUcEcGTYIiFksGInmLMCr6rZY5QuR5LpS4e4gI8yht
+xY5p4zrIVOhSU5BTxPmDbhEU2ghftHRlQ2nBuYDbXSppbMDPx5qTwQZHKIM50p1w
+yjWUSUo8+eCbGvofPgmHMUoeWKaa0U7586NEdN7AF+Usnm4MgaCZ8ffX1o6BxRJ8
+fsevVX3Su2jQycVVGDVMLO48b0dmVmA6Ll9zIsBt/XfcVegLJf4CvEhVt/H23csp
+juerLM0u1TsS3IY1v8AWYTID6fqzNm+15to8SxFIDk5vBNQKAyqpEbV+jQlq+VQM
+YhUsSsXioVEgPfkT5QeGxWMHvq4yhpVY3a2XC5BK4cB9nzPkpa8v6Uk9HPxnKwb6
+m9FwS1Mw+ahkL+9sJyEGOXf72d7YbcoueyR1buvmS4FEuyz25UR5mYNAwbr3PEY0
+QGQbErMnCHVh7kQV2uklmmNO13veaYbBMzqvnmP23ku4FYaVPgS2G7I1Kd8rhEMi
+OkgOfeA1AJP5ZtccS1PVsW8N3aj2YJqQ5cMYfXc+um7de+Fz1USYRPBoRG6D9yMJ
+Ofu7PrQRWTdqzzsz8IWHXLNhrzNlGnZEbxDQCy2uAoXQLjBM62U7mOQCsnKaqyG8
+BspM++3KdFKoNyP2g7T4zMy4PFZZMZaEtYFQpPMsicmH7fFV15s=
+=TcEi
+-----END PGP SIGNATURE-----

Added: dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.sha512
==============================================================================
--- dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.sha512 (added)
+++ dev/hbase/2.3.2RC4/hbase-2.3.2-src.tar.gz.sha512 Mon Sep 21 18:05:57 2020
@@ -0,0 +1,3 @@
+hbase-2.3.2-src.tar.gz: 777CEE52 8E2E36B3 68C7BAF7 96412979 8978CD2B AAA557AD
+                        8A56F551 199F4CB7 F15F1EF2 E002E38C 858E01F6 857E6CC2
+                        A716744F 4145D8DD E5DE58D2 12178815