blob: 4d303a0610febacc830ff0f76b42b3d710a1e3be [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>SlurmController (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="SlurmController (Heron Java API)";
}
}
catch(err) {
}
//-->
var data = {"i0":10,"i1":10,"i2":10,"i3":10,"i4":10};
var tabs = {65535:["t0","All Methods"],2:["t2","Instance Methods"],8:["t4","Concrete 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.scheduler.slurm</a></div>
<h2 title="Class SlurmController" class="title">Class SlurmController</h2>
</div>
<div class="contentContainer">
<ul class="inheritance">
<li>java.lang.Object</li>
<li>
<ul class="inheritance">
<li>org.apache.heron.scheduler.slurm.SlurmController</li>
</ul>
</li>
</ul>
<div class="description">
<ul class="blockList">
<li class="blockList">
<hr>
<pre>public class <span class="typeNameLabel">SlurmController</span>
extends java.lang.Object</pre>
</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="t4" class="tableTab"><span><a href="javascript:show(8);">Concrete 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>boolean</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#createJob(java.lang.String,java.lang.String,java.lang.String%5B%5D,java.lang.String,long)">createJob</a></span>&#8203;(java.lang.String&nbsp;slurmScript,
java.lang.String&nbsp;heronExec,
java.lang.String[]&nbsp;commandArgs,
java.lang.String&nbsp;topologyWorkingDirectory,
long&nbsp;containers)</code></th>
<td class="colLast">
<div class="block">Create a slurm job.</div>
</td>
</tr>
<tr id="i1" class="rowColor">
<td class="colFirst"><code>boolean</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#createJob(java.lang.String,java.lang.String,java.lang.String%5B%5D,java.lang.String,long,java.lang.String)">createJob</a></span>&#8203;(java.lang.String&nbsp;slurmScript,
java.lang.String&nbsp;heronExec,
java.lang.String[]&nbsp;commandArgs,
java.lang.String&nbsp;topologyWorkingDirectory,
long&nbsp;containers,
java.lang.String&nbsp;partition)</code></th>
<td class="colLast">
<div class="block">Create a slurm job.</div>
</td>
</tr>
<tr id="i2" class="altColor">
<td class="colFirst"><code>boolean</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#killJob(java.lang.String)">killJob</a></span>&#8203;(java.lang.String&nbsp;jobIdFile)</code></th>
<td class="colLast">
<div class="block">Cancel the Slurm job by reading the jobid from the jobIdFile.</div>
</td>
</tr>
<tr id="i3" class="rowColor">
<td class="colFirst"><code>protected java.util.List&lt;java.lang.String&gt;</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#readFromFile(java.lang.String)">readFromFile</a></span>&#8203;(java.lang.String&nbsp;filename)</code></th>
<td class="colLast">
<div class="block">Read all the data from a text file line by line
For now lets keep this util function here.</div>
</td>
</tr>
<tr id="i4" class="altColor">
<td class="colFirst"><code>protected boolean</code></td>
<th class="colSecond" scope="row"><code><span class="memberNameLink"><a href="#runProcess(java.lang.String,java.lang.String%5B%5D,java.lang.StringBuilder)">runProcess</a></span>&#8203;(java.lang.String&nbsp;topologyWorkingDirectory,
java.lang.String[]&nbsp;slurmCmd,
java.lang.StringBuilder&nbsp;stderr)</code></th>
<td class="colLast">
<div class="block">This is for unit testing</div>
</td>
</tr>
</table>
<ul class="blockList">
<li class="blockList"><a id="methods.inherited.from.class.java.lang.Object">
<!-- -->
</a>
<h3>Methods inherited from class&nbsp;java.lang.Object</h3>
<code>clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait</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="createJob(java.lang.String,java.lang.String,java.lang.String[],java.lang.String,long,java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>createJob</h4>
<pre class="methodSignature">public&nbsp;boolean&nbsp;createJob&#8203;(java.lang.String&nbsp;slurmScript,
java.lang.String&nbsp;heronExec,
java.lang.String[]&nbsp;commandArgs,
java.lang.String&nbsp;topologyWorkingDirectory,
long&nbsp;containers,
java.lang.String&nbsp;partition)</pre>
<div class="block">Create a slurm job. Use the slurm scheduler's sbatch command to submit the job.
sbatch allocates the nodes and runs the script specified by slurmScript.
This script runs the heron executor on each of the nodes allocated.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>slurmScript</code> - slurm bash script to execute</dd>
<dd><code>heronExec</code> - the heron executable</dd>
<dd><code>commandArgs</code> - arguments to the heron executor</dd>
<dd><code>topologyWorkingDirectory</code> - working directory</dd>
<dd><code>containers</code> - number of containers required to run the topology</dd>
<dd><code>partition</code> - the queue to submit the job</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>true if the job creation is successful</dd>
</dl>
</li>
</ul>
<a id="createJob(java.lang.String,java.lang.String,java.lang.String[],java.lang.String,long)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>createJob</h4>
<pre class="methodSignature">public&nbsp;boolean&nbsp;createJob&#8203;(java.lang.String&nbsp;slurmScript,
java.lang.String&nbsp;heronExec,
java.lang.String[]&nbsp;commandArgs,
java.lang.String&nbsp;topologyWorkingDirectory,
long&nbsp;containers)</pre>
<div class="block">Create a slurm job. Use the slurm schedule'r sbatch command to submit the job.
sbatch allocates the nodes and runs the script specified by slurmScript.
This script runs the heron executor on each of the nodes allocated.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>slurmScript</code> - slurm bash script to execute</dd>
<dd><code>heronExec</code> - the heron executable</dd>
<dd><code>commandArgs</code> - arguments to the heron executor</dd>
<dd><code>topologyWorkingDirectory</code> - working directory</dd>
<dd><code>containers</code> - number of containers required to run the topology</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>true if the job creation is successful</dd>
</dl>
</li>
</ul>
<a id="runProcess(java.lang.String,java.lang.String[],java.lang.StringBuilder)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>runProcess</h4>
<pre class="methodSignature">protected&nbsp;boolean&nbsp;runProcess&#8203;(java.lang.String&nbsp;topologyWorkingDirectory,
java.lang.String[]&nbsp;slurmCmd,
java.lang.StringBuilder&nbsp;stderr)</pre>
<div class="block">This is for unit testing</div>
</li>
</ul>
<a id="killJob(java.lang.String)">
<!-- -->
</a>
<ul class="blockList">
<li class="blockList">
<h4>killJob</h4>
<pre class="methodSignature">public&nbsp;boolean&nbsp;killJob&#8203;(java.lang.String&nbsp;jobIdFile)</pre>
<div class="block">Cancel the Slurm job by reading the jobid from the jobIdFile. Uses scancel
command to cancel the job. The file contains a single line with the job id.
This file is written by the slurm job script after the job is allocated.</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>jobIdFile</code> - the jobId file</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>true if the job is cancelled successfully</dd>
</dl>
</li>
</ul>
<a id="readFromFile(java.lang.String)">
<!-- -->
</a>
<ul class="blockListLast">
<li class="blockList">
<h4>readFromFile</h4>
<pre class="methodSignature">protected&nbsp;java.util.List&lt;java.lang.String&gt;&nbsp;readFromFile&#8203;(java.lang.String&nbsp;filename)</pre>
<div class="block">Read all the data from a text file line by line
For now lets keep this util function here. We need to move it to a util location</div>
<dl>
<dt><span class="paramLabel">Parameters:</span></dt>
<dd><code>filename</code> - name of the file</dd>
<dt><span class="returnLabel">Returns:</span></dt>
<dd>string list containing the lines of the file, if failed to read, return an empty list</dd>
</dl>
</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>