http://git-wip-us.apache.org/repos/asf/incubator-tephra/blob/49c6e8bd/src/site/resources/apidocs/org/apache/tephra/distributed/RetryStrategyProvider.html
----------------------------------------------------------------------
diff --git 
a/src/site/resources/apidocs/org/apache/tephra/distributed/RetryStrategyProvider.html
 
b/src/site/resources/apidocs/org/apache/tephra/distributed/RetryStrategyProvider.html
new file mode 100644
index 0000000..d133a58
--- /dev/null
+++ 
b/src/site/resources/apidocs/org/apache/tephra/distributed/RetryStrategyProvider.html
@@ -0,0 +1,234 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc (version 1.7.0_80) on Mon Sep 19 21:33:27 PDT 2016 
-->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>RetryStrategyProvider (Apache Tephra 0.10.0-incubating-SNAPSHOT 
API)</title>
+<meta name="date" content="2016-09-19">
+<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" 
title="Style">
+</head>
+<body>
+<script type="text/javascript"><!--
+    if (location.href.indexOf('is-external=true') == -1) {
+        parent.document.title="RetryStrategyProvider (Apache Tephra 
0.10.0-incubating-SNAPSHOT API)";
+    }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar_top">
+<!--   -->
+</a><a href="#skip-navbar_top" title="Skip navigation links"></a><a 
name="navbar_top_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/RetryStrategyProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a href="../../../../org/apache/tephra/distributed/RetryWithBackoff.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/RetryStrategyProvider.html"
 target="_top">Frames</a></li>
+<li><a href="RetryStrategyProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_top");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li>Nested&nbsp;|&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li>Constr&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li>Constr&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_top">
+<!--   -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.tephra.distributed</div>
+<h2 title="Interface RetryStrategyProvider" class="title">Interface 
RetryStrategyProvider</h2>
+</div>
+<div class="contentContainer">
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<dl>
+<dt>All Known Implementing Classes:</dt>
+<dd><a 
href="../../../../org/apache/tephra/distributed/RetryNTimes.Provider.html" 
title="class in org.apache.tephra.distributed">RetryNTimes.Provider</a>, <a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html" 
title="class in 
org.apache.tephra.distributed">RetryWithBackoff.Provider</a></dd>
+</dl>
+<hr>
+<br>
+<pre>public interface <span class="strong">RetryStrategyProvider</span></pre>
+<div class="block">A retry strategy provider is used by the tx client to get a 
new retry strategy for every call.</div>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_summary">
+<!--   -->
+</a>
+<h3>Method Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Method Summary table, listing methods, and an explanation">
+<caption><span>Methods</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Method and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html#configure(org.apache.hadoop.conf.Configuration)">configure</a></strong>(org.apache.hadoop.conf.Configuration&nbsp;config)</code>
+<div class="block">Configure the strategy.</div>
+</td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in org.apache.tephra.distributed">RetryStrategy</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html#newRetryStrategy()">newRetryStrategy</a></strong>()</code>
+<div class="block">Provides a new instance of a retry strategy.</div>
+</td>
+</tr>
+</table>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ============ METHOD DETAIL ========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_detail">
+<!--   -->
+</a>
+<h3>Method Detail</h3>
+<a name="newRetryStrategy()">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>newRetryStrategy</h4>
+<pre><a href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in 
org.apache.tephra.distributed">RetryStrategy</a>&nbsp;newRetryStrategy()</pre>
+<div class="block">Provides a new instance of a retry strategy.</div>
+<dl><dt><span class="strong">Returns:</span></dt><dd>a retry strategy</dd></dl>
+</li>
+</ul>
+<a name="configure(org.apache.hadoop.conf.Configuration)">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>configure</h4>
+<pre>void&nbsp;configure(org.apache.hadoop.conf.Configuration&nbsp;config)</pre>
+<div class="block">Configure the strategy.</div>
+<dl><dt><span class="strong">Parameters:</span></dt><dd><code>config</code> - 
the configuration</dd></dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar_bottom">
+<!--   -->
+</a><a href="#skip-navbar_bottom" title="Skip navigation links"></a><a 
name="navbar_bottom_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/RetryStrategyProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a href="../../../../org/apache/tephra/distributed/RetryWithBackoff.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/RetryStrategyProvider.html"
 target="_top">Frames</a></li>
+<li><a href="RetryStrategyProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_bottom");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li>Nested&nbsp;|&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li>Constr&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li>Constr&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_bottom">
+<!--   -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright &#169; 2016 <a 
href="http://www.apache.org";>The Apache Software Foundation</a>. All rights 
reserved.</small></p>
+</body>
+</html>

http://git-wip-us.apache.org/repos/asf/incubator-tephra/blob/49c6e8bd/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.Provider.html
----------------------------------------------------------------------
diff --git 
a/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.Provider.html
 
b/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.Provider.html
new file mode 100644
index 0000000..05e2628
--- /dev/null
+++ 
b/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.Provider.html
@@ -0,0 +1,314 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc (version 1.7.0_80) on Mon Sep 19 21:33:27 PDT 2016 
-->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>RetryWithBackoff.Provider (Apache Tephra 0.10.0-incubating-SNAPSHOT 
API)</title>
+<meta name="date" content="2016-09-19">
+<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" 
title="Style">
+</head>
+<body>
+<script type="text/javascript"><!--
+    if (location.href.indexOf('is-external=true') == -1) {
+        parent.document.title="RetryWithBackoff.Provider (Apache Tephra 
0.10.0-incubating-SNAPSHOT API)";
+    }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar_top">
+<!--   -->
+</a><a href="#skip-navbar_top" title="Skip navigation links"></a><a 
name="navbar_top_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/RetryWithBackoff.Provider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../org/apache/tephra/distributed/RetryWithBackoff.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/RetryWithBackoff.Provider.html"
 target="_top">Frames</a></li>
+<li><a href="RetryWithBackoff.Provider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_top");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li>Nested&nbsp;|&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_top">
+<!--   -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.tephra.distributed</div>
+<h2 title="Class RetryWithBackoff.Provider" class="title">Class 
RetryWithBackoff.Provider</h2>
+</div>
+<div class="contentContainer">
+<ul class="inheritance">
+<li><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">java.lang.Object</a></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.tephra.distributed.RetryWithBackoff.Provider</li>
+</ul>
+</li>
+</ul>
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<dl>
+<dt>All Implemented Interfaces:</dt>
+<dd><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html" 
title="interface in 
org.apache.tephra.distributed">RetryStrategyProvider</a></dd>
+</dl>
+<dl>
+<dt>Enclosing class:</dt>
+<dd><a href="../../../../org/apache/tephra/distributed/RetryWithBackoff.html" 
title="class in org.apache.tephra.distributed">RetryWithBackoff</a></dd>
+</dl>
+<hr>
+<br>
+<pre>public static class <span class="strong">RetryWithBackoff.Provider</span>
+extends <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a>
+implements <a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html" 
title="interface in 
org.apache.tephra.distributed">RetryStrategyProvider</a></pre>
+<div class="block">A provider for this retry strategy.</div>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ======== CONSTRUCTOR SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_summary">
+<!--   -->
+</a>
+<h3>Constructor Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
+<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colOne" scope="col">Constructor and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colOne"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html#RetryWithBackoff.Provider()">RetryWithBackoff.Provider</a></strong>()</code>&nbsp;</td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_summary">
+<!--   -->
+</a>
+<h3>Method Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Method Summary table, listing methods, and an explanation">
+<caption><span>Methods</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Method and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html#configure(org.apache.hadoop.conf.Configuration)">configure</a></strong>(org.apache.hadoop.conf.Configuration&nbsp;config)</code>
+<div class="block">Configure the strategy.</div>
+</td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in org.apache.tephra.distributed">RetryStrategy</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html#newRetryStrategy()">newRetryStrategy</a></strong>()</code>
+<div class="block">Provides a new instance of a retry strategy.</div>
+</td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/String.html?is-external=true";
 title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html#toString()">toString</a></strong>()</code>&nbsp;</td>
+</tr>
+</table>
+<ul class="blockList">
+<li class="blockList"><a name="methods_inherited_from_class_java.lang.Object">
+<!--   -->
+</a>
+<h3>Methods inherited from class&nbsp;java.lang.<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></h3>
+<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#clone()"
 title="class or interface in java.lang">clone</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#equals(java.lang.Object)"
 title="class or interface in java.lang">equals</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#finalize()"
 title="class or interface in java.lang">finalize</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#getClass()"
 title="class or interface in java.lang">getClass</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#hashCode()"
 title="class or interface in java.lang">hashCode</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#notify()"
 title="class or interface in java.lang">notify</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang
 /Object.html?is-external=true#notifyAll()" title="class or interface in 
java.lang">notifyAll</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait()"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long)"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long,%20int)"
 title="class or interface in java.lang">wait</a></code></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ========= CONSTRUCTOR DETAIL ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_detail">
+<!--   -->
+</a>
+<h3>Constructor Detail</h3>
+<a name="RetryWithBackoff.Provider()">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>RetryWithBackoff.Provider</h4>
+<pre>public&nbsp;RetryWithBackoff.Provider()</pre>
+</li>
+</ul>
+</li>
+</ul>
+<!-- ============ METHOD DETAIL ========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_detail">
+<!--   -->
+</a>
+<h3>Method Detail</h3>
+<a name="configure(org.apache.hadoop.conf.Configuration)">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>configure</h4>
+<pre>public&nbsp;void&nbsp;configure(org.apache.hadoop.conf.Configuration&nbsp;config)</pre>
+<div class="block"><strong>Description copied from interface:&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html#configure(org.apache.hadoop.conf.Configuration)">RetryStrategyProvider</a></code></strong></div>
+<div class="block">Configure the strategy.</div>
+<dl>
+<dt><strong>Specified by:</strong></dt>
+<dd><code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html#configure(org.apache.hadoop.conf.Configuration)">configure</a></code>&nbsp;in
 interface&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html" 
title="interface in 
org.apache.tephra.distributed">RetryStrategyProvider</a></code></dd>
+<dt><span class="strong">Parameters:</span></dt><dd><code>config</code> - the 
configuration</dd></dl>
+</li>
+</ul>
+<a name="newRetryStrategy()">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>newRetryStrategy</h4>
+<pre>public&nbsp;<a 
href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in 
org.apache.tephra.distributed">RetryStrategy</a>&nbsp;newRetryStrategy()</pre>
+<div class="block"><strong>Description copied from interface:&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html#newRetryStrategy()">RetryStrategyProvider</a></code></strong></div>
+<div class="block">Provides a new instance of a retry strategy.</div>
+<dl>
+<dt><strong>Specified by:</strong></dt>
+<dd><code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html#newRetryStrategy()">newRetryStrategy</a></code>&nbsp;in
 interface&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html" 
title="interface in 
org.apache.tephra.distributed">RetryStrategyProvider</a></code></dd>
+<dt><span class="strong">Returns:</span></dt><dd>a retry strategy</dd></dl>
+</li>
+</ul>
+<a name="toString()">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>toString</h4>
+<pre>public&nbsp;<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/String.html?is-external=true";
 title="class or interface in java.lang">String</a>&nbsp;toString()</pre>
+<dl>
+<dt><strong>Overrides:</strong></dt>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#toString()"
 title="class or interface in java.lang">toString</a></code>&nbsp;in 
class&nbsp;<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></code></dd>
+</dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar_bottom">
+<!--   -->
+</a><a href="#skip-navbar_bottom" title="Skip navigation links"></a><a 
name="navbar_bottom_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/RetryWithBackoff.Provider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a href="../../../../org/apache/tephra/distributed/RetryWithBackoff.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/RetryWithBackoff.Provider.html"
 target="_top">Frames</a></li>
+<li><a href="RetryWithBackoff.Provider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_bottom");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li>Nested&nbsp;|&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_bottom">
+<!--   -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright &#169; 2016 <a 
href="http://www.apache.org";>The Apache Software Foundation</a>. All rights 
reserved.</small></p>
+</body>
+</html>

http://git-wip-us.apache.org/repos/asf/incubator-tephra/blob/49c6e8bd/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.html
----------------------------------------------------------------------
diff --git 
a/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.html
 
b/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.html
new file mode 100644
index 0000000..761ceab
--- /dev/null
+++ 
b/src/site/resources/apidocs/org/apache/tephra/distributed/RetryWithBackoff.html
@@ -0,0 +1,268 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc (version 1.7.0_80) on Mon Sep 19 21:33:27 PDT 2016 
-->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>RetryWithBackoff (Apache Tephra 0.10.0-incubating-SNAPSHOT API)</title>
+<meta name="date" content="2016-09-19">
+<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" 
title="Style">
+</head>
+<body>
+<script type="text/javascript"><!--
+    if (location.href.indexOf('is-external=true') == -1) {
+        parent.document.title="RetryWithBackoff (Apache Tephra 
0.10.0-incubating-SNAPSHOT API)";
+    }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar_top">
+<!--   -->
+</a><a href="#skip-navbar_top" title="Skip navigation links"></a><a 
name="navbar_top_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/RetryWithBackoff.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html" 
title="interface in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/RetryWithBackoff.html"
 target="_top">Frames</a></li>
+<li><a href="RetryWithBackoff.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_top");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li><a href="#nested_class_summary">Nested</a>&nbsp;|&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#methods_inherited_from_class_java.lang.Object">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li>Method</li>
+</ul>
+</div>
+<a name="skip-navbar_top">
+<!--   -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.tephra.distributed</div>
+<h2 title="Class RetryWithBackoff" class="title">Class RetryWithBackoff</h2>
+</div>
+<div class="contentContainer">
+<ul class="inheritance">
+<li><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">java.lang.Object</a></li>
+<li>
+<ul class="inheritance">
+<li><a href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in 
org.apache.tephra.distributed">org.apache.tephra.distributed.RetryStrategy</a></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.tephra.distributed.RetryWithBackoff</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<hr>
+<br>
+<pre>public class <span class="strong">RetryWithBackoff</span>
+extends <a href="../../../../org/apache/tephra/distributed/RetryStrategy.html" 
title="class in org.apache.tephra.distributed">RetryStrategy</a></pre>
+<div class="block">A retry strategy that makes N attempts and then gives up. 
This does
+ not do anything before the re-attempt - extend this class to add a
+ sleep or similar.</div>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ======== NESTED CLASS SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="nested_class_summary">
+<!--   -->
+</a>
+<h3>Nested Class Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Nested Class Summary table, listing nested classes, and an 
explanation">
+<caption><span>Nested Classes</span><span 
class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Class and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>static class&nbsp;</code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html" 
title="class in 
org.apache.tephra.distributed">RetryWithBackoff.Provider</a></strong></code>
+<div class="block">A provider for this retry strategy.</div>
+</td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ======== CONSTRUCTOR SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_summary">
+<!--   -->
+</a>
+<h3>Constructor Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
+<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier</th>
+<th class="colLast" scope="col">Constructor and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code>protected </code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.html#RetryWithBackoff(int,%20int,%20int)">RetryWithBackoff</a></strong>(int&nbsp;initial,
+                int&nbsp;backoff,
+                int&nbsp;limit)</code>&nbsp;</td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_summary">
+<!--   -->
+</a>
+<h3>Method Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a name="methods_inherited_from_class_java.lang.Object">
+<!--   -->
+</a>
+<h3>Methods inherited from class&nbsp;java.lang.<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></h3>
+<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#clone()"
 title="class or interface in java.lang">clone</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#equals(java.lang.Object)"
 title="class or interface in java.lang">equals</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#finalize()"
 title="class or interface in java.lang">finalize</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#getClass()"
 title="class or interface in java.lang">getClass</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#hashCode()"
 title="class or interface in java.lang">hashCode</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#notify()"
 title="class or interface in java.lang">notify</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang
 /Object.html?is-external=true#notifyAll()" title="class or interface in 
java.lang">notifyAll</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#toString()"
 title="class or interface in java.lang">toString</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait()"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long)"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long,%20int)"
 title="class or interface in java.lang">wait</a></code></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ========= CONSTRUCTOR DETAIL ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_detail">
+<!--   -->
+</a>
+<h3>Constructor Detail</h3>
+<a name="RetryWithBackoff(int, int, int)">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>RetryWithBackoff</h4>
+<pre>protected&nbsp;RetryWithBackoff(int&nbsp;initial,
+                int&nbsp;backoff,
+                int&nbsp;limit)</pre>
+<dl><dt><span class="strong">Parameters:</span></dt><dd><code>initial</code> - 
the initial sleep time (before first retry)</dd><dd><code>backoff</code> - the 
backoff factor by which sleep time is multiplied
+                after each retry</dd><dd><code>limit</code> - the max sleep 
time. if sleep time reaches this limit, we
+              stop retrying</dd></dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar_bottom">
+<!--   -->
+</a><a href="#skip-navbar_bottom" title="Skip navigation links"></a><a 
name="navbar_bottom_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/RetryWithBackoff.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a 
href="../../../../org/apache/tephra/distributed/RetryStrategyProvider.html" 
title="interface in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/RetryWithBackoff.html"
 target="_top">Frames</a></li>
+<li><a href="RetryWithBackoff.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_bottom");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li><a href="#nested_class_summary">Nested</a>&nbsp;|&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#methods_inherited_from_class_java.lang.Object">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li>Method</li>
+</ul>
+</div>
+<a name="skip-navbar_bottom">
+<!--   -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright &#169; 2016 <a 
href="http://www.apache.org";>The Apache Software Foundation</a>. All rights 
reserved.</small></p>
+</body>
+</html>

http://git-wip-us.apache.org/repos/asf/incubator-tephra/blob/49c6e8bd/src/site/resources/apidocs/org/apache/tephra/distributed/SingleUseClientProvider.html
----------------------------------------------------------------------
diff --git 
a/src/site/resources/apidocs/org/apache/tephra/distributed/SingleUseClientProvider.html
 
b/src/site/resources/apidocs/org/apache/tephra/distributed/SingleUseClientProvider.html
new file mode 100644
index 0000000..4c6190c
--- /dev/null
+++ 
b/src/site/resources/apidocs/org/apache/tephra/distributed/SingleUseClientProvider.html
@@ -0,0 +1,362 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc (version 1.7.0_80) on Mon Sep 19 21:33:27 PDT 2016 
-->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>SingleUseClientProvider (Apache Tephra 0.10.0-incubating-SNAPSHOT 
API)</title>
+<meta name="date" content="2016-09-19">
+<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" 
title="Style">
+</head>
+<body>
+<script type="text/javascript"><!--
+    if (location.href.indexOf('is-external=true') == -1) {
+        parent.document.title="SingleUseClientProvider (Apache Tephra 
0.10.0-incubating-SNAPSHOT API)";
+    }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar_top">
+<!--   -->
+</a><a href="#skip-navbar_top" title="Skip navigation links"></a><a 
name="navbar_top_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/SingleUseClientProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/ThreadLocalClientProvider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/SingleUseClientProvider.html"
 target="_top">Frames</a></li>
+<li><a href="SingleUseClientProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_top");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li><a 
href="#nested_classes_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Nested</a>&nbsp;|&nbsp;</li>
+<li><a 
href="#fields_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Field</a>&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_top">
+<!--   -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.tephra.distributed</div>
+<h2 title="Class SingleUseClientProvider" class="title">Class 
SingleUseClientProvider</h2>
+</div>
+<div class="contentContainer">
+<ul class="inheritance">
+<li><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">java.lang.Object</a></li>
+<li>
+<ul class="inheritance">
+<li><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in 
org.apache.tephra.distributed">org.apache.tephra.distributed.AbstractClientProvider</a></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.tephra.distributed.SingleUseClientProvider</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<dl>
+<dt>All Implemented Interfaces:</dt>
+<dd><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html" 
title="interface in org.apache.tephra.distributed">ThriftClientProvider</a></dd>
+</dl>
+<hr>
+<br>
+<pre>public class <span class="strong">SingleUseClientProvider</span>
+extends <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></pre>
+<div class="block">An tx client provider that creates a new connection every 
time.</div>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ======== NESTED CLASS SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="nested_class_summary">
+<!--   -->
+</a>
+<h3>Nested Class Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a 
name="nested_classes_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">
+<!--   -->
+</a>
+<h3>Nested classes/interfaces inherited from 
class&nbsp;org.apache.tephra.distributed.<a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></h3>
+<code><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.EndpointStrategy.html"
 title="interface in 
org.apache.tephra.distributed">AbstractClientProvider.EndpointStrategy</a>, <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.RandomEndpointStrategy.html"
 title="class in 
org.apache.tephra.distributed">AbstractClientProvider.RandomEndpointStrategy</a>,
 <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.TimeLimitEndpointStrategy.html"
 title="class in 
org.apache.tephra.distributed">AbstractClientProvider.TimeLimitEndpointStrategy</a></code></li>
+</ul>
+</li>
+</ul>
+<!-- =========== FIELD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="field_summary">
+<!--   -->
+</a>
+<h3>Field Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a 
name="fields_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">
+<!--   -->
+</a>
+<h3>Fields inherited from class&nbsp;org.apache.tephra.distributed.<a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></h3>
+<code><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#initialized">initialized</a></code></li>
+</ul>
+</li>
+</ul>
+<!-- ======== CONSTRUCTOR SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_summary">
+<!--   -->
+</a>
+<h3>Constructor Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
+<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colOne" scope="col">Constructor and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colOne"><code><strong><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html#SingleUseClientProvider(org.apache.hadoop.conf.Configuration,%20org.apache.twill.discovery.DiscoveryServiceClient,%20int)">SingleUseClientProvider</a></strong>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+                       
org.apache.twill.discovery.DiscoveryServiceClient&nbsp;discoveryServiceClient,
+                       int&nbsp;timeout)</code>&nbsp;</td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_summary">
+<!--   -->
+</a>
+<h3>Method Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Method Summary table, listing methods, and an explanation">
+<caption><span>Methods</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Method and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code><a 
href="../../../../org/apache/tephra/distributed/CloseableThriftClient.html" 
title="class in 
org.apache.tephra.distributed">CloseableThriftClient</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html#getCloseableClient()">getCloseableClient</a></strong>()</code>
+<div class="block">Retrieve an AutoCloseable wrapper around  tx client for 
exclusive use by the
+ current thread.</div>
+</td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html#returnClient(org.apache.tephra.distributed.TransactionServiceThriftClient)">returnClient</a></strong>(<a
 
href="../../../../org/apache/tephra/distributed/TransactionServiceThriftClient.html"
 title="class in 
org.apache.tephra.distributed">TransactionServiceThriftClient</a>&nbsp;client)</code>
+<div class="block">Release an tx client back to the provider's pool, if the 
client is valid.</div>
+</td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/String.html?is-external=true";
 title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html#toString()">toString</a></strong>()</code>&nbsp;</td>
+</tr>
+</table>
+<ul class="blockList">
+<li class="blockList"><a 
name="methods_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">
+<!--   -->
+</a>
+<h3>Methods inherited from class&nbsp;org.apache.tephra.distributed.<a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></h3>
+<code><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#initialize()">initialize</a>,
 <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#newClient()">newClient</a>,
 <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#newClient(int)">newClient</a></code></li>
+</ul>
+<ul class="blockList">
+<li class="blockList"><a name="methods_inherited_from_class_java.lang.Object">
+<!--   -->
+</a>
+<h3>Methods inherited from class&nbsp;java.lang.<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></h3>
+<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#clone()"
 title="class or interface in java.lang">clone</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#equals(java.lang.Object)"
 title="class or interface in java.lang">equals</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#finalize()"
 title="class or interface in java.lang">finalize</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#getClass()"
 title="class or interface in java.lang">getClass</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#hashCode()"
 title="class or interface in java.lang">hashCode</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#notify()"
 title="class or interface in java.lang">notify</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang
 /Object.html?is-external=true#notifyAll()" title="class or interface in 
java.lang">notifyAll</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait()"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long)"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long,%20int)"
 title="class or interface in java.lang">wait</a></code></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ========= CONSTRUCTOR DETAIL ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_detail">
+<!--   -->
+</a>
+<h3>Constructor Detail</h3>
+<a name="SingleUseClientProvider(org.apache.hadoop.conf.Configuration, 
org.apache.twill.discovery.DiscoveryServiceClient, int)">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>SingleUseClientProvider</h4>
+<pre>public&nbsp;SingleUseClientProvider(org.apache.hadoop.conf.Configuration&nbsp;conf,
+                       
org.apache.twill.discovery.DiscoveryServiceClient&nbsp;discoveryServiceClient,
+                       int&nbsp;timeout)</pre>
+</li>
+</ul>
+</li>
+</ul>
+<!-- ============ METHOD DETAIL ========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_detail">
+<!--   -->
+</a>
+<h3>Method Detail</h3>
+<a name="getCloseableClient()">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>getCloseableClient</h4>
+<pre>public&nbsp;<a 
href="../../../../org/apache/tephra/distributed/CloseableThriftClient.html" 
title="class in 
org.apache.tephra.distributed">CloseableThriftClient</a>&nbsp;getCloseableClient()
+                                         throws org.apache.thrift.TException,
+                                                <a 
href="http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/TimeoutException.html?is-external=true";
 title="class or interface in java.util.concurrent">TimeoutException</a>,
+                                                <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/InterruptedException.html?is-external=true";
 title="class or interface in java.lang">InterruptedException</a></pre>
+<div class="block"><strong>Description copied from interface:&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html#getCloseableClient()">ThriftClientProvider</a></code></strong></div>
+<div class="block">Retrieve an AutoCloseable wrapper around  tx client for 
exclusive use by the
+ current thread. The client must be closed (returned) to the provider after 
use.</div>
+<dl><dt><span class="strong">Returns:</span></dt><dd>an tx client, connected 
and fully functional</dd>
+<dt><span class="strong">Throws:</span></dt>
+<dd><code>org.apache.thrift.TException</code></dd>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/TimeoutException.html?is-external=true";
 title="class or interface in 
java.util.concurrent">TimeoutException</a></code></dd>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/InterruptedException.html?is-external=true";
 title="class or interface in 
java.lang">InterruptedException</a></code></dd></dl>
+</li>
+</ul>
+<a 
name="returnClient(org.apache.tephra.distributed.TransactionServiceThriftClient)">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>returnClient</h4>
+<pre>public&nbsp;void&nbsp;returnClient(<a 
href="../../../../org/apache/tephra/distributed/TransactionServiceThriftClient.html"
 title="class in 
org.apache.tephra.distributed">TransactionServiceThriftClient</a>&nbsp;client)</pre>
+<div class="block"><strong>Description copied from interface:&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html#returnClient(org.apache.tephra.distributed.TransactionServiceThriftClient)">ThriftClientProvider</a></code></strong></div>
+<div class="block">Release an tx client back to the provider's pool, if the 
client is valid.
+ If the client becomes disfunctional, for instance, due to a socket
+ exception. The provider must make sure to close the client, and it
+ must remove the client from its arsenal and be prepared to create
+ a new client subsequently.</div>
+<dl><dt><span class="strong">Parameters:</span></dt><dd><code>client</code> - 
The client to return</dd></dl>
+</li>
+</ul>
+<a name="toString()">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>toString</h4>
+<pre>public&nbsp;<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/String.html?is-external=true";
 title="class or interface in java.lang">String</a>&nbsp;toString()</pre>
+<dl>
+<dt><strong>Overrides:</strong></dt>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#toString()"
 title="class or interface in java.lang">toString</a></code>&nbsp;in 
class&nbsp;<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></code></dd>
+</dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar_bottom">
+<!--   -->
+</a><a href="#skip-navbar_bottom" title="Skip navigation links"></a><a 
name="navbar_bottom_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/SingleUseClientProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a 
href="../../../../org/apache/tephra/distributed/RetryWithBackoff.Provider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/ThreadLocalClientProvider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/SingleUseClientProvider.html"
 target="_top">Frames</a></li>
+<li><a href="SingleUseClientProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_bottom");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li><a 
href="#nested_classes_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Nested</a>&nbsp;|&nbsp;</li>
+<li><a 
href="#fields_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Field</a>&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_bottom">
+<!--   -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright &#169; 2016 <a 
href="http://www.apache.org";>The Apache Software Foundation</a>. All rights 
reserved.</small></p>
+</body>
+</html>

http://git-wip-us.apache.org/repos/asf/incubator-tephra/blob/49c6e8bd/src/site/resources/apidocs/org/apache/tephra/distributed/ThreadLocalClientProvider.html
----------------------------------------------------------------------
diff --git 
a/src/site/resources/apidocs/org/apache/tephra/distributed/ThreadLocalClientProvider.html
 
b/src/site/resources/apidocs/org/apache/tephra/distributed/ThreadLocalClientProvider.html
new file mode 100644
index 0000000..8b7918e
--- /dev/null
+++ 
b/src/site/resources/apidocs/org/apache/tephra/distributed/ThreadLocalClientProvider.html
@@ -0,0 +1,361 @@
+<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" 
"http://www.w3.org/TR/html4/loose.dtd";>
+<!-- NewPage -->
+<html lang="en">
+<head>
+<!-- Generated by javadoc (version 1.7.0_80) on Mon Sep 19 21:33:27 PDT 2016 
-->
+<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+<title>ThreadLocalClientProvider (Apache Tephra 0.10.0-incubating-SNAPSHOT 
API)</title>
+<meta name="date" content="2016-09-19">
+<link rel="stylesheet" type="text/css" href="../../../../stylesheet.css" 
title="Style">
+</head>
+<body>
+<script type="text/javascript"><!--
+    if (location.href.indexOf('is-external=true') == -1) {
+        parent.document.title="ThreadLocalClientProvider (Apache Tephra 
0.10.0-incubating-SNAPSHOT API)";
+    }
+//-->
+</script>
+<noscript>
+<div>JavaScript is disabled on your browser.</div>
+</noscript>
+<!-- ========= START OF TOP NAVBAR ======= -->
+<div class="topNav"><a name="navbar_top">
+<!--   -->
+</a><a href="#skip-navbar_top" title="Skip navigation links"></a><a 
name="navbar_top_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/ThreadLocalClientProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html" 
title="interface in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/ThreadLocalClientProvider.html"
 target="_top">Frames</a></li>
+<li><a href="ThreadLocalClientProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_top">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_top");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li><a 
href="#nested_classes_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Nested</a>&nbsp;|&nbsp;</li>
+<li><a 
href="#fields_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Field</a>&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_top">
+<!--   -->
+</a></div>
+<!-- ========= END OF TOP NAVBAR ========= -->
+<!-- ======== START OF CLASS DATA ======== -->
+<div class="header">
+<div class="subTitle">org.apache.tephra.distributed</div>
+<h2 title="Class ThreadLocalClientProvider" class="title">Class 
ThreadLocalClientProvider</h2>
+</div>
+<div class="contentContainer">
+<ul class="inheritance">
+<li><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">java.lang.Object</a></li>
+<li>
+<ul class="inheritance">
+<li><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in 
org.apache.tephra.distributed">org.apache.tephra.distributed.AbstractClientProvider</a></li>
+<li>
+<ul class="inheritance">
+<li>org.apache.tephra.distributed.ThreadLocalClientProvider</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+<div class="description">
+<ul class="blockList">
+<li class="blockList">
+<dl>
+<dt>All Implemented Interfaces:</dt>
+<dd><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html" 
title="interface in org.apache.tephra.distributed">ThriftClientProvider</a></dd>
+</dl>
+<hr>
+<br>
+<pre>public class <span class="strong">ThreadLocalClientProvider</span>
+extends <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></pre>
+<div class="block">An tx client provider that uses thread local to maintain at 
most one open connection per thread.
+ Note that there can be a connection leak if the threads are recycled.</div>
+</li>
+</ul>
+</div>
+<div class="summary">
+<ul class="blockList">
+<li class="blockList">
+<!-- ======== NESTED CLASS SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="nested_class_summary">
+<!--   -->
+</a>
+<h3>Nested Class Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a 
name="nested_classes_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">
+<!--   -->
+</a>
+<h3>Nested classes/interfaces inherited from 
class&nbsp;org.apache.tephra.distributed.<a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></h3>
+<code><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.EndpointStrategy.html"
 title="interface in 
org.apache.tephra.distributed">AbstractClientProvider.EndpointStrategy</a>, <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.RandomEndpointStrategy.html"
 title="class in 
org.apache.tephra.distributed">AbstractClientProvider.RandomEndpointStrategy</a>,
 <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.TimeLimitEndpointStrategy.html"
 title="class in 
org.apache.tephra.distributed">AbstractClientProvider.TimeLimitEndpointStrategy</a></code></li>
+</ul>
+</li>
+</ul>
+<!-- =========== FIELD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="field_summary">
+<!--   -->
+</a>
+<h3>Field Summary</h3>
+<ul class="blockList">
+<li class="blockList"><a 
name="fields_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">
+<!--   -->
+</a>
+<h3>Fields inherited from class&nbsp;org.apache.tephra.distributed.<a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></h3>
+<code><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#initialized">initialized</a></code></li>
+</ul>
+</li>
+</ul>
+<!-- ======== CONSTRUCTOR SUMMARY ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_summary">
+<!--   -->
+</a>
+<h3>Constructor Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Constructor Summary table, listing constructors, and an explanation">
+<caption><span>Constructors</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colOne" scope="col">Constructor and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colOne"><code><strong><a 
href="../../../../org/apache/tephra/distributed/ThreadLocalClientProvider.html#ThreadLocalClientProvider(org.apache.hadoop.conf.Configuration,%20org.apache.twill.discovery.DiscoveryServiceClient)">ThreadLocalClientProvider</a></strong>(org.apache.hadoop.conf.Configuration&nbsp;conf,
+                         
org.apache.twill.discovery.DiscoveryServiceClient&nbsp;discoveryServiceClient)</code>&nbsp;</td>
+</tr>
+</table>
+</li>
+</ul>
+<!-- ========== METHOD SUMMARY =========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_summary">
+<!--   -->
+</a>
+<h3>Method Summary</h3>
+<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" 
summary="Method Summary table, listing methods, and an explanation">
+<caption><span>Methods</span><span class="tabEnd">&nbsp;</span></caption>
+<tr>
+<th class="colFirst" scope="col">Modifier and Type</th>
+<th class="colLast" scope="col">Method and Description</th>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code><a 
href="../../../../org/apache/tephra/distributed/CloseableThriftClient.html" 
title="class in 
org.apache.tephra.distributed">CloseableThriftClient</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/ThreadLocalClientProvider.html#getCloseableClient()">getCloseableClient</a></strong>()</code>
+<div class="block">Retrieve an AutoCloseable wrapper around  tx client for 
exclusive use by the
+ current thread.</div>
+</td>
+</tr>
+<tr class="rowColor">
+<td class="colFirst"><code>void</code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/ThreadLocalClientProvider.html#returnClient(org.apache.tephra.distributed.TransactionServiceThriftClient)">returnClient</a></strong>(<a
 
href="../../../../org/apache/tephra/distributed/TransactionServiceThriftClient.html"
 title="class in 
org.apache.tephra.distributed">TransactionServiceThriftClient</a>&nbsp;client)</code>
+<div class="block">Release an tx client back to the provider's pool, if the 
client is valid.</div>
+</td>
+</tr>
+<tr class="altColor">
+<td class="colFirst"><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/String.html?is-external=true";
 title="class or interface in java.lang">String</a></code></td>
+<td class="colLast"><code><strong><a 
href="../../../../org/apache/tephra/distributed/ThreadLocalClientProvider.html#toString()">toString</a></strong>()</code>&nbsp;</td>
+</tr>
+</table>
+<ul class="blockList">
+<li class="blockList"><a 
name="methods_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">
+<!--   -->
+</a>
+<h3>Methods inherited from class&nbsp;org.apache.tephra.distributed.<a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html" 
title="class in org.apache.tephra.distributed">AbstractClientProvider</a></h3>
+<code><a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#initialize()">initialize</a>,
 <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#newClient()">newClient</a>,
 <a 
href="../../../../org/apache/tephra/distributed/AbstractClientProvider.html#newClient(int)">newClient</a></code></li>
+</ul>
+<ul class="blockList">
+<li class="blockList"><a name="methods_inherited_from_class_java.lang.Object">
+<!--   -->
+</a>
+<h3>Methods inherited from class&nbsp;java.lang.<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></h3>
+<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#clone()"
 title="class or interface in java.lang">clone</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#equals(java.lang.Object)"
 title="class or interface in java.lang">equals</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#finalize()"
 title="class or interface in java.lang">finalize</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#getClass()"
 title="class or interface in java.lang">getClass</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#hashCode()"
 title="class or interface in java.lang">hashCode</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#notify()"
 title="class or interface in java.lang">notify</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang
 /Object.html?is-external=true#notifyAll()" title="class or interface in 
java.lang">notifyAll</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait()"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long)"
 title="class or interface in java.lang">wait</a>, <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#wait(long,%20int)"
 title="class or interface in java.lang">wait</a></code></li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+<div class="details">
+<ul class="blockList">
+<li class="blockList">
+<!-- ========= CONSTRUCTOR DETAIL ======== -->
+<ul class="blockList">
+<li class="blockList"><a name="constructor_detail">
+<!--   -->
+</a>
+<h3>Constructor Detail</h3>
+<a name="ThreadLocalClientProvider(org.apache.hadoop.conf.Configuration, 
org.apache.twill.discovery.DiscoveryServiceClient)">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>ThreadLocalClientProvider</h4>
+<pre>public&nbsp;ThreadLocalClientProvider(org.apache.hadoop.conf.Configuration&nbsp;conf,
+                         
org.apache.twill.discovery.DiscoveryServiceClient&nbsp;discoveryServiceClient)</pre>
+</li>
+</ul>
+</li>
+</ul>
+<!-- ============ METHOD DETAIL ========== -->
+<ul class="blockList">
+<li class="blockList"><a name="method_detail">
+<!--   -->
+</a>
+<h3>Method Detail</h3>
+<a name="getCloseableClient()">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>getCloseableClient</h4>
+<pre>public&nbsp;<a 
href="../../../../org/apache/tephra/distributed/CloseableThriftClient.html" 
title="class in 
org.apache.tephra.distributed">CloseableThriftClient</a>&nbsp;getCloseableClient()
+                                         throws org.apache.thrift.TException,
+                                                <a 
href="http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/TimeoutException.html?is-external=true";
 title="class or interface in java.util.concurrent">TimeoutException</a>,
+                                                <a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/InterruptedException.html?is-external=true";
 title="class or interface in java.lang">InterruptedException</a></pre>
+<div class="block"><strong>Description copied from interface:&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html#getCloseableClient()">ThriftClientProvider</a></code></strong></div>
+<div class="block">Retrieve an AutoCloseable wrapper around  tx client for 
exclusive use by the
+ current thread. The client must be closed (returned) to the provider after 
use.</div>
+<dl><dt><span class="strong">Returns:</span></dt><dd>an tx client, connected 
and fully functional</dd>
+<dt><span class="strong">Throws:</span></dt>
+<dd><code>org.apache.thrift.TException</code></dd>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/util/concurrent/TimeoutException.html?is-external=true";
 title="class or interface in 
java.util.concurrent">TimeoutException</a></code></dd>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/InterruptedException.html?is-external=true";
 title="class or interface in 
java.lang">InterruptedException</a></code></dd></dl>
+</li>
+</ul>
+<a 
name="returnClient(org.apache.tephra.distributed.TransactionServiceThriftClient)">
+<!--   -->
+</a>
+<ul class="blockList">
+<li class="blockList">
+<h4>returnClient</h4>
+<pre>public&nbsp;void&nbsp;returnClient(<a 
href="../../../../org/apache/tephra/distributed/TransactionServiceThriftClient.html"
 title="class in 
org.apache.tephra.distributed">TransactionServiceThriftClient</a>&nbsp;client)</pre>
+<div class="block"><strong>Description copied from interface:&nbsp;<code><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html#returnClient(org.apache.tephra.distributed.TransactionServiceThriftClient)">ThriftClientProvider</a></code></strong></div>
+<div class="block">Release an tx client back to the provider's pool, if the 
client is valid.
+ If the client becomes disfunctional, for instance, due to a socket
+ exception. The provider must make sure to close the client, and it
+ must remove the client from its arsenal and be prepared to create
+ a new client subsequently.</div>
+<dl><dt><span class="strong">Parameters:</span></dt><dd><code>client</code> - 
The client to return</dd></dl>
+</li>
+</ul>
+<a name="toString()">
+<!--   -->
+</a>
+<ul class="blockListLast">
+<li class="blockList">
+<h4>toString</h4>
+<pre>public&nbsp;<a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/String.html?is-external=true";
 title="class or interface in java.lang">String</a>&nbsp;toString()</pre>
+<dl>
+<dt><strong>Overrides:</strong></dt>
+<dd><code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true#toString()"
 title="class or interface in java.lang">toString</a></code>&nbsp;in 
class&nbsp;<code><a 
href="http://docs.oracle.com/javase/7/docs/api/java/lang/Object.html?is-external=true";
 title="class or interface in java.lang">Object</a></code></dd>
+</dl>
+</li>
+</ul>
+</li>
+</ul>
+</li>
+</ul>
+</div>
+</div>
+<!-- ========= END OF CLASS DATA ========= -->
+<!-- ======= START OF BOTTOM NAVBAR ====== -->
+<div class="bottomNav"><a name="navbar_bottom">
+<!--   -->
+</a><a href="#skip-navbar_bottom" title="Skip navigation links"></a><a 
name="navbar_bottom_firstrow">
+<!--   -->
+</a>
+<ul class="navList" title="Navigation">
+<li><a href="../../../../overview-summary.html">Overview</a></li>
+<li><a href="package-summary.html">Package</a></li>
+<li class="navBarCell1Rev">Class</li>
+<li><a href="class-use/ThreadLocalClientProvider.html">Use</a></li>
+<li><a href="package-tree.html">Tree</a></li>
+<li><a href="../../../../deprecated-list.html">Deprecated</a></li>
+<li><a href="../../../../index-all.html">Index</a></li>
+<li><a href="../../../../help-doc.html">Help</a></li>
+</ul>
+</div>
+<div class="subNav">
+<ul class="navList">
+<li><a 
href="../../../../org/apache/tephra/distributed/SingleUseClientProvider.html" 
title="class in org.apache.tephra.distributed"><span class="strong">Prev 
Class</span></a></li>
+<li><a 
href="../../../../org/apache/tephra/distributed/ThriftClientProvider.html" 
title="interface in org.apache.tephra.distributed"><span class="strong">Next 
Class</span></a></li>
+</ul>
+<ul class="navList">
+<li><a 
href="../../../../index.html?org/apache/tephra/distributed/ThreadLocalClientProvider.html"
 target="_top">Frames</a></li>
+<li><a href="ThreadLocalClientProvider.html" target="_top">No Frames</a></li>
+</ul>
+<ul class="navList" id="allclasses_navbar_bottom">
+<li><a href="../../../../allclasses-noframe.html">All Classes</a></li>
+</ul>
+<div>
+<script type="text/javascript"><!--
+  allClassesLink = document.getElementById("allclasses_navbar_bottom");
+  if(window==top) {
+    allClassesLink.style.display = "block";
+  }
+  else {
+    allClassesLink.style.display = "none";
+  }
+  //-->
+</script>
+</div>
+<div>
+<ul class="subNavList">
+<li>Summary:&nbsp;</li>
+<li><a 
href="#nested_classes_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Nested</a>&nbsp;|&nbsp;</li>
+<li><a 
href="#fields_inherited_from_class_org.apache.tephra.distributed.AbstractClientProvider">Field</a>&nbsp;|&nbsp;</li>
+<li><a href="#constructor_summary">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_summary">Method</a></li>
+</ul>
+<ul class="subNavList">
+<li>Detail:&nbsp;</li>
+<li>Field&nbsp;|&nbsp;</li>
+<li><a href="#constructor_detail">Constr</a>&nbsp;|&nbsp;</li>
+<li><a href="#method_detail">Method</a></li>
+</ul>
+</div>
+<a name="skip-navbar_bottom">
+<!--   -->
+</a></div>
+<!-- ======== END OF BOTTOM NAVBAR ======= -->
+<p class="legalCopy"><small>Copyright &#169; 2016 <a 
href="http://www.apache.org";>The Apache Software Foundation</a>. All rights 
reserved.</small></p>
+</body>
+</html>

Reply via email to