Added: helix/site-content/1.0.2-docs/jacoco/jacoco-sessions.html
URL: 
http://svn.apache.org/viewvc/helix/site-content/1.0.2-docs/jacoco/jacoco-sessions.html?rev=1900184&view=auto
==============================================================================
--- helix/site-content/1.0.2-docs/jacoco/jacoco-sessions.html (added)
+++ helix/site-content/1.0.2-docs/jacoco/jacoco-sessions.html Sat Apr 23 
04:22:15 2022
@@ -0,0 +1 @@
+<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 
1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd";><html 
xmlns="http://www.w3.org/1999/xhtml"; lang="en"><head><meta 
http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link 
rel="stylesheet" href="jacoco-resources/report.css" type="text/css"/><link 
rel="shortcut icon" href="jacoco-resources/report.gif" 
type="image/gif"/><title>Sessions</title></head><body><div class="breadcrumb" 
id="breadcrumb"><span class="info"><a href="jacoco-sessions.html" 
class="el_session">Sessions</a></span><a href="index.html" 
class="el_report">Apache Helix :: Website :: 1.0.2</a> &gt; <span 
class="el_session">Sessions</span></div><h1>Sessions</h1><p>This coverage 
report is based on execution data from the following sessions:</p><table 
class="coverage" cellspacing="0"><thead><tr><td>Session</td><td>Start 
Time</td><td>Dump Time</td></tr></thead><tbody><tr><td><span 
class="el_session">olamy-mbp.modem-48f492
 dc</span></td><td>23 Apr. 2022, 2:18:28 pm</td><td>23 Apr. 2022, 2:18:30 
pm</td></tr></tbody></table><p>Execution data for the following classes is 
considered in this report:</p><table class="coverage" 
cellspacing="0"><thead><tr><td>Class</td><td>Id</td></tr></thead><tbody><tr><td><span
 
class="el_class">org.apache.maven.plugin.surefire.log.api.NullConsoleLogger</span></td><td><code>34981977f337d296</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.AbstractPathConfiguration</span></td><td><code>c2402bb34e4f898d</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.BaseProviderFactory</span></td><td><code>d60467d86457c81f</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.BiProperty</span></td><td><code>9236607646284cb9</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.BooterDeserializer</span></td><td><code>306469d5c682e529</code></td></tr><tr><td><span
 class="el_class">
 
org.apache.maven.surefire.booter.ClassLoaderConfiguration</span></td><td><code>19c77fd79f32ea88</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.Classpath</span></td><td><code>5e6a6ddff52748c2</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ClasspathConfiguration</span></td><td><code>8895eec3b7189eea</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.Command</span></td><td><code>1d2792e9b62ef0f9</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.CommandReader</span></td><td><code>4edf29f705ec460d</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.CommandReader.1</span></td><td><code>677b3673c0ebbd85</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.CommandReader.CommandRunnable</span></td><td><code>4fd8bde59e2b50e4</code></td></tr><tr><td><span
 class="el_class">org.apache.maven.surefire.booter.DumpErrorSin
 gleton</span></td><td><code>c64abc82be98caa5</code></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter</span></td><td><code>4e550597e6f18cfa</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter.1</span></td><td><code>f8b52234ddc56ffa</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter.2</span></td><td><code>757edc1b2982ae12</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter.3</span></td><td><code>d89fa0cbf26df977</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter.4</span></td><td><code>169173e6a5043c1a</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter.5</span></td><td><code>c4f0628f97d65d46</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ForkedBooter.6</span></td><td><code>a88d08e89faaefaa</code></td></tr><tr><td
 ><span 
 >class="el_class">org.apache.maven.surefire.booter.ForkedBooter.7</span></td><td><code>d4598b55e716c460</code></td></tr><tr><td><span
 > 
 >class="el_class">org.apache.maven.surefire.booter.ForkedBooter.PingScheduler</span></td><td><code>2e76ab494508fdaf</code></td></tr><tr><td><span
 > 
 >class="el_class">org.apache.maven.surefire.booter.ForkingReporterFactory</span></td><td><code>d624a3ff4c39e3d4</code></td></tr><tr><td><span
 > 
 >class="el_class">org.apache.maven.surefire.booter.ForkingRunListener</span></td><td><code>a2ea5da7cd5371a7</code></td></tr><tr><td><span
 > 
 >class="el_class">org.apache.maven.surefire.booter.MasterProcessCommand</span></td><td><code>05fb16849daa78db</code></td></tr><tr><td><span
 > 
 >class="el_class">org.apache.maven.surefire.booter.PpidChecker</span></td><td><code>41a87f96ba3b2a4c</code></td></tr><tr><td><span
 > 
 >class="el_class">org.apache.maven.surefire.booter.PpidChecker.1</span></td><td><code>480486982e6a4ad4</code></td></tr><tr><td><span
 > class="el_class">org.apache.maven
 
.surefire.booter.PpidChecker.ProcessInfoConsumer</span></td><td><code>90f8c5cd997cce89</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ProcessInfo</span></td><td><code>18d80dd86e23f860</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.PropertiesWrapper</span></td><td><code>aa990574b7f5ec6d</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.ProviderConfiguration</span></td><td><code>b70b2330addc3ae0</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.Shutdown</span></td><td><code>356ba240477c97f4</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.StartupConfiguration</span></td><td><code>98793019a848968f</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.booter.SystemPropertyManager</span></td><td><code>7feeed32fa06cafb</code></td></tr><tr><td><span
 class="el_class">org.apache.maven.surefire.booter.TypeEncodedValue</
 span></td><td><code>1edbe909f5e4981e</code></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.cli.CommandLineOption</span></td><td><code>650c56cb7d574904</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.providerapi.AbstractProvider</span></td><td><code>86e36c4f788e6c7d</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.report.ConsoleOutputCapture</span></td><td><code>0cfbd45fd8537b66</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.report.ConsoleOutputCapture.ForwardingPrintStream</span></td><td><code>a8ed5ba6c7a29b25</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.report.ConsoleOutputCapture.NullOutputStream</span></td><td><code>41649fe809517b8c</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.report.ReporterConfiguration</span></td><td><code>f31f556366e1c596</code></td></tr><tr><td><span
 class="el_class">org.apache.maven.surefire.report.SimpleRepor
 tEntry</span></td><td><code>5ca04b556a4039c5</code></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.shade.api.org.apache.maven.shared.utils.StringUtils</span></td><td><code>6ce67c035c0afe63</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.shade.booter.org.apache.commons.io.IOUtils</span></td><td><code>d046bdc5e1bf8954</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.shade.booter.org.apache.commons.io.output.StringBuilderWriter</span></td><td><code>8ac3e1f579c4efde</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.shade.booter.org.apache.commons.lang3.JavaVersion</span></td><td><code>197d5dd830c3e73a</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.shade.booter.org.apache.commons.lang3.StringUtils</span></td><td><code>5a7c279815b20692</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.shade.booter.org.apache.commons.lang3.SystemUtils</span></td><td><c
 ode>68215669fc9a9579</code></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.shade.booter.org.apache.commons.lang3.math.NumberUtils</span></td><td><code>18e20bf2c09f3df2</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.suite.RunResult</span></td><td><code>81613777905b3eee</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.ConfigurationAwareTestNGReporter</span></td><td><code>083dc40bb2c2d200</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.TestNGExecutor</span></td><td><code>186daf67b442e28a</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.TestNGProvider</span></td><td><code>69a4155d8f4ce871</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.TestNGReporter</span></td><td><code>7e02754829d43fdb</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.TestNGXmlTestSuite</span></td><td><code>d36d5bff8ee40
 96b</code></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.testng.TestSuite</span></td><td><code>1d6ce92b7bfd1aa3</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.conf.TestNG510Configurator</span></td><td><code>0d16fc5889609491</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.conf.TestNG513Configurator</span></td><td><code>e8f91904270631f0</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.conf.TestNG5141Configurator</span></td><td><code>aa5486f5350e34b4</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.conf.TestNG5143Configurator</span></td><td><code>bd43e17980458b83</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.conf.TestNG60Configurator</span></td><td><code>7c04a9bca2d14909</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testng.conf.TestNGMapConfigurator</span></td><td><code>00d52660ca1
 e78aa</code></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.testset.DirectoryScannerParameters</span></td><td><code>efd9846294dcd9d3</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.IncludedExcludedPatterns</span></td><td><code>56297f38e9129f8a</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.ResolvedTest</span></td><td><code>796057f3cc9de1bb</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.ResolvedTest.ClassMatcher</span></td><td><code>56071ed43e4085ce</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.ResolvedTest.MethodMatcher</span></td><td><code>3a23042e465518e1</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.ResolvedTest.Type</span></td><td><code>f6a950bdfef9ee1d</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.RunOrderParameters</span></td><td><code>da2414cd0197f87c</co
 de></td></tr><tr><td><span 
class="el_class">org.apache.maven.surefire.testset.TestArtifactInfo</span></td><td><code>3602f6ecc058f1dc</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.TestListResolver</span></td><td><code>d232058146aee284</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.testset.TestRequest</span></td><td><code>9474bd762e00dbae</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.DefaultRunOrderCalculator</span></td><td><code>9489cd4a6e59be77</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.DefaultScanResult</span></td><td><code>b7314cec56fd6571</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.ReflectionUtils</span></td><td><code>a589a4697c79c60c</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.RunOrder</span></td><td><code>4af8042033fd6cff</code></td></tr><tr><td><span
 class="el_class">org.apache.maven.
 
surefire.util.internal.DaemonThreadFactory</span></td><td><code>6382e048b023d128</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.internal.DaemonThreadFactory.NamedThreadFactory</span></td><td><code>f3f5b66bd083019c</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.internal.DumpFileUtils</span></td><td><code>8b6479526cb6d255</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.internal.ImmutableMap</span></td><td><code>7217145ff50f5baa</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.internal.ImmutableMap.Node</span></td><td><code>0d9659bbf1f62384</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.internal.ObjectUtils</span></td><td><code>cbf51204c27ae79e</code></td></tr><tr><td><span
 
class="el_class">org.apache.maven.surefire.util.internal.StringUtils</span></td><td><code>62d2b3e206fa4b5f</code></td></tr><tr><td><span
 class="el_class">org.testng.
 
ClassMethodMap</span></td><td><code>1e64351e995da473</code></td></tr><tr><td><span
 
class="el_class">org.testng.CommandLineArgs</span></td><td><code>0be054f3fefedd55</code></td></tr><tr><td><span
 
class="el_class">org.testng.InstanceOrderingMethodInterceptor</span></td><td><code>4c9908209cc4be73</code></td></tr><tr><td><span
 
class="el_class">org.testng.Reporter</span></td><td><code>d9e892b90af3b082</code></td></tr><tr><td><span
 
class="el_class">org.testng.SuiteResult</span></td><td><code>1660c63943d2adfd</code></td></tr><tr><td><span
 
class="el_class">org.testng.SuiteRunState</span></td><td><code>42de5787ecffa2bd</code></td></tr><tr><td><span
 
class="el_class">org.testng.SuiteRunner</span></td><td><code>1911b5f88067d3dc</code></td></tr><tr><td><span
 
class="el_class">org.testng.SuiteRunner.DefaultTestRunnerFactory</span></td><td><code>6661d4e2dc44ca9f</code></td></tr><tr><td><span
 
class="el_class">org.testng.SuiteRunnerWorker</span></td><td><code>c4fab4d747232df0</code></td></tr><tr><td>
 <span 
class="el_class">org.testng.TestListenerAdapter</span></td><td><code>9df6464d1cf32893</code></td></tr><tr><td><span
 
class="el_class">org.testng.TestNG</span></td><td><code>90e6abe41a029f1b</code></td></tr><tr><td><span
 
class="el_class">org.testng.TestNG.ExitCodeListener</span></td><td><code>6bf004ce16cef8d2</code></td></tr><tr><td><span
 
class="el_class">org.testng.TestRunner</span></td><td><code>f9b0b855e0caac8d</code></td></tr><tr><td><span
 
class="el_class">org.testng.TestRunner.ConfigurationListener</span></td><td><code>ba778b58f8f9ee88</code></td></tr><tr><td><span
 
class="el_class">org.testng.collections.Lists</span></td><td><code>79a27e9faffced3e</code></td></tr><tr><td><span
 
class="el_class">org.testng.collections.Maps</span></td><td><code>90014c72f7d725a4</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.AnnotationTypeEnum</span></td><td><code>dda211088c072951</code></td></tr><tr><td><span
 class="el_class">org.testng.internal.Attributes</span></td><td><c
 ode>1269d87bbf7df439</code></td></tr><tr><td><span 
class="el_class">org.testng.internal.BaseClassFinder</span></td><td><code>e9d72ae6bed96fd0</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.ClassHelper</span></td><td><code>07f05aca321ff638</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.ClassInfoMap</span></td><td><code>77215e52b8f96b3c</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.Configuration</span></td><td><code>98a0a6060efa7e6c</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.ConfigurationGroupMethods</span></td><td><code>21118295fd05defc</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.Constants</span></td><td><code>b90715fa415dd824</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.Graph</span></td><td><code>4a033c93ea3ac1d2</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.Invoker</span></td><td><code>518d5ff90999d243</code></td></tr><tr><td><span
 c
 
lass="el_class">org.testng.internal.MapList</span></td><td><code>1da8a7e2bec7c7b3</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.MethodGroupsHelper</span></td><td><code>ebc5e325b435ae45</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.MethodHelper</span></td><td><code>5a2e0ad0f3a71975</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.MethodSelectorDescriptor</span></td><td><code>f70243a546fe3e19</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.ObjectFactoryImpl</span></td><td><code>4d9a12f41ccb055b</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.OverrideProcessor</span></td><td><code>c6b7941786ca4190</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.PackageUtils</span></td><td><code>32e599813d00ef11</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.PoolService</span></td><td><code>2155898a20fd4352</code></td></tr><tr><td><span
 class="el_class">org.testng.inte
 
rnal.PoolService.1</span></td><td><code>3a1d9b742ae22c6f</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.ResultMap</span></td><td><code>9bcd5d7a816c8734</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.RunInfo</span></td><td><code>3013a5c87f660e3a</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.TestNGClassFinder</span></td><td><code>320db436033976d2</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.TestNGMethodFinder</span></td><td><code>1dc26b521f72e9e5</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.TestNGProperty</span></td><td><code>4f4ff0b564e970e7</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.Utils</span></td><td><code>7cfe05b49d2146a4</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.Utils.1</span></td><td><code>898dcd9b5d7bd82e</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.XmlMethodSelector</span></td><td><code>c0da063b1cfed6c
 b</code></td></tr><tr><td><span 
class="el_class">org.testng.internal.YamlParser</span></td><td><code>8476fabfc450b8c2</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.annotations.DefaultAnnotationTransformer</span></td><td><code>0867e290887063b5</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.annotations.JDK15AnnotationFinder</span></td><td><code>0d3fb95ce96d550d</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.annotations.JDK15TagFactory</span></td><td><code>d538e2c4791a9e0d</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.annotations.JDK15TagFactory.1</span></td><td><code>94956072d40283c4</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.annotations.JDK15TagFactory.2</span></td><td><code>e7bc5c71b58ce8c2</code></td></tr><tr><td><span
 
class="el_class">org.testng.internal.annotations.Sets</span></td><td><code>f053711ffe7e985b</code></td></tr><tr><td><span
 class="el_class">org.testng.internal.ve
 
rsion.VersionInfo</span></td><td><code>e0b0ed823d2d2e4b</code></td></tr><tr><td><span
 
class="el_class">org.testng.log4testng.Logger</span></td><td><code>6c9b44ed523ff571</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.EmailableReporter</span></td><td><code>c0b3087b226224cb</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.EmailableReporter.TestSorter</span></td><td><code>86c872a5774ae917</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.FailedReporter</span></td><td><code>a4c883c4a56f1484</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.HtmlHelper</span></td><td><code>f1a21624e07907d1</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.JUnitReportReporter</span></td><td><code>83ed9293d8cc9cd8</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.JUnitXMLReporter</span></td><td><code>95e7ba20a1e64a61</code></td></tr><tr><td><span
 class="el_class">org.testng.reporters.SuiteHTMLRepo
 rter</span></td><td><code>23fcb18711b7cb36</code></td></tr><tr><td><span 
class="el_class">org.testng.reporters.SuiteHTMLReporter.1</span></td><td><code>d56cc8512bfde40a</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.Tag</span></td><td><code>38e497489a851b4d</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.TestHTMLReporter</span></td><td><code>a148a87a4e7ef7c9</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.TestHTMLReporter.ConfigurationComparator</span></td><td><code>0afc2fa6bb37356f</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.TestHTMLReporter.NameComparator</span></td><td><code>bd32dbba0c1bf21d</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.TextReporter</span></td><td><code>d3b01fbe8174607f</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.XMLReporter</span></td><td><code>d47fb0eed920baaa</code></td></tr><tr><td><span
 class="el_class">org.testng.reporters.XMLRe
 
porterConfig</span></td><td><code>bdc13cb32cf7b339</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.XMLReporterConfig.1</span></td><td><code>3841a79317976272</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.XMLStringBuffer</span></td><td><code>b350df3364d5ead3</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.XMLSuiteResultWriter</span></td><td><code>d2b80c2933068db4</code></td></tr><tr><td><span
 
class="el_class">org.testng.reporters.XMLUtils</span></td><td><code>2c077d88480572d0</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.Parser</span></td><td><code>ae9795404f0a504f</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.SuiteXmlParser</span></td><td><code>48520badd647cd11</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.TestNGContentHandler</span></td><td><code>a069086da6020b42</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.XMLParser</span></td><td><code>2a820c67ffd79b7e</co
 de></td></tr><tr><td><span 
class="el_class">org.testng.xml.XmlPackage</span></td><td><code>6ba947b653148f8e</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.XmlSuite</span></td><td><code>80e08de3c313c339</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.XmlTest</span></td><td><code>556522ea4ac49267</code></td></tr><tr><td><span
 
class="el_class">org.testng.xml.XmlUtils</span></td><td><code>0dc29a2cd1902f53</code></td></tr><tr><td><span
 
class="el_class">sun.text.resources.cldr.ext.FormatData_en_001</span></td><td><code>2cc6a2b2c70d9189</code></td></tr><tr><td><span
 
class="el_class">sun.text.resources.cldr.ext.FormatData_en_AU</span></td><td><code>4a1524ce5f792676</code></td></tr><tr><td><span
 
class="el_class">sun.util.resources.cldr.provider.CLDRLocaleDataMetaInfo</span></td><td><code>3d1ea3e23b319ce9</code></td></tr><tr><td><span
 
class="el_class">sun.util.resources.provider.LocaleDataProvider</span></td><td><code>eebde39dfb7981b7</code></td></tr><tr><td><span
  
class="el_class">sun.util.resources.provider.NonBaseLocaleDataMetaInfo</span></td><td><code>fbc0acd0e1812c05</code></td></tr></tbody></table><div
 class="footer"><span class="right">Created with <a 
href="http://www.jacoco.org/jacoco";>JaCoCo</a> 
0.8.6.202009150832</span></div></body></html>
\ No newline at end of file

Added: helix/site-content/1.0.2-docs/jacoco/jacoco.csv
URL: 
http://svn.apache.org/viewvc/helix/site-content/1.0.2-docs/jacoco/jacoco.csv?rev=1900184&view=auto
==============================================================================
--- helix/site-content/1.0.2-docs/jacoco/jacoco.csv (added)
+++ helix/site-content/1.0.2-docs/jacoco/jacoco.csv Sat Apr 23 04:22:15 2022
@@ -0,0 +1 @@
+GROUP,PACKAGE,CLASS,INSTRUCTION_MISSED,INSTRUCTION_COVERED,BRANCH_MISSED,BRANCH_COVERED,LINE_MISSED,LINE_COVERED,COMPLEXITY_MISSED,COMPLEXITY_COVERED,METHOD_MISSED,METHOD_COVERED

Added: helix/site-content/1.0.2-docs/jacoco/jacoco.xml
URL: 
http://svn.apache.org/viewvc/helix/site-content/1.0.2-docs/jacoco/jacoco.xml?rev=1900184&view=auto
==============================================================================
--- helix/site-content/1.0.2-docs/jacoco/jacoco.xml (added)
+++ helix/site-content/1.0.2-docs/jacoco/jacoco.xml Sat Apr 23 04:22:15 2022
@@ -0,0 +1 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?><!DOCTYPE report PUBLIC 
"-//JACOCO//DTD Report 1.1//EN" "report.dtd"><report name="Apache Helix :: 
Website :: 1.0.2"><sessioninfo id="olamy-mbp.modem-48f492dc" 
start="1650687508843" dump="1650687510559"/></report>
\ No newline at end of file

Modified: helix/site-content/1.0.2-docs/privacy-policy.html
URL: 
http://svn.apache.org/viewvc/helix/site-content/1.0.2-docs/privacy-policy.html?rev=1900184&r1=1900183&r2=1900184&view=diff
==============================================================================
--- helix/site-content/1.0.2-docs/privacy-policy.html (original)
+++ helix/site-content/1.0.2-docs/privacy-policy.html Sat Apr 23 04:22:15 2022
@@ -1,201 +1,172 @@
-
 <!DOCTYPE html>
+
+
 <!--
- Generated by Apache Maven Doxia at 2022-04-23
- Rendered using Maven Reflow Skin 1.0.0 
(http://andriusvelykis.github.com/reflow-maven-skin)
+ | Generated by Apache Maven Doxia Site Renderer 1.11.1 from 
src/site/apt/privacy-policy.apt at 2022-04-23
+ | Rendered using Apache Maven Fluido Skin 1.11.0-SNAPSHOT
 -->
-<html  xml:lang="en" lang="en">
-
-       <head>
-               <meta charset="UTF-8" />
-               <title>Apache Helix &#x2013; Privacy Policy</title>
-               <meta name="viewport" content="width=device-width, 
initial-scale=1.0" />
-               <meta name="description" content="" />
-               <meta name="author" content="Olivier Lamy" />
-               <meta http-equiv="content-language" content="en" />
-
-               <link 
href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/css/bootstrap.min.css";
 rel="stylesheet" />
-               <link 
href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/css/bootstrap-responsive.min.css";
 rel="stylesheet" />
-               <link href="./css/docs.css" rel="stylesheet" />
-               <link href="./css/reflow-skin.css" rel="stylesheet" />
-               
-               
-               <link href="./css/lightbox.css" rel="stylesheet" />
-               
-               <link href="./css/site.css" rel="stylesheet" />
-               <link href="./css/print.css" rel="stylesheet" media="print" />
-               
-               <!-- Le HTML5 shim, for IE6-8 support of HTML5 elements -->
-               <!--[if lt IE 9]>
-                       <script 
src="http://html5shim.googlecode.com/svn/trunk/html5.js";></script>
-               <![endif]-->
-               
-       </head>
-
-       <body class="page-$config.fileId project-$config.projectId" 
data-spy="scroll" data-offset="60" data-target="#toc-scroll-target">
-
-               <div class="navbar navbar-fixed-top">
-                       <div class="navbar-inner">
-                               <div class="container">
-                                       <a class="btn btn-navbar" 
data-toggle="collapse" data-target=".nav-collapse">
-                                               <span class="icon-bar"></span>
-                                               <span class="icon-bar"></span>
-                                               <span class="icon-bar"></span>
-                                       </a>
-                                       <div class="nav-collapse">
-                                               <ul class="nav pull-right">
-                                                       <li class="active"><a 
href="" title="Helix 1.0.2">Helix 1.0.2 </a></li>
-                                                       <li class="dropdown 
active">
-                                                               <a href="#" 
class="dropdown-toggle" data-toggle="dropdown">Get Helix <b 
class="caret"></b></a>
-                                                               <ul 
class="dropdown-menu">
-                                                                       <li 
class="active"><a href="" title="Download">Download </a></li>
-                                                                       <li 
class="active"><a href="" title="Building">Building </a></li>
-                                                                       <li 
class="active"><a href="" title="Release Notes">Release Notes </a></li>
-                                                               </ul>
-                                                       </li>
-                                                       <li class="dropdown 
active">
-                                                               <a href="#" 
class="dropdown-toggle" data-toggle="dropdown">Hands-On <b 
class="caret"></b></a>
-                                                               <ul 
class="dropdown-menu">
-                                                                       <li 
class="active"><a href="" title="Quick Start">Quick Start </a></li>
-                                                                       <li 
class="active"><a href="" title="Tutorial">Tutorial </a></li>
-                                                                       <li 
class="active"><a href="" title="Javadocs">Javadocs </a></li>
-                                                               </ul>
-                                                       </li>
-                                                       <li class="dropdown 
active">
-                                                               <a href="#" 
class="dropdown-toggle" data-toggle="dropdown">Recipes <b class="caret"></b></a>
-                                                               <ul 
class="dropdown-menu">
-                                                                       <li 
class="active"><a href="" title="Distributed lock manager">Distributed lock 
manager </a></li>
-                                                                       <li 
class="active"><a href="" title="Rabbit MQ consumer group">Rabbit MQ consumer 
group </a></li>
-                                                                       <li 
class="active"><a href="" title="Rsync replicated file store">Rsync replicated 
file store </a></li>
-                                                                       <li 
class="active"><a href="" title="Service discovery">Service discovery </a></li>
-                                                                       <li 
class="active"><a href="" title="Distributed task DAG execution">Distributed 
task DAG execution </a></li>
-                                                               </ul>
-                                                       </li>
-                                               </ul>
-                                       </div><!--/.nav-collapse -->
-                               </div>
-                       </div>
-               </div>
-               
-       <div class="container">
-       
-       <!-- Masthead
-       ================================================== -->
-       <header class="jumbotron subhead">
-               <div class="row" id="banner">
-                       <div class="span12">
-                               <div class="pull-left">
-                                       <a href="" id="bannerLeft"><img src="" 
alt='"''"' /></a>
-                               </div>
-                               <div class="pull-right">
-                                       <a href="http://www.apache.org/"; 
id="bannerRight"><img src="" alt='"''"' /></a>
-                               </div>
-                       </div>
-               </div>
-               <div>
-                       <ul class="breadcrumb">
-                               <li><a href="" title="Apache Helix">Apache 
Helix </a></li>
-                               <li class="divider">/</li>
-                               <li><a href="" title="Release 1.0.2">Release 
1.0.2 </a></li>
-                               <li class="divider">/</li>
-                               <li>Privacy Policy</li>
-                               <li class="publishDate version-date 
pull-right">Last Published: 2022-04-23</li>
-                       </ul>
-               </div>
-       </header>
-
-       <div class="main-body">
-       <div class="row">
-               <div class="span12">
-                       <div class="body-content">
-$bodyWithHeader
-                       </div>
-               </div>
-       </div>
-       </div>
-
-       </div><!-- /container -->
-       
-       <!-- Footer
-       ================================================== -->
-       <footer class="well">
-               <div class="container">
-                       <div class="row">
-                               <div class="span9 bottom-nav">
-                                       <ul class="nav nav-list">
-                                               <li class="nav-header">Get 
Helix</li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Download">Download </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Building">Building </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Release Notes">Release Notes </a>
-                                               </li>
-                                               <li 
class="nav-header">Hands-On</li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Quick Start">Quick Start </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Tutorial">Tutorial </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Javadocs">Javadocs </a>
-                                               </li>
-                                               <li 
class="nav-header">Recipes</li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Distributed lock manager">Distributed lock manager </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Rabbit MQ consumer group">Rabbit MQ consumer group </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Rsync replicated file store">Rsync replicated file store </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Service discovery">Service discovery </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Distributed task DAG execution">Distributed task DAG execution </a>
-                                               </li>
-                                       </ul>
-                               </div>
-                       </div>
-               </div>
-       </footer>
-               
-       <div class="container subfooter">
-               <div class="row">
-                       <div class="span12">
-                               <p class="pull-right"><a href="#">Back to 
top</a></p>
-                               <p class="copyright">Copyright &copy;2022 <a 
href="https://www.apache.org/";>The Apache Software Foundation</a>. All Rights 
Reserved.</p>
-                               <p><a 
href="http://github.com/andriusvelykis/reflow-maven-skin"; title="Reflow Maven 
skin">Reflow Maven skin</a> by <a href="http://andrius.velykis.lt"; 
target="_blank" title="Andrius Velykis">Andrius Velykis</a>.</p>
-                                       </div>
-               </div>
-       </div>
-
-       <!-- Le javascript
-       ================================================== -->
-       <!-- Placed at the end of the document so the pages load faster -->
-
-       <!-- Fallback jQuery loading from Google CDN:
-            
http://stackoverflow.com/questions/1014203/best-way-to-use-googles-hosted-jquery-but-fall-back-to-my-hosted-library-on-go
 -->
-       <script type="text/javascript" 
src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js";></script>
-       <script type="text/javascript">
-               if (typeof jQuery == 'undefined')
-               {
-                       document.write(unescape("%3Cscript 
src='./js/jquery-1.8.3.min.js' type='text/javascript'%3E%3C/script%3E"));
-               }
-       </script>
-       
-       <script 
src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/js/bootstrap.min.js";></script>
-       <script src="./js/lightbox.js"></script>
-       <script src="./js/jquery.smooth-scroll.min.js"></script>
-       <!-- back button support for smooth scroll -->
-       <script src="./js/jquery.ba-bbq.min.js"></script>
-
-       <script src="./js/reflow-skin.js"></script>
-       
-       </body>
+<html xmlns="http://www.w3.org/1999/xhtml"; lang="en">
+  <head>
+    <meta charset="UTF-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1" />
+    <meta name="generator" content="Apache Maven Doxia Site Renderer 1.11.1" />
+    <meta name="author" content="Olivier Lamy" />
+    <meta name="date" content="2013-02-04" />
+    <title>Apache Helix &#x2013; Privacy Policy</title>
+    <link rel="stylesheet" 
href="./css/apache-maven-fluido-1.11.0-SNAPSHOT.min.css" />
+    <link rel="stylesheet" href="./css/site.css" />
+    <link rel="stylesheet" href="./css/print.css" media="print" />
+    <script src="./js/apache-maven-fluido-1.11.0-SNAPSHOT.min.js"></script>
+<script type="text/javascript">
+
+        var _gaq = _gaq || [];
+        _gaq.push(['_setAccount', 'UA-3211522-12']);
+        _gaq.push(['_trackPageview']);
+
+        (function() {
+        var ga = document.createElement('script'); ga.type = 
'text/javascript'; ga.async = true;
+        ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 
'http://www') + '.google-analytics.com/ga.js';
+        var s = document.getElementsByTagName('script')[0]; 
s.parentNode.insertBefore(ga, s);
+        })();
+
+      </script>
+  </head>
+  <body class="topBarEnabled">
+    <header id="topbar" class="navbar navbar-fixed-top ">
+      <div class="navbar-inner">
+        <div class="container-fluid">
+        <a data-target=".nav-collapse" data-toggle="collapse" class="btn 
btn-navbar">
+          <span class="icon-bar"></span>
+          <span class="icon-bar"></span>
+          <span class="icon-bar"></span>
+        </a>
+            <ul class="nav">
+      <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Get Helix 
<b class="caret"></b></a>
+        <ul class="dropdown-menu">
+            <li><a href="download.html" title="Download">Download</a></li>
+            <li><a href="Building.html" title="Building">Building</a></li>
+            <li><a href="releasenotes/release-1.0.2.html" title="Release 
Notes">Release Notes</a></li>
+        </ul>
+      </li>
+      <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Hands-On <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+            <li><a href="Quickstart.html" title="Quick Start">Quick 
Start</a></li>
+            <li><a href="Tutorial.html" title="Tutorial">Tutorial</a></li>
+            <li><a href="../javadocs/1.0.2" title="Javadocs">Javadocs</a></li>
+        </ul>
+      </li>
+      <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Recipes <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+            <li><a href="recipes/lock_manager.html" title="Distributed lock 
manager">Distributed lock manager</a></li>
+            <li><a href="recipes/rabbitmq_consumer_group.html" title="Rabbit 
MQ consumer group">Rabbit MQ consumer group</a></li>
+            <li><a href="recipes/rsync_replicated_file_store.html" 
title="Rsync replicated file store">Rsync replicated file store</a></li>
+            <li><a href="recipes/service_discovery.html" title="Service 
discovery">Service discovery</a></li>
+            <li><a href="recipes/task_dag_execution.html" title="Distributed 
task DAG execution">Distributed task DAG execution</a></li>
+        </ul>
+      </li>
+            </ul>
+            <ul class="nav pull-right">
+              <li class="dropdown">
+                <a href="#" class="dropdown-toggle" 
data-toggle="dropdown">External Links <b class="caret"></b></a>
+                <ul class="dropdown-menu">
+    <li><a href="index.html" title="Helix 1.0.2">Helix 1.0.2</a></li>
+                </ul>
+              </li>
+            </ul>
+        </div>
+      </div>
+    </header>
+    <div class="container-fluid">
+      <header>
+        <div id="banner">
+          <div class="pull-left"><a href="../" id="bannerLeft"><img 
src="../images/helix-logo.jpg"  alt=""/></a></div>
+          <div class="pull-right"><a href="https://www.apache.org/"; 
id="bannerRight"><img src="../images/feather_small.gif"  alt=""/></a></div>
+          <div class="clear"><hr/></div>
+        </div>
+
+        <div id="breadcrumbs">
+          <ul class="breadcrumb">
+      <li class=""><a href="http://helix.apache.org/"; class="externalLink" 
title="Apache Helix">Apache Helix</a><span class="divider">/</span></li>
+      <li class=""><a href="../" title="Apache Helix">Apache Helix</a><span 
class="divider">/</span></li>
+      <li class=""><a href="./" title="Release 1.0.2">Release 1.0.2</a><span 
class="divider">/</span></li>
+    <li class="active ">Privacy Policy</li>
+        <li id="publishDate" class="pull-right">Last Published: 2022-04-23</li>
+          </ul>
+        </div>
+      </header>
+      <div class="row-fluid">
+        <header id="leftColumn" class="span2">
+          <nav class="well sidebar-nav">
+  <ul class="nav nav-list">
+   <li class="nav-header">Get Helix</li>
+    <li><a href="download.html" title="Download"><span 
class="none"></span>Download</a></li>
+    <li><a href="Building.html" title="Building"><span 
class="none"></span>Building</a></li>
+    <li><a href="releasenotes/release-1.0.2.html" title="Release Notes"><span 
class="none"></span>Release Notes</a></li>
+   <li class="nav-header">Hands-On</li>
+    <li><a href="Quickstart.html" title="Quick Start"><span 
class="none"></span>Quick Start</a></li>
+    <li><a href="Tutorial.html" title="Tutorial"><span 
class="none"></span>Tutorial</a></li>
+    <li><a href="../javadocs/1.0.2" title="Javadocs"><span 
class="none"></span>Javadocs</a></li>
+   <li class="nav-header">Recipes</li>
+    <li><a href="recipes/lock_manager.html" title="Distributed lock 
manager"><span class="none"></span>Distributed lock manager</a></li>
+    <li><a href="recipes/rabbitmq_consumer_group.html" title="Rabbit MQ 
consumer group"><span class="none"></span>Rabbit MQ consumer group</a></li>
+    <li><a href="recipes/rsync_replicated_file_store.html" title="Rsync 
replicated file store"><span class="none"></span>Rsync replicated file 
store</a></li>
+    <li><a href="recipes/service_discovery.html" title="Service 
discovery"><span class="none"></span>Service discovery</a></li>
+    <li><a href="recipes/task_dag_execution.html" title="Distributed task DAG 
execution"><span class="none"></span>Distributed task DAG execution</a></li>
+  </ul>
+          </nav>
+          <div class="well sidebar-nav">
+<form id="search-form" action="https://www.google.com/search"; method="get" >
+  <input value="helix.apache.org/1.0.2-docs" name="sitesearch" type="hidden"/>
+  <input class="search-query" name="q" id="query" type="text" />
+</form>
+<script>asyncJs( 'https://cse.google.com/brand?form=search-form' )</script>
+            <hr />
+            <div id="poweredBy">
+              <div class="clear"></div>
+    <div id="twitter" style="border:none; margin-top: 10px">
+    <a href="https://twitter.com/ApacheHelix"; class="twitter-follow-button" 
data-show-count="false" data-align="left" data-size="medium" 
data-show-screen-name="true" data-lang="en">Follow ApacheHelix</a>
+    <script>!function(d,s,id){var 
js,fjs=d.getElementsByTagName(s)[0];if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src="//platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);}}(document,"script","twitter-wjs");</script>
+    </div>
+              <div class="clear"></div>
+              <div class="clear"></div>
+<a href="http://maven.apache.org/"; title="Built by Maven" 
class="poweredBy"><img class="builtBy" alt="Built by Maven" 
src="./images/logos/maven-feather.png" /></a>
+            </div>
+          </div>
+        </header>
+        <main id="bodyColumn"  class="span10" >
+<section>
+<h2><a name="Privacy_Policy"></a>Privacy Policy</h2>
+<p>Information about your use of this website is collected using server access 
logs and a tracking cookie. The collected information consists of the 
following:</p>
+<ol style="list-style-type: decimal">
+<li>The IP address from which you access the website;</li>
+<li>The type of browser and operating system you use to access our site;</li>
+<li>The date and time you access our site;</li>
+<li>The pages you visit; and</li>
+<li>The addresses of pages from where you followed a link to our 
site.</li></ol>
+<p>Part of this information is gathered using a tracking cookie set by the <a 
class="externalLink" href="http://www.google.com/analytics/";>Google 
Analytics</a> service and handled by Google as described in their <a 
class="externalLink" href="http://www.google.com/privacy.html";>privacy 
policy</a>. See your browser documentation for instructions on how to disable 
the cookie if you prefer not to share this data with Google.</p>
+<p>We use the gathered information to help us make our site more useful to 
visitors and to better understand how and when our site is used. We do not 
track or collect personally identifiable information or associate gathered data 
with any personally identifying information from other sources.</p>
+<p>By using this website, you consent to the collection of this data in the 
manner and for the purpose described above.</p></section>
+        </main>
+      </div>
+    </div>
+    <hr/>
+    <footer>
+      <div class="container-fluid">
+        <div class="row-fluid">
+<div class="row span16"><div>Apache Helix, Apache, the Apache feather logo, 
and the Apache Helix project logos are trademarks of The Apache Software 
Foundation.
+        All other marks mentioned may be trademarks or registered trademarks 
of their respective owners.</div>
+        <a 
href="https://helix.apache.org/1.0.2-docs/privacy-policy.html";>Privacy 
Policy</a>
+      </div>
+        </div>
+      </div>
+    </footer>
+<script>
+       if(anchors) {
+         anchors.add();
+       }
+</script>
+  </body>
 </html>
\ No newline at end of file

Modified: helix/site-content/1.0.2-docs/quota_scheduling.html
URL: 
http://svn.apache.org/viewvc/helix/site-content/1.0.2-docs/quota_scheduling.html?rev=1900184&r1=1900183&r2=1900184&view=diff
==============================================================================
--- helix/site-content/1.0.2-docs/quota_scheduling.html (original)
+++ helix/site-content/1.0.2-docs/quota_scheduling.html Sat Apr 23 04:22:15 2022
@@ -1,200 +1,357 @@
-
 <!DOCTYPE html>
+
+
 <!--
- Generated by Apache Maven Doxia at 2022-04-23
- Rendered using Maven Reflow Skin 1.0.0 
(http://andriusvelykis.github.com/reflow-maven-skin)
+ | Generated by Apache Maven Doxia Site Renderer 1.11.1 from 
src/site/markdown/quota_scheduling.md at 2022-04-23
+ | Rendered using Apache Maven Fluido Skin 1.11.0-SNAPSHOT
 -->
-<html  xml:lang="en" lang="en">
+<html xmlns="http://www.w3.org/1999/xhtml"; lang="en">
+  <head>
+    <meta charset="UTF-8" />
+    <meta name="viewport" content="width=device-width, initial-scale=1" />
+    <meta name="generator" content="Apache Maven Doxia Site Renderer 1.11.1" />
+    <title>Apache Helix &#x2013; Quota-based Task Scheduling</title>
+    <link rel="stylesheet" 
href="./css/apache-maven-fluido-1.11.0-SNAPSHOT.min.css" />
+    <link rel="stylesheet" href="./css/site.css" />
+    <link rel="stylesheet" href="./css/print.css" media="print" />
+    <script src="./js/apache-maven-fluido-1.11.0-SNAPSHOT.min.js"></script>
+<script type="text/javascript">
+
+        var _gaq = _gaq || [];
+        _gaq.push(['_setAccount', 'UA-3211522-12']);
+        _gaq.push(['_trackPageview']);
+
+        (function() {
+        var ga = document.createElement('script'); ga.type = 
'text/javascript'; ga.async = true;
+        ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 
'http://www') + '.google-analytics.com/ga.js';
+        var s = document.getElementsByTagName('script')[0]; 
s.parentNode.insertBefore(ga, s);
+        })();
+
+      </script>
+  </head>
+  <body class="topBarEnabled">
+    <header id="topbar" class="navbar navbar-fixed-top ">
+      <div class="navbar-inner">
+        <div class="container-fluid">
+        <a data-target=".nav-collapse" data-toggle="collapse" class="btn 
btn-navbar">
+          <span class="icon-bar"></span>
+          <span class="icon-bar"></span>
+          <span class="icon-bar"></span>
+        </a>
+            <ul class="nav">
+      <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Get Helix 
<b class="caret"></b></a>
+        <ul class="dropdown-menu">
+            <li><a href="download.html" title="Download">Download</a></li>
+            <li><a href="Building.html" title="Building">Building</a></li>
+            <li><a href="releasenotes/release-1.0.2.html" title="Release 
Notes">Release Notes</a></li>
+        </ul>
+      </li>
+      <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Hands-On <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+            <li><a href="Quickstart.html" title="Quick Start">Quick 
Start</a></li>
+            <li><a href="Tutorial.html" title="Tutorial">Tutorial</a></li>
+            <li><a href="../javadocs/1.0.2" title="Javadocs">Javadocs</a></li>
+        </ul>
+      </li>
+      <li class="dropdown">
+        <a href="#" class="dropdown-toggle" data-toggle="dropdown">Recipes <b 
class="caret"></b></a>
+        <ul class="dropdown-menu">
+            <li><a href="recipes/lock_manager.html" title="Distributed lock 
manager">Distributed lock manager</a></li>
+            <li><a href="recipes/rabbitmq_consumer_group.html" title="Rabbit 
MQ consumer group">Rabbit MQ consumer group</a></li>
+            <li><a href="recipes/rsync_replicated_file_store.html" 
title="Rsync replicated file store">Rsync replicated file store</a></li>
+            <li><a href="recipes/service_discovery.html" title="Service 
discovery">Service discovery</a></li>
+            <li><a href="recipes/task_dag_execution.html" title="Distributed 
task DAG execution">Distributed task DAG execution</a></li>
+        </ul>
+      </li>
+            </ul>
+            <ul class="nav pull-right">
+              <li class="dropdown">
+                <a href="#" class="dropdown-toggle" 
data-toggle="dropdown">External Links <b class="caret"></b></a>
+                <ul class="dropdown-menu">
+    <li><a href="index.html" title="Helix 1.0.2">Helix 1.0.2</a></li>
+                </ul>
+              </li>
+            </ul>
+        </div>
+      </div>
+    </header>
+    <div class="container-fluid">
+      <header>
+        <div id="banner">
+          <div class="pull-left"><a href="../" id="bannerLeft"><img 
src="../images/helix-logo.jpg"  alt=""/></a></div>
+          <div class="pull-right"><a href="https://www.apache.org/"; 
id="bannerRight"><img src="../images/feather_small.gif"  alt=""/></a></div>
+          <div class="clear"><hr/></div>
+        </div>
+
+        <div id="breadcrumbs">
+          <ul class="breadcrumb">
+      <li class=""><a href="http://helix.apache.org/"; class="externalLink" 
title="Apache Helix">Apache Helix</a><span class="divider">/</span></li>
+      <li class=""><a href="../" title="Apache Helix">Apache Helix</a><span 
class="divider">/</span></li>
+      <li class=""><a href="./" title="Release 1.0.2">Release 1.0.2</a><span 
class="divider">/</span></li>
+    <li class="active ">Quota-based Task Scheduling</li>
+        <li id="publishDate" class="pull-right">Last Published: 2022-04-23</li>
+          </ul>
+        </div>
+      </header>
+      <div class="row-fluid">
+        <header id="leftColumn" class="span2">
+          <nav class="well sidebar-nav">
+  <ul class="nav nav-list">
+   <li class="nav-header">Get Helix</li>
+    <li><a href="download.html" title="Download"><span 
class="none"></span>Download</a></li>
+    <li><a href="Building.html" title="Building"><span 
class="none"></span>Building</a></li>
+    <li><a href="releasenotes/release-1.0.2.html" title="Release Notes"><span 
class="none"></span>Release Notes</a></li>
+   <li class="nav-header">Hands-On</li>
+    <li><a href="Quickstart.html" title="Quick Start"><span 
class="none"></span>Quick Start</a></li>
+    <li><a href="Tutorial.html" title="Tutorial"><span 
class="none"></span>Tutorial</a></li>
+    <li><a href="../javadocs/1.0.2" title="Javadocs"><span 
class="none"></span>Javadocs</a></li>
+   <li class="nav-header">Recipes</li>
+    <li><a href="recipes/lock_manager.html" title="Distributed lock 
manager"><span class="none"></span>Distributed lock manager</a></li>
+    <li><a href="recipes/rabbitmq_consumer_group.html" title="Rabbit MQ 
consumer group"><span class="none"></span>Rabbit MQ consumer group</a></li>
+    <li><a href="recipes/rsync_replicated_file_store.html" title="Rsync 
replicated file store"><span class="none"></span>Rsync replicated file 
store</a></li>
+    <li><a href="recipes/service_discovery.html" title="Service 
discovery"><span class="none"></span>Service discovery</a></li>
+    <li><a href="recipes/task_dag_execution.html" title="Distributed task DAG 
execution"><span class="none"></span>Distributed task DAG execution</a></li>
+  </ul>
+          </nav>
+          <div class="well sidebar-nav">
+<form id="search-form" action="https://www.google.com/search"; method="get" >
+  <input value="helix.apache.org/1.0.2-docs" name="sitesearch" type="hidden"/>
+  <input class="search-query" name="q" id="query" type="text" />
+</form>
+<script>asyncJs( 'https://cse.google.com/brand?form=search-form' )</script>
+            <hr />
+            <div id="poweredBy">
+              <div class="clear"></div>
+    <div id="twitter" style="border:none; margin-top: 10px">
+    <a href="https://twitter.com/ApacheHelix"; class="twitter-follow-button" 
data-show-count="false" data-align="left" data-size="medium" 
data-show-screen-name="true" data-lang="en">Follow ApacheHelix</a>
+    <script>!function(d,s,id){var 
js,fjs=d.getElementsByTagName(s)[0];if(!d.getElementById(id)){js=d.createElement(s);js.id=id;js.src="//platform.twitter.com/widgets.js";fjs.parentNode.insertBefore(js,fjs);}}(document,"script","twitter-wjs");</script>
+    </div>
+              <div class="clear"></div>
+              <div class="clear"></div>
+<a href="http://maven.apache.org/"; title="Built by Maven" 
class="poweredBy"><img class="builtBy" alt="Built by Maven" 
src="./images/logos/maven-feather.png" /></a>
+            </div>
+          </div>
+        </header>
+        <main id="bodyColumn"  class="span10" >
+<!---
+Licensed to the Apache Software Foundation (ASF) under one
+or more contributor license agreements.  See the NOTICE file
+distributed with this work for additional information
+regarding copyright ownership.  The ASF licenses this file
+to you under the Apache License, Version 2.0 (the
+"License"); you may not use this file except in compliance
+with the License.  You may obtain a copy of the License at
+
+  http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing,
+software distributed under the License is distributed on an
+"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+KIND, either express or implied.  See the License for the
+specific language governing permissions and limitations
+under the License.
+-->
+<h1>Quota-based Task Scheduling</h1><section>
+<h2><a name="Introduction"></a>Introduction</h2>
+<p><img src="./images/quota_intro.png" alt="Intro" /></p>
+<p>Quota-based task scheduling is a feature addition to Helix Task Framework 
that enables users of Task Framework to apply the notion of categories in 
distributed task management.</p></section><section>
+<h2><a name="Purpose"></a>Purpose</h2>
+<p>As Helix Task Framework gains usage in other open-source frameworks such as 
<a class="externalLink" href="https://gobblin.apache.org/";>Apache Gobblin</a> 
and <a class="externalLink" href="http://pinot.incubator.apache.org/";>Apache 
Pinot</a>, it has also seen an increase in the variety in the types of 
distributed tasks it was managing. There have also been explicit feature 
requests to Helix for differentiating different types of tasks by creating 
corresponding quotas.</p>
+<p>Quota-based task scheduling aims to fulfill these requests by allowing 
users to define a quota profile consisting of quota types and their 
corresponding quotas. The goal of this feature is threefold: 1) the user will 
have the ability to prioritize one type of workflows/jobs/tasks over another 
and 2) achieve isolation among the type of tasks and 3) make monitoring easier 
by tracking the status of distributed execution by type.</p></section><section>
+<h2><a name="Glossary_and_Definitions"></a>Glossary and Definitions</h2>
+<ul>
+
+<li>Task Framework: a component of Apache Helix. A framework on which users 
can define and run workflows, jobs, and tasks in a distributed way.</li>
+<li>Workflow: the largest unit of work in Task Framework. A workflow consists 
of one or more jobs. There are two types of workflows:
+<ul>
+
+<li>Generic workflow: a generic workflow is a workflow consisting of jobs (a 
job DAG) that are used for general purposes. <b>A generic workflow may be 
removed if expired or timed out.</b></li>
+<li>Job queue: a job queue is a special type of workflow consisting of jobs 
that tend to have a linear dependency (this dependency is configurable, 
however). <b>There is no expiration for job queues</b> - it lives on until it 
is deleted.</li>
+</ul>
+</li>
+<li>Job: the second largest unit of work in Task Framework. A job consists of 
one or more mutually independent tasks. There are two types of jobs:
+<ul>
+
+<li>Generic job: a generic job is a job consisting of one or more tasks.</li>
+<li>Targeted job: a targeted job differs from generic jobs in that these jobs 
must have a  <i>target resource</i>, and the tasks belonging to such jobs will 
be scheduled alongside the partitions of the target resource. To illustrate, an 
Espresso user of Task Framework may wish to schedule a backup job on one of 
their DBs called  <i>MemberDataDB</i>. This DB will be divided into multiple 
partitions (_MemberDataDB_1, _MemberDataDB_2, &#x2026; 
<i>MemberDataDB_N)</i>__, and suppose that a targeted job is submitted such 
that its tasks will be paired up with each of those partitions. This 
&#x201c;pairing-up&#x201d; is necessary because this task is a backup task that 
needs to be on the same physical machine as those partitions the task is 
backing up.</li>
+</ul>
+</li>
+<li>Task: the <b>smallest unit of work</b> in Task Framework. A task is an 
independent unit of work.</li>
+<li>Quota resource type: denotes a particular type of resource. Examples would 
be JVM thread count, memory, CPU resources, etc.. Generally, each task that 
runs on a Helix Participant (= instance, worker, node) occupies a set amount of 
resources.  <b>Note that only JVM thread count is the only quota resource type 
currently supported by Task Framework, with each task occupying 1 thread out of 
40 threads available per Helix Participant (instance).</b></li>
+<li>Quota type: denotes which category a given job and its underlying tasks 
should be classified as. For example, you may define a quota configuration with 
two quota types, type &#x201c;Backup&#x201d;, and type 
&#x201c;Aggregation&#x201d; and a default type &#x201c;DEFAULT&#x201d;. You may 
prioritize the backup type by giving it a higher quota ratio - such as 
20:10:10, respectively. When there are streams of jobs being submitted, you can 
expect each Participant, assuming that it has a total of 40 JVM threads, will 
have 20 &#x201c;Backup&#x201d; tasks, 10 &#x201c;Aggregation&#x201d; tasks, and 
10 &#x201c;DEFAULT&#x201d; tasks. <b>Quota types are defined and applied at the 
job level, meaning all tasks belonging to a particular job with a quota type 
will be of that quota type.</b> Note that if a quota type is set for a 
workflow, then all jobs belonging to that workflow will  <i>inherit</i>  the 
type from the workflow.</li>
+<li>Quota: a number referring to a <b>relative ratio</b> that determines what 
portion of given resources should be allotted to a particular quota type.
+<ul>
+
+<li>E.g.) TYPE_0:  40, TYPE_1:  20, &#x2026;, DEFAULT:  40</li>
+</ul>
+</li>
+<li>Quota config: a set of string-integer mappings that indicate the  quota 
resource type, quota types, and corresponding quotas. <b>Task Framework stores 
the quota config in ClusterConfig.</b></li>
+</ul></section><section>
+<h2><a name="Architecture"></a>Architecture</h2><section>
+<h3><a name="AssignableInstance"></a>AssignableInstance</h3>
+<p>AssignableInstance is an abstraction that represents each live Participant 
that is able to take on tasks from the Controller. Each AssignableInstance will 
cache what tasks it has running  as well as remaining task counts from the 
quota-based capacity calculation.</p></section><section>
+<h3><a name="AssignableInstanceManager"></a>AssignableInstanceManager</h3>
+<p>AssignableInstanceManager manages all AssignableInstances. It also serves 
as a connecting layer between the Controller and each AssignableInstance. 
AssignableInstanceManager also provides a set of interfaces that allows the 
Controller to easily determine whether an AssignableInstance is able to take on 
more tasks.</p></section><section>
+<h3><a name="TaskAssigner"></a>TaskAssigner</h3>
+<p>The TaskAssigner interface provides basic API methods that involve 
assignments of tasks based on quota constraints. Currently, Task Framework only 
concerns the number of Participant-side JVM threads, each of which corresponds 
to an active task.</p></section><section>
+<h3><a name="RuntimeJobDag_.28JobDagIterator.29"></a>RuntimeJobDag 
(JobDagIterator)</h3>
+<p>This new component serves as an iterator for JobDAGs for the Controller. 
Previously, task assignment required the Controller to iterate through all jobs 
and their underlying tasks to determine whether there were any tasks that 
needed to be assigned and scheduled. This proved to be inefficient and did not 
scale with the increasing load we were putting on Task Framework. Each 
RuntimeJobDag records states, that is, it knows what task needs to be offered 
up to the Controller for scheduling. This saves the redundant computation for 
the Controller every time it goes through the TaskSchedulingStage of the Task 
pipeline.</p>
+<p><img src="./images/quota_InstanceCapacityManager.jpeg" alt="Architecture" 
/></p></section></section><section>
+<h2><a name="User_Manual"></a>User Manual</h2><section>
+<h3><a name="How_it_works"></a>How it works</h3>
+<p>Quota-based task scheduling works as follows. If a quota type is set, Task 
Framework will calculate a ratio against the sum of all quota config numbers 
for each quota type. Then it will apply that ratio to find the actual resource 
amount allotted to each quota type. Here is an example to illustrate this: 
Suppose the quota config is as follows:</p>
+
+<div class="source"><pre class="prettyprint"><code 
class="language-json">&quot;QUOTA_TYPES&quot;:{
+  &quot;A&quot;:&quot;2&quot;
+  ,&quot;B&quot;:&quot;1&quot;
+  ,&quot;DEFAULT&quot;:&quot;1&quot;
+}
+</code></pre></div>
+<p>Based on these raw numbers, Task Framework will compute the ratios. With 
the ratios, Task Framework will apply them to find the actual resource amount 
per quota type. The following table summarizes these calculations with  <b>the 
assumption of 40 JVM threads per instance</b>:</p>
+<table border="0" class="table table-striped">
+<thead>
+
+<tr class="a">
+<th align="center">Quota Type</th>
+<th align="center">Quota Config</th>
+<th align="center">Ratio</th>
+<th align="center">Actual Resource Allotted (# of JVM Threads)</th></tr>
+</thead><tbody>
+
+<tr class="b">
+<td align="left">A</td>
+<td align="center">2</td>
+<td align="center">50%</td>
+<td align="center">20</td></tr>
+<tr class="a">
+<td align="left">B</td>
+<td align="center">1</td>
+<td align="center">25%</td>
+<td align="center">10</td></tr>
+<tr class="b">
+<td align="left">DEFAULT</td>
+<td align="center">1</td>
+<td align="center">25%</td>
+<td align="center">10</td></tr>
+</tbody>
+</table>
+<p>Every instance (node) will have a quota profile that looks like this. This 
has a few implications. First, this allows for  <b>prioritization of certain 
jobs by allotting a greater amount of resources to corresponding quota 
types</b>. In that sense, you may treat quota config numbers/ratios as 
user-defined priority values. More specifically, take the quota profile in the 
example above. In this case, when there are 100 jobs submitted for each quota 
type, jobs of type A will finish faster; in other words, quota type A will see 
twice as much throughput when there is a continuous stream of jobs due to its 
quota ratio being twice that of other quota types.</p>
+<p>Quota-based task scheduling also allows for  
<b>isolation/compartmentalization in scheduling jobs</b>. Suppose there are two 
categories of jobs, with the first category being  <i>urgent</i>  jobs that are 
short-lived but need to be run right away. On the other hand, suppose that the 
second category of jobs tend to take longer, but they aren't as urgent and can 
take their time running. Previously, these two types of jobs will get assigned, 
scheduled, and run in a mix, and it was indeed difficult to ensure that jobs in 
the first category be processed in an urgent manner. Quota-based scheduling 
solves this problem by allowing the user to create quota types that model 
&#x201c;categories&#x201d; with different characteristics and 
requirements.</p></section><section>
+<h3><a name="How_to_use"></a>How to use</h3>
+<ul>
+
+<li>Setting a Quota Config in ClusterConfig</li>
+</ul>
+<p>In order to use quota-based task scheduling, you must establish a quota 
config first. This is a one-time operation, and once you verified that your 
ClusterConfig has a quota config set, there is no need to set it again. See the 
following code snippet for example:</p>
+
+<div class="source"><pre class="prettyprint"><code 
class="language-java">ClusterConfig clusterConfig = 
_manager.getConfigAccessor().getClusterConfig(CLUSTER_NAME); // Retrieve 
ClusterConfig
+clusterConfig.resetTaskQuotaRatioMap(); // Optional: you may want to reset the 
quota config before creating a new quota config
+clusterConfig.setTaskQuotaRatio(DEFAULT_QUOTA_TYPE, 10); // Define the default 
quota (DEFAULT_QUOTA_TYPE = &quot;DEFAULT&quot;)
+clusterConfig.setTaskQuotaRatio(&quot;A&quot;, 20); // Define quota type A
+clusterConfig.setTaskQuotaRatio(&quot;B&quot;, 10); // Define quota type B
+_manager.getConfigAccessor().setClusterConfig(CLUSTER_NAME, clusterConfig); // 
Set the new ClusterConfig
+</code></pre></div>
+<p>A word of caution - if you do set the quota config, you  <b>must</b> 
<b>always define the default quota type (with the key 
&#x201c;DEFAULT&#x201d;)</b>. Otherwise, jobs with no type information will no 
longer be scheduled and run. If you have been using Task Framework prior to the 
inception of quota-based scheduling, you might have recurrent workflows whose 
jobs do not have any type set. If you neglect to include the default quota 
type, these recurrent workflows will not execute properly.</p>
+<p>Upon setting the quota config in ClusterConfig, you will see the updated 
field in your ZooKeeper cluster config ZNode in the JSON format. See an example 
below:</p>
+
+<div class="source"><pre class="prettyprint"><code class="language-json">{
+  &quot;id&quot;:&quot;Example_Cluster&quot;
+  ,&quot;simpleFields&quot;:{
+    &quot;allowParticipantAutoJoin&quot;:&quot;true&quot;
+  }
+  ,&quot;listFields&quot;:{
+  }
+  ,&quot;mapFields&quot;:{
+    &quot;QUOTA_TYPES&quot;:{
+      &quot;A&quot;:&quot;20&quot;
+      ,&quot;B&quot;:&quot;10&quot;
+      ,&quot;DEFAULT&quot;:&quot;10&quot;
+    }
+  }
+}
+</code></pre></div>
+<ul>
+
+<li>Setting a quota type for workflows and jobs
+The Builders for WorkflowConfig and JobConfig provides a method for setting 
the quota type for the job. See below:</li>
+</ul>
+
+<div class="source"><pre class="prettyprint"><code 
class="language-java">JobConfig.Builder jobBuilderA =
+    new 
JobConfig.Builder().setCommand(JOB_COMMAND).setJobCommandConfigMap(_jobCommandMap)
+        
.addTaskConfigs(taskConfigsA).setNumConcurrentTasksPerInstance(50).setJobType(&quot;A&quot;);
 // Setting the job quota type as &quot;A&quot;
+workflowBuilder.addJob(&quot;JOB_A&quot;, jobBuilderA);
+</code></pre></div></section></section><section>
+<h2><a name="FAQ"></a>FAQ</h2>
+<ul>
+
+<li>What happens if I don't set a quota config in ClusterConfig?
+<ul>
+
+<li>When no quota config is found in ClusterConfig, Task Framework will treat 
all incoming jobs as DEFAULT and will give 100% of quota resources to the 
default type.</li>
+</ul>
+</li>
+<li>What happens if my job doesn't have a quota type set?
+<ul>
+
+<li>If Task Framework encounters a job without a quota type (that is, either 
the quotaType field is missing, is an empty String, or a literal 
&#x201c;null&#x201d;), then the job will be treated as a DEFAULT job.</li>
+</ul>
+</li>
+<li>What if there is a workflow/job whose quota type does not exist in the 
quota config I have in ClusterConfig?
+<ul>
+
+<li>Task Framework will  <b>not</b>  be able to locate the correct quota type, 
so it would  <b>treat it as the DEFAULT type</b>  and will assign and schedule 
accordingly using the quota for the DEFAULT type.</li>
+</ul>
+</li>
+<li>What about targeted jobs?
+<ul>
+
+<li>Quotas will also apply to targeted jobs, each task of the targeted job 
taking up a pre-set resource amount (currently each task occupies 1 JVM 
thread).</li>
+</ul>
+</li>
+<li>What about job queues?
+<ul>
+
+<li>Quota-based scheduling applies to all types of workflows - both generic 
workflows and job queues. A word of caution for the user is to be careful and 
always verify whether a job's quota type has been properly set. Task Framework 
will  <b>not</b>  automatically delete or inform the user of the jobs that are 
stuck due to an invalid quota type, so we caution all users to make sure the 
quota type exists by querying their settings in ClusterConfig.</li>
+</ul>
+</li>
+</ul></section><section>
+<h2><a name="Future_Steps"></a>Future Steps</h2>
+<p>Quota-based task scheduling has been tested internally at LinkedIn and has 
been integrated into <a class="externalLink" 
href="https://gobblin.apache.org/";>Apache Gobblin</a>, enabling users of Helix 
Task Framework and Gobblin's Job Launcher to define categories and 
corresponding quota values. There are a few immediate to-do's that will improve 
the usability of this feature:</p>
+<ul>
+
+<li>More fine-grained quota profile</li>
+</ul>
+<p>Currently, quota profiles apply across the entire cluster; that is, one 
quota profile defined in ClusterConfig will apply globally for all 
Participants. However, some use cases may require that each Participant have a 
different quota profile.</p>
+<ul>
+
+<li>Making Participants' maximum JVM thread capacity configurable</li>
+</ul>
+<p>Helix Task Framework has the maximum number of task threads set at 40. 
Making this configurable will potentially allow some users to increase 
throughput of tasks depending on the duration of execution of such tasks.</p>
+<ul>
 
-       <head>
-               <meta charset="UTF-8" />
-               <title>Apache Helix &#x2013; Quota-based Task Scheduling</title>
-               <meta name="viewport" content="width=device-width, 
initial-scale=1.0" />
-               <meta name="description" content="" />
-               <meta http-equiv="content-language" content="en" />
-
-               <link 
href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/css/bootstrap.min.css";
 rel="stylesheet" />
-               <link 
href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/css/bootstrap-responsive.min.css";
 rel="stylesheet" />
-               <link href="./css/docs.css" rel="stylesheet" />
-               <link href="./css/reflow-skin.css" rel="stylesheet" />
-               
-               
-               <link href="./css/lightbox.css" rel="stylesheet" />
-               
-               <link href="./css/site.css" rel="stylesheet" />
-               <link href="./css/print.css" rel="stylesheet" media="print" />
-               
-               <!-- Le HTML5 shim, for IE6-8 support of HTML5 elements -->
-               <!--[if lt IE 9]>
-                       <script 
src="http://html5shim.googlecode.com/svn/trunk/html5.js";></script>
-               <![endif]-->
-               
-       </head>
-
-       <body class="page-$config.fileId project-$config.projectId" 
data-spy="scroll" data-offset="60" data-target="#toc-scroll-target">
-
-               <div class="navbar navbar-fixed-top">
-                       <div class="navbar-inner">
-                               <div class="container">
-                                       <a class="btn btn-navbar" 
data-toggle="collapse" data-target=".nav-collapse">
-                                               <span class="icon-bar"></span>
-                                               <span class="icon-bar"></span>
-                                               <span class="icon-bar"></span>
-                                       </a>
-                                       <div class="nav-collapse">
-                                               <ul class="nav pull-right">
-                                                       <li class="active"><a 
href="" title="Helix 1.0.2">Helix 1.0.2 </a></li>
-                                                       <li class="dropdown 
active">
-                                                               <a href="#" 
class="dropdown-toggle" data-toggle="dropdown">Get Helix <b 
class="caret"></b></a>
-                                                               <ul 
class="dropdown-menu">
-                                                                       <li 
class="active"><a href="" title="Download">Download </a></li>
-                                                                       <li 
class="active"><a href="" title="Building">Building </a></li>
-                                                                       <li 
class="active"><a href="" title="Release Notes">Release Notes </a></li>
-                                                               </ul>
-                                                       </li>
-                                                       <li class="dropdown 
active">
-                                                               <a href="#" 
class="dropdown-toggle" data-toggle="dropdown">Hands-On <b 
class="caret"></b></a>
-                                                               <ul 
class="dropdown-menu">
-                                                                       <li 
class="active"><a href="" title="Quick Start">Quick Start </a></li>
-                                                                       <li 
class="active"><a href="" title="Tutorial">Tutorial </a></li>
-                                                                       <li 
class="active"><a href="" title="Javadocs">Javadocs </a></li>
-                                                               </ul>
-                                                       </li>
-                                                       <li class="dropdown 
active">
-                                                               <a href="#" 
class="dropdown-toggle" data-toggle="dropdown">Recipes <b class="caret"></b></a>
-                                                               <ul 
class="dropdown-menu">
-                                                                       <li 
class="active"><a href="" title="Distributed lock manager">Distributed lock 
manager </a></li>
-                                                                       <li 
class="active"><a href="" title="Rabbit MQ consumer group">Rabbit MQ consumer 
group </a></li>
-                                                                       <li 
class="active"><a href="" title="Rsync replicated file store">Rsync replicated 
file store </a></li>
-                                                                       <li 
class="active"><a href="" title="Service discovery">Service discovery </a></li>
-                                                                       <li 
class="active"><a href="" title="Distributed task DAG execution">Distributed 
task DAG execution </a></li>
-                                                               </ul>
-                                                       </li>
-                                               </ul>
-                                       </div><!--/.nav-collapse -->
-                               </div>
-                       </div>
-               </div>
-               
-       <div class="container">
-       
-       <!-- Masthead
-       ================================================== -->
-       <header class="jumbotron subhead">
-               <div class="row" id="banner">
-                       <div class="span12">
-                               <div class="pull-left">
-                                       <a href="" id="bannerLeft"><img src="" 
alt='"''"' /></a>
-                               </div>
-                               <div class="pull-right">
-                                       <a href="http://www.apache.org/"; 
id="bannerRight"><img src="" alt='"''"' /></a>
-                               </div>
-                       </div>
-               </div>
-               <div>
-                       <ul class="breadcrumb">
-                               <li><a href="" title="Apache Helix">Apache 
Helix </a></li>
-                               <li class="divider">/</li>
-                               <li><a href="" title="Release 1.0.2">Release 
1.0.2 </a></li>
-                               <li class="divider">/</li>
-                               <li>Quota-based Task Scheduling</li>
-                               <li class="publishDate version-date 
pull-right">Last Published: 2022-04-23</li>
-                       </ul>
-               </div>
-       </header>
-
-       <div class="main-body">
-       <div class="row">
-               <div class="span12">
-                       <div class="body-content">
-$bodyWithHeader
-                       </div>
-               </div>
-       </div>
-       </div>
-
-       </div><!-- /container -->
-       
-       <!-- Footer
-       ================================================== -->
-       <footer class="well">
-               <div class="container">
-                       <div class="row">
-                               <div class="span9 bottom-nav">
-                                       <ul class="nav nav-list">
-                                               <li class="nav-header">Get 
Helix</li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Download">Download </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Building">Building </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Release Notes">Release Notes </a>
-                                               </li>
-                                               <li 
class="nav-header">Hands-On</li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Quick Start">Quick Start </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Tutorial">Tutorial </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Javadocs">Javadocs </a>
-                                               </li>
-                                               <li 
class="nav-header">Recipes</li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Distributed lock manager">Distributed lock manager </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Rabbit MQ consumer group">Rabbit MQ consumer group </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Rsync replicated file store">Rsync replicated file store </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Service discovery">Service discovery </a>
-                                               </li>
-                                               <li class="active">
-                                                       <a href="#" 
title="Distributed task DAG execution">Distributed task DAG execution </a>
-                                               </li>
-                                       </ul>
-                               </div>
-                       </div>
-               </div>
-       </footer>
-               
-       <div class="container subfooter">
-               <div class="row">
-                       <div class="span12">
-                               <p class="pull-right"><a href="#">Back to 
top</a></p>
-                               <p class="copyright">Copyright &copy;2022 <a 
href="https://www.apache.org/";>The Apache Software Foundation</a>. All Rights 
Reserved.</p>
-                               <p><a 
href="http://github.com/andriusvelykis/reflow-maven-skin"; title="Reflow Maven 
skin">Reflow Maven skin</a> by <a href="http://andrius.velykis.lt"; 
target="_blank" title="Andrius Velykis">Andrius Velykis</a>.</p>
-                                       </div>
-               </div>
-       </div>
-
-       <!-- Le javascript
-       ================================================== -->
-       <!-- Placed at the end of the document so the pages load faster -->
-
-       <!-- Fallback jQuery loading from Google CDN:
-            
http://stackoverflow.com/questions/1014203/best-way-to-use-googles-hosted-jquery-but-fall-back-to-my-hosted-library-on-go
 -->
-       <script type="text/javascript" 
src="http://ajax.googleapis.com/ajax/libs/jquery/1.8.3/jquery.min.js";></script>
-       <script type="text/javascript">
-               if (typeof jQuery == 'undefined')
-               {
-                       document.write(unescape("%3Cscript 
src='./js/jquery-1.8.3.min.js' type='text/javascript'%3E%3C/script%3E"));
-               }
-       </script>
-       
-       <script 
src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.2.2/js/bootstrap.min.js";></script>
-       <script src="./js/lightbox.js"></script>
-       <script src="./js/jquery.smooth-scroll.min.js"></script>
-       <!-- back button support for smooth scroll -->
-       <script src="./js/jquery.ba-bbq.min.js"></script>
-
-       <script src="./js/reflow-skin.js"></script>
-       
-       </body>
+<li>Adding more dimensions to quota resource type</li>
+</ul>
+<p>Currently, the number of JVM threads per Participant is the only dimension 
where Helix Task Framework defines quota in. However, as discussed in earlier 
sections, this is extendable to commonly-used constraints such as CPU usage, 
memory usage, or disk usage. As new dimensions are added, there will need to be 
additional implementation of the TaskAssigner interface that produces 
assignments for tasks based on constraints.</p></section>
+        </main>
+      </div>
+    </div>
+    <hr/>
+    <footer>
+      <div class="container-fluid">
+        <div class="row-fluid">
+<div class="row span16"><div>Apache Helix, Apache, the Apache feather logo, 
and the Apache Helix project logos are trademarks of The Apache Software 
Foundation.
+        All other marks mentioned may be trademarks or registered trademarks 
of their respective owners.</div>
+        <a 
href="https://helix.apache.org/1.0.2-docs/privacy-policy.html";>Privacy 
Policy</a>
+      </div>
+        </div>
+      </div>
+    </footer>
+<script>
+       if(anchors) {
+         anchors.add();
+       }
+</script>
+  </body>
 </html>
\ No newline at end of file


Reply via email to