<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<!-- NewPage -->
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html" charset="UTF-8">
<title>KuduSession (Kudu 0.8.0 API)</title>
<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="KuduSession (Kudu 0.8.0 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/KuduSession.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/kududb/client/KuduServerException.html" title="class in org.kududb.client"><span class="strong">Prev Class</span></a></li>
<li><a href="../../../org/kududb/client/KuduTable.html" title="class in org.kududb.client"><span class="strong">Next Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../index.html?org/kududb/client/KuduSession.html" target="_top">Frames</a></li>
<li><a href="KuduSession.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><a href="#field_summary">Field</a>&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><a href="#field_detail">Field</a>&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.kududb.client</div>
<h2 title="Class KuduSession" class="title">Class KuduSession</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.kududb.client.KuduSession</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<dl>
<dt>All Implemented Interfaces:</dt>
<dd><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></dd>
</dl>
<hr>
<br>
<pre>@InterfaceAudience.Public
@InterfaceStability.Evolving
public class <span class="strong">KuduSession</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/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></pre>
<div class="block">Synchronous version of <a href="../../../org/kududb/client/AsyncKuduSession.html" title="class in org.kududb.client"><code>AsyncKuduSession</code></a>.
 Offers the same API but with blocking methods.<p>

 This class is <b>not</b> thread-safe.<p>

 A major difference with <a href="../../../org/kududb/client/AsyncKuduSession.html" title="class in org.kududb.client"><code>AsyncKuduSession</code></a> is that the time spent waiting on operations is
 defined by <a href="../../../org/kududb/client/KuduSession.html#setTimeoutMillis(long)"><code>setTimeoutMillis(long)</code></a> which defaults to getting it from
 <a href="../../../org/kududb/client/KuduClient.html#getDefaultOperationTimeoutMs()"><code>KuduClient.getDefaultOperationTimeoutMs()</code></a>.</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.kududb.client.SessionConfiguration">
<!--   -->
</a>
<h3>Nested classes/interfaces inherited from interface&nbsp;org.kududb.client.<a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></h3>
<code><a href="../../../org/kududb/client/SessionConfiguration.FlushMode.html" title="enum in org.kududb.client">SessionConfiguration.FlushMode</a></code></li>
</ul>
</li>
</ul>
<!-- =========== FIELD SUMMARY =========== -->
<ul class="blockList">
<li class="blockList"><a name="field_summary">
<!--   -->
</a>
<h3>Field Summary</h3>
<table class="overviewSummary" border="0" cellpadding="3" cellspacing="0" summary="Field Summary table, listing fields, and an explanation">
<caption><span>Fields</span><span class="tabEnd">&nbsp;</span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colLast" scope="col">Field and Description</th>
</tr>
<tr class="altColor">
<td class="colFirst"><code>static org.slf4j.Logger</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#LOG">LOG</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><a href="../../../org/kududb/client/OperationResponse.html" title="class in org.kududb.client">OperationResponse</a></code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#apply(org.kududb.client.Operation)">apply</a></strong>(<a href="../../../org/kududb/client/Operation.html" title="class in org.kududb.client">Operation</a>&nbsp;operation)</code>
<div class="block">Blocking call with a different behavior based on the flush mode.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code><a href="http://docs.oracle.com/javase/7/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../org/kududb/client/OperationResponse.html" title="class in org.kududb.client">OperationResponse</a>&gt;</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#close()">close</a></strong>()</code>
<div class="block">Blocking call that flushes the buffers (see <a href="../../../org/kududb/client/KuduSession.html#flush()"><code>flush()</code></a> and closes the sessions.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>int</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#countPendingErrors()">countPendingErrors</a></strong>()</code>
<div class="block">Return the number of errors which are pending.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code><a href="http://docs.oracle.com/javase/7/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../org/kududb/client/OperationResponse.html" title="class in org.kududb.client">OperationResponse</a>&gt;</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#flush()">flush</a></strong>()</code>
<div class="block">Blocking call that force flushes this session's buffers.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code><a href="../../../org/kududb/client/SessionConfiguration.FlushMode.html" title="enum in org.kududb.client">SessionConfiguration.FlushMode</a></code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#getFlushMode()">getFlushMode</a></strong>()</code>
<div class="block">Get the current flush mode.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code><a href="../../../org/kududb/client/RowErrorsAndOverflowStatus.html" title="class in org.kududb.client">RowErrorsAndOverflowStatus</a></code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#getPendingErrors()">getPendingErrors</a></strong>()</code>
<div class="block">Return any errors from previous calls.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>long</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#getTimeoutMillis()">getTimeoutMillis</a></strong>()</code>
<div class="block">Get the current timeout.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>boolean</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#hasPendingOperations()">hasPendingOperations</a></strong>()</code>
<div class="block">Check if there are operations that haven't been completely applied.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>boolean</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#isClosed()">isClosed</a></strong>()</code>
<div class="block">Returns true if this session has already been closed.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>boolean</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#isIgnoreAllDuplicateRows()">isIgnoreAllDuplicateRows</a></strong>()</code>
<div class="block">Tells if the session is currently ignoring row errors when the whole list returned by a tablet
 server is of the AlreadyPresent type.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setExternalConsistencyMode(org.kududb.client.ExternalConsistencyMode)">setExternalConsistencyMode</a></strong>(<a href="../../../org/kududb/client/ExternalConsistencyMode.html" title="enum in org.kududb.client">ExternalConsistencyMode</a>&nbsp;consistencyMode)</code>
<div class="block">Set the new external consistency mode for this session.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setFlushInterval(int)">setFlushInterval</a></strong>(int&nbsp;interval)</code>
<div class="block">Set the flush interval, which will be used for the next scheduling decision.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setFlushMode(org.kududb.client.SessionConfiguration.FlushMode)">setFlushMode</a></strong>(<a href="../../../org/kududb/client/SessionConfiguration.FlushMode.html" title="enum in org.kududb.client">SessionConfiguration.FlushMode</a>&nbsp;flushMode)</code>
<div class="block">Set the new flush mode for this session.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setIgnoreAllDuplicateRows(boolean)">setIgnoreAllDuplicateRows</a></strong>(boolean&nbsp;ignoreAllDuplicateRows)</code>
<div class="block">Configures the option to ignore all the row errors if they are all of the AlreadyPresent type.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setMutationBufferLowWatermark(float)">setMutationBufferLowWatermark</a></strong>(float&nbsp;mutationBufferLowWatermarkPercentage)</code>
<div class="block">Set the low watermark for this session.</div>
</td>
</tr>
<tr class="rowColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setMutationBufferSpace(int)">setMutationBufferSpace</a></strong>(int&nbsp;size)</code>
<div class="block">Set the number of operations that can be buffered.</div>
</td>
</tr>
<tr class="altColor">
<td class="colFirst"><code>void</code></td>
<td class="colLast"><code><strong><a href="../../../org/kududb/client/KuduSession.html#setTimeoutMillis(long)">setTimeoutMillis</a></strong>(long&nbsp;timeout)</code>
<div class="block">Sets the timeout for the next applied operations.</div>
</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#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">
<!-- ============ FIELD DETAIL =========== -->
<ul class="blockList">
<li class="blockList"><a name="field_detail">
<!--   -->
</a>
<h3>Field Detail</h3>
<a name="LOG">
<!--   -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>LOG</h4>
<pre>public static final&nbsp;org.slf4j.Logger LOG</pre>
</li>
</ul>
</li>
</ul>
<!-- ============ METHOD DETAIL ========== -->
<ul class="blockList">
<li class="blockList"><a name="method_detail">
<!--   -->
</a>
<h3>Method Detail</h3>
<a name="apply(org.kududb.client.Operation)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>apply</h4>
<pre>public&nbsp;<a href="../../../org/kududb/client/OperationResponse.html" title="class in org.kududb.client">OperationResponse</a>&nbsp;apply(<a href="../../../org/kududb/client/Operation.html" title="class in org.kududb.client">Operation</a>&nbsp;operation)
                        throws <a href="http://docs.oracle.com/javase/7/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<div class="block">Blocking call with a different behavior based on the flush mode. PleaseThrottleException is
 managed by this method and will not be thrown, unlike <a href="../../../org/kududb/client/AsyncKuduSession.html#apply(org.kududb.client.Operation)"><code>AsyncKuduSession.apply(org.kududb.client.Operation)</code></a>.
 <p>
 <ul>
 <li>AUTO_FLUSH_SYNC: the call returns when the operation is persisted,
 else it throws an exception.
 <li>AUTO_FLUSH_BACKGROUND: the call returns when the operation has been added to the buffer.
 This call should normally perform only fast in-memory operations but
 it may have to wait when the buffer is full and there's another buffer being flushed. Row
 errors can be checked by calling <a href="../../../org/kududb/client/KuduSession.html#countPendingErrors()"><code>countPendingErrors()</code></a> and can be retrieved by calling
 <a href="../../../org/kududb/client/KuduSession.html#getPendingErrors()"><code>getPendingErrors()</code></a>.
 <li>MANUAL_FLUSH: the call returns when the operation has been added to the buffer,
 else it throws an exception such as a NonRecoverableException if the buffer is full.
 </ul></div>
<dl><dt><span class="strong">Parameters:</span></dt><dd><code>operation</code> - operation to apply</dd>
<dt><span class="strong">Returns:</span></dt><dd>an OperationResponse for the applied Operation</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code><a href="http://docs.oracle.com/javase/7/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></code> - if anything went wrong</dd></dl>
</li>
</ul>
<a name="flush()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>flush</h4>
<pre>public&nbsp;<a href="http://docs.oracle.com/javase/7/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../org/kududb/client/OperationResponse.html" title="class in org.kududb.client">OperationResponse</a>&gt;&nbsp;flush()
                              throws <a href="http://docs.oracle.com/javase/7/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<div class="block">Blocking call that force flushes this session's buffers. Data is persisted when this call
 returns, else it will throw an exception.</div>
<dl><dt><span class="strong">Returns:</span></dt><dd>a list of OperationResponse, one per operation that was flushed</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code><a href="http://docs.oracle.com/javase/7/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></code> - if anything went wrong. If it's an issue with some or all batches,
 it will be of type DeferredGroupException.</dd></dl>
</li>
</ul>
<a name="close()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>close</h4>
<pre>public&nbsp;<a href="http://docs.oracle.com/javase/7/docs/api/java/util/List.html?is-external=true" title="class or interface in java.util">List</a>&lt;<a href="../../../org/kududb/client/OperationResponse.html" title="class in org.kududb.client">OperationResponse</a>&gt;&nbsp;close()
                              throws <a href="http://docs.oracle.com/javase/7/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></pre>
<div class="block">Blocking call that flushes the buffers (see <a href="../../../org/kududb/client/KuduSession.html#flush()"><code>flush()</code></a> and closes the sessions.</div>
<dl><dt><span class="strong">Returns:</span></dt><dd>List of OperationResponse, one per operation that was flushed</dd>
<dt><span class="strong">Throws:</span></dt>
<dd><code><a href="http://docs.oracle.com/javase/7/docs/api/java/lang/Exception.html?is-external=true" title="class or interface in java.lang">Exception</a></code> - if anything went wrong. If it's an issue with some or all batches,
 it will be of type DeferredGroupException.</dd></dl>
</li>
</ul>
<a name="getFlushMode()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getFlushMode</h4>
<pre>public&nbsp;<a href="../../../org/kududb/client/SessionConfiguration.FlushMode.html" title="enum in org.kududb.client">SessionConfiguration.FlushMode</a>&nbsp;getFlushMode()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#getFlushMode()">SessionConfiguration</a></code></strong></div>
<div class="block">Get the current flush mode.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#getFlushMode()">getFlushMode</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Returns:</span></dt><dd>flush mode, AUTO_FLUSH_SYNC by default</dd></dl>
</li>
</ul>
<a name="setFlushMode(org.kududb.client.SessionConfiguration.FlushMode)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setFlushMode</h4>
<pre>public&nbsp;void&nbsp;setFlushMode(<a href="../../../org/kududb/client/SessionConfiguration.FlushMode.html" title="enum in org.kududb.client">SessionConfiguration.FlushMode</a>&nbsp;flushMode)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setFlushMode(org.kududb.client.SessionConfiguration.FlushMode)">SessionConfiguration</a></code></strong></div>
<div class="block">Set the new flush mode for this session.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setFlushMode(org.kududb.client.SessionConfiguration.FlushMode)">setFlushMode</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>flushMode</code> - new flush mode, can be the same as the previous one.</dd></dl>
</li>
</ul>
<a name="setMutationBufferSpace(int)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setMutationBufferSpace</h4>
<pre>public&nbsp;void&nbsp;setMutationBufferSpace(int&nbsp;size)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setMutationBufferSpace(int)">SessionConfiguration</a></code></strong></div>
<div class="block">Set the number of operations that can be buffered.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setMutationBufferSpace(int)">setMutationBufferSpace</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>size</code> - number of ops.</dd></dl>
</li>
</ul>
<a name="setMutationBufferLowWatermark(float)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setMutationBufferLowWatermark</h4>
<pre>public&nbsp;void&nbsp;setMutationBufferLowWatermark(float&nbsp;mutationBufferLowWatermarkPercentage)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setMutationBufferLowWatermark(float)">SessionConfiguration</a></code></strong></div>
<div class="block">Set the low watermark for this session. The default is set to half the mutation buffer space.
 For example, a buffer space of 1000 with a low watermark set to 50% (0.5) will start randomly
 sending PleaseRetryExceptions once there's an outstanding flush and the buffer is over 500.
 As the buffer gets fuller, it becomes likelier to hit the exception.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setMutationBufferLowWatermark(float)">setMutationBufferLowWatermark</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>mutationBufferLowWatermarkPercentage</code> - a new low watermark as a percentage,
                             has to be between 0  and 1 (inclusive). A value of 1 disables
                             the low watermark since it's the same as the high one</dd></dl>
</li>
</ul>
<a name="setFlushInterval(int)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setFlushInterval</h4>
<pre>public&nbsp;void&nbsp;setFlushInterval(int&nbsp;interval)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setFlushInterval(int)">SessionConfiguration</a></code></strong></div>
<div class="block">Set the flush interval, which will be used for the next scheduling decision.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setFlushInterval(int)">setFlushInterval</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>interval</code> - interval in milliseconds.</dd></dl>
</li>
</ul>
<a name="getTimeoutMillis()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>getTimeoutMillis</h4>
<pre>public&nbsp;long&nbsp;getTimeoutMillis()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#getTimeoutMillis()">SessionConfiguration</a></code></strong></div>
<div class="block">Get the current timeout.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#getTimeoutMillis()">getTimeoutMillis</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Returns:</span></dt><dd>operation timeout in milliseconds, 0 if none was configured.</dd></dl>
</li>
</ul>
<a name="setTimeoutMillis(long)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setTimeoutMillis</h4>
<pre>public&nbsp;void&nbsp;setTimeoutMillis(long&nbsp;timeout)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setTimeoutMillis(long)">SessionConfiguration</a></code></strong></div>
<div class="block">Sets the timeout for the next applied operations.
 The default timeout is 0, which disables the timeout functionality.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setTimeoutMillis(long)">setTimeoutMillis</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>timeout</code> - Timeout in milliseconds.</dd></dl>
</li>
</ul>
<a name="isClosed()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>isClosed</h4>
<pre>public&nbsp;boolean&nbsp;isClosed()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#isClosed()">SessionConfiguration</a></code></strong></div>
<div class="block">Returns true if this session has already been closed.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#isClosed()">isClosed</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
</dl>
</li>
</ul>
<a name="hasPendingOperations()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>hasPendingOperations</h4>
<pre>public&nbsp;boolean&nbsp;hasPendingOperations()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#hasPendingOperations()">SessionConfiguration</a></code></strong></div>
<div class="block">Check if there are operations that haven't been completely applied.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#hasPendingOperations()">hasPendingOperations</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Returns:</span></dt><dd>true if operations are pending, else false.</dd></dl>
</li>
</ul>
<a name="setExternalConsistencyMode(org.kududb.client.ExternalConsistencyMode)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setExternalConsistencyMode</h4>
<pre>public&nbsp;void&nbsp;setExternalConsistencyMode(<a href="../../../org/kududb/client/ExternalConsistencyMode.html" title="enum in org.kududb.client">ExternalConsistencyMode</a>&nbsp;consistencyMode)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setExternalConsistencyMode(org.kududb.client.ExternalConsistencyMode)">SessionConfiguration</a></code></strong></div>
<div class="block">Set the new external consistency mode for this session.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setExternalConsistencyMode(org.kududb.client.ExternalConsistencyMode)">setExternalConsistencyMode</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>consistencyMode</code> - new external consistency mode, can the same as the previous one.</dd></dl>
</li>
</ul>
<a name="isIgnoreAllDuplicateRows()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>isIgnoreAllDuplicateRows</h4>
<pre>public&nbsp;boolean&nbsp;isIgnoreAllDuplicateRows()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#isIgnoreAllDuplicateRows()">SessionConfiguration</a></code></strong></div>
<div class="block">Tells if the session is currently ignoring row errors when the whole list returned by a tablet
 server is of the AlreadyPresent type.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#isIgnoreAllDuplicateRows()">isIgnoreAllDuplicateRows</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Returns:</span></dt><dd>true if the session is enforcing this, else false</dd></dl>
</li>
</ul>
<a name="setIgnoreAllDuplicateRows(boolean)">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>setIgnoreAllDuplicateRows</h4>
<pre>public&nbsp;void&nbsp;setIgnoreAllDuplicateRows(boolean&nbsp;ignoreAllDuplicateRows)</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#setIgnoreAllDuplicateRows(boolean)">SessionConfiguration</a></code></strong></div>
<div class="block">Configures the option to ignore all the row errors if they are all of the AlreadyPresent type.
 This can be needed when facing KUDU-568. The effect of enabling this is that operation
 responses that match this pattern will be cleared of their row errors, meaning that we consider
 them successful.
 This is disabled by default.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#setIgnoreAllDuplicateRows(boolean)">setIgnoreAllDuplicateRows</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Parameters:</span></dt><dd><code>ignoreAllDuplicateRows</code> - true if this session should enforce this, else false</dd></dl>
</li>
</ul>
<a name="countPendingErrors()">
<!--   -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>countPendingErrors</h4>
<pre>public&nbsp;int&nbsp;countPendingErrors()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#countPendingErrors()">SessionConfiguration</a></code></strong></div>
<div class="block">Return the number of errors which are pending. Errors may accumulate when
 using the AUTO_FLUSH_BACKGROUND mode.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#countPendingErrors()">countPendingErrors</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Returns:</span></dt><dd>a count of errors</dd></dl>
</li>
</ul>
<a name="getPendingErrors()">
<!--   -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>getPendingErrors</h4>
<pre>public&nbsp;<a href="../../../org/kududb/client/RowErrorsAndOverflowStatus.html" title="class in org.kududb.client">RowErrorsAndOverflowStatus</a>&nbsp;getPendingErrors()</pre>
<div class="block"><strong>Description copied from interface:&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html#getPendingErrors()">SessionConfiguration</a></code></strong></div>
<div class="block">Return any errors from previous calls. If there were more errors
 than could be held in the session's error storage, the overflow state is set to true.
 Resets the pending errors.</div>
<dl>
<dt><strong>Specified by:</strong></dt>
<dd><code><a href="../../../org/kududb/client/SessionConfiguration.html#getPendingErrors()">getPendingErrors</a></code>&nbsp;in interface&nbsp;<code><a href="../../../org/kududb/client/SessionConfiguration.html" title="interface in org.kududb.client">SessionConfiguration</a></code></dd>
<dt><span class="strong">Returns:</span></dt><dd>an object that contains the errors and the overflow status</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/KuduSession.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/kududb/client/KuduServerException.html" title="class in org.kududb.client"><span class="strong">Prev Class</span></a></li>
<li><a href="../../../org/kududb/client/KuduTable.html" title="class in org.kududb.client"><span class="strong">Next Class</span></a></li>
</ul>
<ul class="navList">
<li><a href="../../../index.html?org/kududb/client/KuduSession.html" target="_top">Frames</a></li>
<li><a href="KuduSession.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><a href="#field_summary">Field</a>&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><a href="#field_detail">Field</a>&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. All rights reserved.</small></p>
</body>
</html>
