blob: e21c677661425f69c7a7b6f356bb6b9647139797 [file] [log] [blame]
<!DOCTYPE HTML>
<!-- NewPage -->
<html lang="en">
<head>
<!-- Generated by javadoc (11.0.18) on Wed Mar 01 02:01:42 GMT 2023 -->
<title>ISpoutMetrics (Heron Java API)</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<meta name="dc.created" content="2023-03-01">
<link rel="stylesheet" type="text/css" href="../../../../../../stylesheet.css" title="Style">
<link rel="stylesheet" type="text/css" href="../../../../../../jquery/jquery-ui.min.css" title="Style">
<link rel="stylesheet" type="text/css" href="../../../../../../jquery-ui.overrides.css" title="Style">
<script type="text/javascript" src="../../../../../../script.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jszip/dist/jszip.min.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jszip-utils/dist/jszip-utils.min.js"></script>
<!--[if IE]>
<script type="text/javascript" src="../../../../../../jquery/jszip-utils/dist/jszip-utils-ie.min.js"></script>
<![endif]-->
<script type="text/javascript" src="../../../../../../jquery/jquery-3.6.0.min.js"></script>
<script type="text/javascript" src="../../../../../../jquery/jquery-ui.min.js"></script>
</head>
<body>
<script type="text/javascript"><!--
try {
if (location.href.indexOf('is-external=true') == -1) {
parent.document.title="ISpoutMetrics (Heron Java API)";
}
}
catch(err) {
}
//-->
var data = {"i0":6,"i1":6,"i2":6,"i3":6,"i4":6,"i5":6,"i6":6,"i7":6,"i8":6,"i9":6,"i10":6};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],4:["t3","Abstract Methods"]};
var altColor = "altColor";
var rowColor = "rowColor";
var tableTab = "tableTab";
var activeTableTab = "activeTableTab";
var pathtoroot = "../../../../../../";
var useModuleDirectories = true;
loadScripts(document, 'script');</script>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
<header role="banner">
<nav role="navigation">
<div class="fixedNav">
<!-- ========= START OF TOP NAVBAR ======= -->
<div class="topNav"><a id="navbar.top">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.top" title="Skip navigation links">Skip navigation links</a></div>
<a id="navbar.top.firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../../../index.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</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" id="allclasses_navbar_top">
<li><a href="../../../../../../allclasses.html">All&nbsp;Classes</a></li>
</ul>
<ul class="navListSearch">
<li><label for="search">SEARCH:</label>
<input type="text" id="search" value="search" disabled="disabled">
<input type="reset" id="reset" value="reset" disabled="disabled">
</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>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
</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 id="skip.navbar.top">
<!-- -->
</a></div>
<!-- ========= END OF TOP NAVBAR ========= -->
</div>
<div class="navPadding">&nbsp;</div>
<script type="text/javascript"><!--
$('.navPadding').css('padding-top', $('.fixedNav').css("height"));
//-->
</script>
</nav>
</header>
<!-- ======== START OF CLASS DATA ======== -->
<main role="main">
<div class="header">
<div class="subTitle"><span class="packageLabelInType">Package</span>&nbsp;<a href="package-summary.html">org.apache.heron.common.utils.metrics</a></div>
<h2 title="Interface ISpoutMetrics" class="title">Interface ISpoutMetrics</h2>
</div>
<div class="contentContainer">
<div class="description">
<ul class="blockList">
<li class="blockList">
<dl>
<dt>All Superinterfaces:</dt>
<dd><code><a href="ComponentMetrics.html" title="interface in org.apache.heron.common.utils.metrics">ComponentMetrics</a></code></dd>
</dl>
<dl>
<dt>All Known Implementing Classes:</dt>
<dd><code><a href="FullSpoutMetrics.html" title="class in org.apache.heron.common.utils.metrics">FullSpoutMetrics</a></code>, <code><a href="SpoutMetrics.html" title="class in org.apache.heron.common.utils.metrics">SpoutMetrics</a></code></dd>
</dl>
<hr>
<pre>public interface <span class="typeNameLabel">ISpoutMetrics</span>
extends <a href="ComponentMetrics.html" title="interface in org.apache.heron.common.utils.metrics">ComponentMetrics</a></pre>
<div class="block">Spout's metrics to be collect
We need to:
1. Define the metrics to be collected
2. New them in the constructor
3. Register them in registerMetrics(...) by using MetricsCollector's registerMetric(...)
4. Expose methods which could be called externally to change the value of metrics</div>
</li>
</ul>
</div>
<div class="summary">
<ul class="blockList">
<li class="blockList">
<!-- ========== METHOD SUMMARY =========== -->
<section>
<ul class="blockList">
<li class="blockList"><a id="method.summary">
<!-- -->
</a>
<h3>Method Summary</h3>
<table class="memberSummary">
<caption><span id="t0" class="activeTableTab"><span>All Methods</span><span class="tabEnd">&nbsp;</span></span><span id="t2" class="tableTab"><span><a href="javascript:show(2);">Instance Methods</a></span><span class="tabEnd">&nbsp;</span></span><span id="t3" class="tableTab"><span><a href="javascript:show(4);">Abstract Methods</a></span><span class="tabEnd">&nbsp;</span></span></caption>
<tr>
<th class="colFirst" scope="col">Modifier and Type</th>
<th class="colSecond" scope="col">Method</th>
<th class="colLast" scope="col">Description</th>
</tr>
<tr id="i0" class="altColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#ackedTuple(java.lang.String,long)">ackedTuple</a></span>&#8203;(java.lang.String&nbsp;streamId,
long&nbsp;latency)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#failedTuple(java.lang.String,long)">failedTuple</a></span>&#8203;(java.lang.String&nbsp;streamId,
long&nbsp;latency)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#initMultiCountMetrics(org.apache.heron.common.utils.misc.PhysicalPlanHelper)">initMultiCountMetrics</a></span>&#8203;(<a href="../misc/PhysicalPlanHelper.html" title="class in org.apache.heron.common.utils.misc">PhysicalPlanHelper</a>&nbsp;helper)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#nextTuple(long)">nextTuple</a></span>&#8203;(long&nbsp;latency)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i4" class="altColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#registerMetrics(org.apache.heron.common.utils.topology.TopologyContextImpl)">registerMetrics</a></span>&#8203;(<a href="../topology/TopologyContextImpl.html" title="class in org.apache.heron.common.utils.topology">TopologyContextImpl</a>&nbsp;topologyContext)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i5" class="rowColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#timeoutTuple(java.lang.String)">timeoutTuple</a></span>&#8203;(java.lang.String&nbsp;streamId)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i6" class="altColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#updateContinueWorkCount()">updateContinueWorkCount</a></span>()</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i7" class="rowColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#updateOutQueueFullCount()">updateOutQueueFullCount</a></span>()</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i8" class="altColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#updatePendingTuplesCount(long)">updatePendingTuplesCount</a></span>&#8203;(long&nbsp;count)</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i9" class="rowColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#updateProduceTupleCount()">updateProduceTupleCount</a></span>()</code></th>
<td class="colLast">&nbsp;</td>
</tr>
<tr id="i10" class="altColor">
<td class="colFirst"><code>void</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#updateTaskRunCount()">updateTaskRunCount</a></span>()</code></th>
<td class="colLast">&nbsp;</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a id="methods.inherited.from.class.org.apache.heron.common.utils.metrics.ComponentMetrics">
<!-- -->
</a>
<h3>Methods inherited from interface&nbsp;org.apache.heron.common.utils.metrics.<a href="ComponentMetrics.html" title="interface in org.apache.heron.common.utils.metrics">ComponentMetrics</a></h3>
<code><a href="ComponentMetrics.html#addTupleToQueue(int)">addTupleToQueue</a>, <a href="ComponentMetrics.html#emittedTuple(java.lang.String)">emittedTuple</a>, <a href="ComponentMetrics.html#serializeDataTuple(java.lang.String,long)">serializeDataTuple</a></code></li>
</ul>
</li>
</ul>
</section>
</li>
</ul>
</div>
<div class="details">
<ul class="blockList">
<li class="blockList">
<!-- ============ METHOD DETAIL ========== -->
<section>
<ul class="blockList">
<li class="blockList"><a id="method.detail">
<!-- -->
</a>
<h3>Method Detail</h3>
<a id="registerMetrics(org.apache.heron.common.utils.topology.TopologyContextImpl)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>registerMetrics</h4>
<pre class="methodSignature">void&nbsp;registerMetrics&#8203;(<a href="../topology/TopologyContextImpl.html" title="class in org.apache.heron.common.utils.topology">TopologyContextImpl</a>&nbsp;topologyContext)</pre>
</li>
</ul>
<a id="initMultiCountMetrics(org.apache.heron.common.utils.misc.PhysicalPlanHelper)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>initMultiCountMetrics</h4>
<pre class="methodSignature">void&nbsp;initMultiCountMetrics&#8203;(<a href="../misc/PhysicalPlanHelper.html" title="class in org.apache.heron.common.utils.misc">PhysicalPlanHelper</a>&nbsp;helper)</pre>
</li>
</ul>
<a id="ackedTuple(java.lang.String,long)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>ackedTuple</h4>
<pre class="methodSignature">void&nbsp;ackedTuple&#8203;(java.lang.String&nbsp;streamId,
long&nbsp;latency)</pre>
</li>
</ul>
<a id="failedTuple(java.lang.String,long)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>failedTuple</h4>
<pre class="methodSignature">void&nbsp;failedTuple&#8203;(java.lang.String&nbsp;streamId,
long&nbsp;latency)</pre>
</li>
</ul>
<a id="timeoutTuple(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>timeoutTuple</h4>
<pre class="methodSignature">void&nbsp;timeoutTuple&#8203;(java.lang.String&nbsp;streamId)</pre>
</li>
</ul>
<a id="nextTuple(long)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>nextTuple</h4>
<pre class="methodSignature">void&nbsp;nextTuple&#8203;(long&nbsp;latency)</pre>
</li>
</ul>
<a id="updateOutQueueFullCount()">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>updateOutQueueFullCount</h4>
<pre class="methodSignature">void&nbsp;updateOutQueueFullCount()</pre>
</li>
</ul>
<a id="updatePendingTuplesCount(long)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>updatePendingTuplesCount</h4>
<pre class="methodSignature">void&nbsp;updatePendingTuplesCount&#8203;(long&nbsp;count)</pre>
</li>
</ul>
<a id="updateTaskRunCount()">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>updateTaskRunCount</h4>
<pre class="methodSignature">void&nbsp;updateTaskRunCount()</pre>
</li>
</ul>
<a id="updateProduceTupleCount()">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>updateProduceTupleCount</h4>
<pre class="methodSignature">void&nbsp;updateProduceTupleCount()</pre>
</li>
</ul>
<a id="updateContinueWorkCount()">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>updateContinueWorkCount</h4>
<pre class="methodSignature">void&nbsp;updateContinueWorkCount()</pre>
</li>
</ul>
</li>
</ul>
</section>
</li>
</ul>
</div>
</div>
</main>
<!-- ========= END OF CLASS DATA ========= -->
<footer role="contentinfo">
<nav role="navigation">
<!-- ======= START OF BOTTOM NAVBAR ====== -->
<div class="bottomNav"><a id="navbar.bottom">
<!-- -->
</a>
<div class="skipNav"><a href="#skip.navbar.bottom" title="Skip navigation links">Skip navigation links</a></div>
<a id="navbar.bottom.firstrow">
<!-- -->
</a>
<ul class="navList" title="Navigation">
<li><a href="../../../../../../index.html">Overview</a></li>
<li><a href="package-summary.html">Package</a></li>
<li class="navBarCell1Rev">Class</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" id="allclasses_navbar_bottom">
<li><a href="../../../../../../allclasses.html">All&nbsp;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>
<noscript>
<div>JavaScript is disabled on your browser.</div>
</noscript>
</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 id="skip.navbar.bottom">
<!-- -->
</a></div>
<!-- ======== END OF BOTTOM NAVBAR ======= -->
</nav>
</footer>
</body>
</html>