blob: 8a4830bd2d1aa6715c957902f712bf87827317ea [file] [log] [blame]
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=9"/>
<meta name="generator" content="Doxygen 1.8.6"/>
<title>Impala: be/src/statestore/query-resource-mgr.cc Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="dynsections.js"></script>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
$(window).load(resizeHeight);
</script>
<link href="search/search.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="search/search.js"></script>
<script type="text/javascript">
$(document).ready(function() { searchBox.OnSelectItem(0); });
</script>
<link href="doxygen.css" rel="stylesheet" type="text/css" />
</head>
<body>
<div id="top"><!-- do not remove this div, it is closed by doxygen! -->
<div id="titlearea">
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td style="padding-left: 0.5em;">
<div id="projectname">Impala
</div>
<div id="projectbrief">Impalaistheopensource,nativeanalyticdatabaseforApacheHadoop.</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- end header part -->
<!-- Generated by Doxygen 1.8.6 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
<div id="navrow1" class="tabs">
<ul class="tablist">
<li><a href="index.html"><span>Main&#160;Page</span></a></li>
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
<li><a href="annotated.html"><span>Classes</span></a></li>
<li class="current"><a href="files.html"><span>Files</span></a></li>
<li>
<div id="MSearchBox" class="MSearchBoxInactive">
<span class="left">
<img id="MSearchSelect" src="search/mag_sel.png"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
alt=""/>
<input type="text" id="MSearchField" value="Search" accesskey="S"
onfocus="searchBox.OnSearchFieldFocus(true)"
onblur="searchBox.OnSearchFieldFocus(false)"
onkeyup="searchBox.OnSearchFieldChange(event)"/>
</span><span class="right">
<a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
</span>
</div>
</li>
</ul>
</div>
<div id="navrow2" class="tabs2">
<ul class="tablist">
<li><a href="files.html"><span>File&#160;List</span></a></li>
<li><a href="globals.html"><span>File&#160;Members</span></a></li>
</ul>
</div>
</div><!-- top -->
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
<div id="nav-sync" class="sync"></div>
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
$(document).ready(function(){initNavTree('query-resource-mgr_8cc_source.html','');});
</script>
<div id="doc-content">
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
onmouseover="return searchBox.OnSearchSelectShow()"
onmouseout="return searchBox.OnSearchSelectHide()"
onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Files</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(8)"><span class="SelectionMark">&#160;</span>Enumerator</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(9)"><span class="SelectionMark">&#160;</span>Friends</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(10)"><span class="SelectionMark">&#160;</span>Macros</a></div>
<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0"
name="MSearchResults" id="MSearchResults">
</iframe>
</div>
<div class="header">
<div class="headertitle">
<div class="title">query-resource-mgr.cc</div> </div>
</div><!--header-->
<div class="contents">
<a href="query-resource-mgr_8cc.html">Go to the documentation of this file.</a><div class="fragment"><div class="line"><a name="l00001"></a><span class="lineno"> 1</span>&#160;<span class="comment">// Copyright 2012 Cloudera Inc.</span></div>
<div class="line"><a name="l00002"></a><span class="lineno"> 2</span>&#160;<span class="comment">//</span></div>
<div class="line"><a name="l00003"></a><span class="lineno"> 3</span>&#160;<span class="comment">// Licensed under the Apache License, Version 2.0 (the &quot;License&quot;);</span></div>
<div class="line"><a name="l00004"></a><span class="lineno"> 4</span>&#160;<span class="comment">// you may not use this file except in compliance with the License.</span></div>
<div class="line"><a name="l00005"></a><span class="lineno"> 5</span>&#160;<span class="comment">// You may obtain a copy of the License at</span></div>
<div class="line"><a name="l00006"></a><span class="lineno"> 6</span>&#160;<span class="comment">//</span></div>
<div class="line"><a name="l00007"></a><span class="lineno"> 7</span>&#160;<span class="comment">// http://www.apache.org/licenses/LICENSE-2.0</span></div>
<div class="line"><a name="l00008"></a><span class="lineno"> 8</span>&#160;<span class="comment">//</span></div>
<div class="line"><a name="l00009"></a><span class="lineno"> 9</span>&#160;<span class="comment">// Unless required by applicable law or agreed to in writing, software</span></div>
<div class="line"><a name="l00010"></a><span class="lineno"> 10</span>&#160;<span class="comment">// distributed under the License is distributed on an &quot;AS IS&quot; BASIS,</span></div>
<div class="line"><a name="l00011"></a><span class="lineno"> 11</span>&#160;<span class="comment">// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span></div>
<div class="line"><a name="l00012"></a><span class="lineno"> 12</span>&#160;<span class="comment">// See the License for the specific language governing permissions and</span></div>
<div class="line"><a name="l00013"></a><span class="lineno"> 13</span>&#160;<span class="comment">// limitations under the License.</span></div>
<div class="line"><a name="l00014"></a><span class="lineno"> 14</span>&#160;</div>
<div class="line"><a name="l00015"></a><span class="lineno"> 15</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="query-resource-mgr_8h.html">statestore/query-resource-mgr.h</a>&quot;</span></div>
<div class="line"><a name="l00016"></a><span class="lineno"> 16</span>&#160;</div>
<div class="line"><a name="l00017"></a><span class="lineno"> 17</span>&#160;<span class="preprocessor">#include &lt;boost/foreach.hpp&gt;</span></div>
<div class="line"><a name="l00018"></a><span class="lineno"> 18</span>&#160;<span class="preprocessor">#include &lt;boost/uuid/uuid.hpp&gt;</span></div>
<div class="line"><a name="l00019"></a><span class="lineno"> 19</span>&#160;<span class="preprocessor">#include &lt;boost/uuid/uuid_generators.hpp&gt;</span></div>
<div class="line"><a name="l00020"></a><span class="lineno"> 20</span>&#160;<span class="preprocessor">#include &lt;gutil/strings/substitute.h&gt;</span></div>
<div class="line"><a name="l00021"></a><span class="lineno"> 21</span>&#160;<span class="preprocessor">#include &lt;sstream&gt;</span></div>
<div class="line"><a name="l00022"></a><span class="lineno"> 22</span>&#160;</div>
<div class="line"><a name="l00023"></a><span class="lineno"> 23</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="exec-env_8h.html">runtime/exec-env.h</a>&quot;</span></div>
<div class="line"><a name="l00024"></a><span class="lineno"> 24</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="resource-broker_8h.html">resourcebroker/resource-broker.h</a>&quot;</span></div>
<div class="line"><a name="l00025"></a><span class="lineno"> 25</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="container-util_8h.html">util/container-util.h</a>&quot;</span></div>
<div class="line"><a name="l00026"></a><span class="lineno"> 26</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="network-util_8h.html">util/network-util.h</a>&quot;</span></div>
<div class="line"><a name="l00027"></a><span class="lineno"> 27</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="promise_8h.html">util/promise.h</a>&quot;</span></div>
<div class="line"><a name="l00028"></a><span class="lineno"> 28</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="time_8h.html">util/time.h</a>&quot;</span></div>
<div class="line"><a name="l00029"></a><span class="lineno"> 29</span>&#160;</div>
<div class="line"><a name="l00030"></a><span class="lineno"> 30</span>&#160;<span class="preprocessor">#include &quot;<a class="code" href="names_8h.html">common/names.h</a>&quot;</span></div>
<div class="line"><a name="l00031"></a><span class="lineno"> 31</span>&#160;</div>
<div class="line"><a name="l00032"></a><span class="lineno"> 32</span>&#160;<span class="keyword">using</span> boost::uuids::random_generator;</div>
<div class="line"><a name="l00033"></a><span class="lineno"> 33</span>&#160;<span class="keyword">using</span> boost::uuids::uuid;</div>
<div class="line"><a name="l00034"></a><span class="lineno"> 34</span>&#160;<span class="keyword">using namespace </span>impala;</div>
<div class="line"><a name="l00035"></a><span class="lineno"> 35</span>&#160;<span class="keyword">using namespace </span>strings;</div>
<div class="line"><a name="l00036"></a><span class="lineno"> 36</span>&#160;</div>
<div class="line"><a name="l00037"></a><span class="lineno"><a class="line" href="query-resource-mgr_8cc.html#a24bf3427d3423dc9acca2d2db1df1f6b"> 37</a></span>&#160;<span class="keyword">const</span> int64_t <a class="code" href="query-resource-mgr_8cc.html#a24bf3427d3423dc9acca2d2db1df1f6b">DEFAULT_EXPANSION_REQUEST_TIMEOUT_MS</a> = 5000;</div>
<div class="line"><a name="l00038"></a><span class="lineno"> 38</span>&#160;</div>
<div class="line"><a name="l00039"></a><span class="lineno"> 39</span>&#160;<a class="code" href="query-resource-mgr_8cc.html#a4d9e5bafce4d149eb6a0a4ff93ba09c2">DEFINE_double</a>(max_vcore_oversubscription_ratio, 2.5, <span class="stringliteral">&quot;(Advanced) The maximum ratio &quot;</span></div>
<div class="line"><a name="l00040"></a><span class="lineno"> 40</span>&#160; <span class="stringliteral">&quot;allowed between running threads and acquired VCore resources for a query&#39;s fragments&quot;</span></div>
<div class="line"><a name="l00041"></a><span class="lineno"> 41</span>&#160; <span class="stringliteral">&quot; on a single node&quot;</span>);</div>
<div class="line"><a name="l00042"></a><span class="lineno"> 42</span>&#160;</div>
<div class="line"><a name="l00043"></a><span class="lineno"><a class="line" href="classimpala_1_1ResourceResolver.html#ae4fbc74771bbd9204917fd778cfdee36"> 43</a></span>&#160;<a class="code" href="classimpala_1_1ResourceResolver.html#ae4fbc74771bbd9204917fd778cfdee36">ResourceResolver::ResourceResolver</a>(<span class="keyword">const</span> unordered_set&lt;TNetworkAddress&gt;&amp; unique_hosts) {</div>
<div class="line"><a name="l00044"></a><span class="lineno"> 44</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>()-&gt;is_pseudo_distributed_llama()) {</div>
<div class="line"><a name="l00045"></a><span class="lineno"> 45</span>&#160; CreateLocalLlamaNodeMapping(unique_hosts);</div>
<div class="line"><a name="l00046"></a><span class="lineno"> 46</span>&#160; }</div>
<div class="line"><a name="l00047"></a><span class="lineno"> 47</span>&#160;}</div>
<div class="line"><a name="l00048"></a><span class="lineno"> 48</span>&#160;</div>
<div class="line"><a name="l00049"></a><span class="lineno"><a class="line" href="classimpala_1_1ResourceResolver.html#a9a8422510df7f059d96f3963df2078db"> 49</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1ResourceResolver.html#a9a8422510df7f059d96f3963df2078db">ResourceResolver::GetResourceHostport</a>(<span class="keyword">const</span> TNetworkAddress&amp; src,</div>
<div class="line"><a name="l00050"></a><span class="lineno"> 50</span>&#160; TNetworkAddress* dest) {</div>
<div class="line"><a name="l00051"></a><span class="lineno"> 51</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>()-&gt;is_pseudo_distributed_llama()) {</div>
<div class="line"><a name="l00052"></a><span class="lineno"> 52</span>&#160; *dest = impalad_to_dn_[src];</div>
<div class="line"><a name="l00053"></a><span class="lineno"> 53</span>&#160; } <span class="keywordflow">else</span> {</div>
<div class="line"><a name="l00054"></a><span class="lineno"> 54</span>&#160; dest-&gt;hostname = src.hostname;</div>
<div class="line"><a name="l00055"></a><span class="lineno"> 55</span>&#160; dest-&gt;port = 0;</div>
<div class="line"><a name="l00056"></a><span class="lineno"> 56</span>&#160; }</div>
<div class="line"><a name="l00057"></a><span class="lineno"> 57</span>&#160;}</div>
<div class="line"><a name="l00058"></a><span class="lineno"> 58</span>&#160;</div>
<div class="line"><a name="l00059"></a><span class="lineno"><a class="line" href="classimpala_1_1ResourceResolver.html#a8f6643c91e9f67880d082693744db578"> 59</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1ResourceResolver.html#a8f6643c91e9f67880d082693744db578">ResourceResolver::CreateLocalLlamaNodeMapping</a>(</div>
<div class="line"><a name="l00060"></a><span class="lineno"> 60</span>&#160; <span class="keyword">const</span> unordered_set&lt;TNetworkAddress&gt;&amp; unique_hosts) {</div>
<div class="line"><a name="l00061"></a><span class="lineno"> 61</span>&#160; DCHECK(<a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>()-&gt;is_pseudo_distributed_llama());</div>
<div class="line"><a name="l00062"></a><span class="lineno"> 62</span>&#160; <span class="keyword">const</span> vector&lt;string&gt;&amp; llama_nodes =</div>
<div class="line"><a name="l00063"></a><span class="lineno"> 63</span>&#160; <a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>()-&gt;<a class="code" href="classimpala_1_1ExecEnv.html#a069a3da92141cfb1b2ecef658d894392">resource_broker</a>()-&gt;<a class="code" href="classimpala_1_1ResourceBroker.html#a31c0aefde39c980a0ac942508c6e4ac8">llama_nodes</a>();</div>
<div class="line"><a name="l00064"></a><span class="lineno"> 64</span>&#160; DCHECK(!llama_nodes.empty());</div>
<div class="line"><a name="l00065"></a><span class="lineno"> 65</span>&#160; <span class="keywordtype">int</span> llama_node_ix = 0;</div>
<div class="line"><a name="l00066"></a><span class="lineno"> 66</span>&#160; BOOST_FOREACH(<span class="keyword">const</span> TNetworkAddress&amp; host, unique_hosts) {</div>
<div class="line"><a name="l00067"></a><span class="lineno"> 67</span>&#160; TNetworkAddress dn_hostport = <a class="code" href="namespaceimpala.html#a309108c8b3eaf4e5b154bc4eb4624880">MakeNetworkAddress</a>(llama_nodes[llama_node_ix]);</div>
<div class="line"><a name="l00068"></a><span class="lineno"> 68</span>&#160; impalad_to_dn_[host] = dn_hostport;</div>
<div class="line"><a name="l00069"></a><span class="lineno"> 69</span>&#160; dn_to_impalad_[dn_hostport] = host;</div>
<div class="line"><a name="l00070"></a><span class="lineno"> 70</span>&#160; LOG(INFO) &lt;&lt; <span class="stringliteral">&quot;Mapping Datanode &quot;</span> &lt;&lt; dn_hostport &lt;&lt; <span class="stringliteral">&quot; to Impalad: &quot;</span> &lt;&lt; host;</div>
<div class="line"><a name="l00071"></a><span class="lineno"> 71</span>&#160; <span class="comment">// Round robin the registered Llama nodes.</span></div>
<div class="line"><a name="l00072"></a><span class="lineno"> 72</span>&#160; llama_node_ix = (llama_node_ix + 1) % llama_nodes.size();</div>
<div class="line"><a name="l00073"></a><span class="lineno"> 73</span>&#160; }</div>
<div class="line"><a name="l00074"></a><span class="lineno"> 74</span>&#160;}</div>
<div class="line"><a name="l00075"></a><span class="lineno"> 75</span>&#160;</div>
<div class="line"><a name="l00076"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a8b83e88776213d3bc9c1a8ae1de6812a"> 76</a></span>&#160;<a class="code" href="classimpala_1_1QueryResourceMgr.html#a8b83e88776213d3bc9c1a8ae1de6812a">QueryResourceMgr::QueryResourceMgr</a>(<span class="keyword">const</span> TUniqueId&amp; reservation_id,</div>
<div class="line"><a name="l00077"></a><span class="lineno"> 77</span>&#160; <span class="keyword">const</span> TNetworkAddress&amp; local_resource_location, <span class="keyword">const</span> TUniqueId&amp; <a class="code" href="namespaceimpala.html#af9bbe2e7657f31e00eb4adbf126c2ce1">query_id</a>)</div>
<div class="line"><a name="l00078"></a><span class="lineno"> 78</span>&#160; : reservation_id_(reservation_id), <a class="code" href="namespaceimpala.html#acf144f0a59543984e935c4afb3525cbc">query_id_</a>(query_id),</div>
<div class="line"><a name="l00079"></a><span class="lineno"> 79</span>&#160; local_resource_location_(local_resource_location), exit_(false), callback_count_(0),</div>
<div class="line"><a name="l00080"></a><span class="lineno"> 80</span>&#160; threads_running_(0), vcores_(0) {</div>
<div class="line"><a name="l00081"></a><span class="lineno"> 81</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a2826351b009db29e80a4452cca727c55">max_vcore_oversubscription_ratio_</a> = FLAGS_max_vcore_oversubscription_ratio;</div>
<div class="line"><a name="l00082"></a><span class="lineno"> 82</span>&#160;}</div>
<div class="line"><a name="l00083"></a><span class="lineno"> 83</span>&#160;</div>
<div class="line"><a name="l00084"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a6b75c55f1e81093a971665211c5d99ff"> 84</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a6b75c55f1e81093a971665211c5d99ff">QueryResourceMgr::InitVcoreAcquisition</a>(int32_t init_vcores) {</div>
<div class="line"><a name="l00085"></a><span class="lineno"> 85</span>&#160; LOG(INFO) &lt;&lt; <span class="stringliteral">&quot;Initialising vcore acquisition thread for query &quot;</span> &lt;&lt; <a class="code" href="namespaceimpala.html#a19e01fc90bc956ac7e1a735d2bea5a5e">PrintId</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#ab52333a16e143bce561d056f36f8a609">query_id_</a>)</div>
<div class="line"><a name="l00086"></a><span class="lineno"> 86</span>&#160; &lt;&lt; <span class="stringliteral">&quot; (&quot;</span> &lt;&lt; init_vcores &lt;&lt; <span class="stringliteral">&quot; initial vcores)&quot;</span>;</div>
<div class="line"><a name="l00087"></a><span class="lineno"> 87</span>&#160; DCHECK(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a1554ae6f6f3faee9bc82a82d59c7c305">acquire_vcore_thread_</a>.get() == NULL)</div>
<div class="line"><a name="l00088"></a><span class="lineno"> 88</span>&#160; &lt;&lt; <span class="stringliteral">&quot;Double initialisation of QueryResourceMgr::InitCpuAcquisition()&quot;</span>;</div>
<div class="line"><a name="l00089"></a><span class="lineno"> 89</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#aa5447f64f910edc628fb5e258a507289">vcores_</a> = init_vcores;</div>
<div class="line"><a name="l00090"></a><span class="lineno"> 90</span>&#160;</div>
<div class="line"><a name="l00091"></a><span class="lineno"> 91</span>&#160; <span class="comment">// These shared pointers to atomic values are used to communicate between the vcore</span></div>
<div class="line"><a name="l00092"></a><span class="lineno"> 92</span>&#160; <span class="comment">// acquisition thread and the class destructor. If the acquisition thread is in the</span></div>
<div class="line"><a name="l00093"></a><span class="lineno"> 93</span>&#160; <span class="comment">// middle of an Expand() call, the destructor might have to wait 5s (the default</span></div>
<div class="line"><a name="l00094"></a><span class="lineno"> 94</span>&#160; <span class="comment">// timeout) to return. This holds up query close operations. So instead check to see if</span></div>
<div class="line"><a name="l00095"></a><span class="lineno"> 95</span>&#160; <span class="comment">// the thread is in Expand(), and if so we set a synchronised flag early_exit_ which it</span></div>
<div class="line"><a name="l00096"></a><span class="lineno"> 96</span>&#160; <span class="comment">// inspects immediately after exiting Expand(), and if true, exits before touching any</span></div>
<div class="line"><a name="l00097"></a><span class="lineno"> 97</span>&#160; <span class="comment">// of the class-wide state (because the destructor may have finished before this point).</span></div>
<div class="line"><a name="l00098"></a><span class="lineno"> 98</span>&#160;</div>
<div class="line"><a name="l00099"></a><span class="lineno"> 99</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#aa0ab13828f77267b6c5138e3f4d7acba">thread_in_expand_</a>.reset(<span class="keyword">new</span> <a class="code" href="classimpala_1_1AtomicInt.html">AtomicInt&lt;int16_t&gt;</a>());</div>
<div class="line"><a name="l00100"></a><span class="lineno"> 100</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a951a2b1bbb52218964c7209343b09e57">early_exit_</a>.reset(<span class="keyword">new</span> <a class="code" href="classimpala_1_1AtomicInt.html">AtomicInt&lt;int16_t&gt;</a>());</div>
<div class="line"><a name="l00101"></a><span class="lineno"> 101</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a1554ae6f6f3faee9bc82a82d59c7c305">acquire_vcore_thread_</a>.reset(</div>
<div class="line"><a name="l00102"></a><span class="lineno"> 102</span>&#160; <span class="keyword">new</span> <a class="code" href="classimpala_1_1Thread.html">Thread</a>(<span class="stringliteral">&quot;resource-mgmt&quot;</span>, Substitute(<span class="stringliteral">&quot;acquire-cpu-$0&quot;</span>, <a class="code" href="namespaceimpala.html#a19e01fc90bc956ac7e1a735d2bea5a5e">PrintId</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#ab52333a16e143bce561d056f36f8a609">query_id_</a>)),</div>
<div class="line"><a name="l00103"></a><span class="lineno"> 103</span>&#160; bind&lt;void&gt;(mem_fn(&amp;<a class="code" href="classimpala_1_1QueryResourceMgr.html#ad570e3ce975997e94bc5bc68fca7a76a">QueryResourceMgr::AcquireVcoreResources</a>), <span class="keyword">this</span>,</div>
<div class="line"><a name="l00104"></a><span class="lineno"> 104</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#aa0ab13828f77267b6c5138e3f4d7acba">thread_in_expand_</a>, <a class="code" href="classimpala_1_1QueryResourceMgr.html#a951a2b1bbb52218964c7209343b09e57">early_exit_</a>)));</div>
<div class="line"><a name="l00105"></a><span class="lineno"> 105</span>&#160;}</div>
<div class="line"><a name="l00106"></a><span class="lineno"> 106</span>&#160;</div>
<div class="line"><a name="l00107"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a174aae4b50f2577d6608a2d709658da1"> 107</a></span>&#160;<a class="code" href="classimpala_1_1Status.html">Status</a> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a174aae4b50f2577d6608a2d709658da1">QueryResourceMgr::CreateExpansionRequest</a>(int64_t memory_mb, int64_t vcores,</div>
<div class="line"><a name="l00108"></a><span class="lineno"> 108</span>&#160; TResourceBrokerExpansionRequest* request) {</div>
<div class="line"><a name="l00109"></a><span class="lineno"> 109</span>&#160; DCHECK(request != NULL);</div>
<div class="line"><a name="l00110"></a><span class="lineno"> 110</span>&#160; DCHECK(memory_mb &gt; 0 || vcores &gt; 0);</div>
<div class="line"><a name="l00111"></a><span class="lineno"> 111</span>&#160; DCHECK(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a52a3c04f04788be93866deaf6309b44a">reservation_id_</a> != TUniqueId()) &lt;&lt; <span class="stringliteral">&quot;Expansion requires existing reservation&quot;</span>;</div>
<div class="line"><a name="l00112"></a><span class="lineno"> 112</span>&#160;</div>
<div class="line"><a name="l00113"></a><span class="lineno"> 113</span>&#160; unordered_set&lt;TNetworkAddress&gt; hosts;</div>
<div class="line"><a name="l00114"></a><span class="lineno"> 114</span>&#160; hosts.insert(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a2b32dc607712d540a47085e9395efe38">local_resource_location_</a>);</div>
<div class="line"><a name="l00115"></a><span class="lineno"> 115</span>&#160; <a class="code" href="classimpala_1_1ResourceResolver.html">ResourceResolver</a> resolver(hosts);</div>
<div class="line"><a name="l00116"></a><span class="lineno"> 116</span>&#160; llama::TResource res;</div>
<div class="line"><a name="l00117"></a><span class="lineno"> 117</span>&#160; res.memory_mb = memory_mb;</div>
<div class="line"><a name="l00118"></a><span class="lineno"> 118</span>&#160; res.v_cpu_cores = vcores;</div>
<div class="line"><a name="l00119"></a><span class="lineno"> 119</span>&#160; TNetworkAddress res_address;</div>
<div class="line"><a name="l00120"></a><span class="lineno"> 120</span>&#160; resolver.<a class="code" href="classimpala_1_1ResourceResolver.html#a9a8422510df7f059d96f3963df2078db">GetResourceHostport</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a2b32dc607712d540a47085e9395efe38">local_resource_location_</a>, &amp;res_address);</div>
<div class="line"><a name="l00121"></a><span class="lineno"> 121</span>&#160; res.__set_askedLocation(<a class="code" href="namespaceimpala.html#a29b1cad3b2efbbe5d64a9f18417e7708">TNetworkAddressToString</a>(res_address));</div>
<div class="line"><a name="l00122"></a><span class="lineno"> 122</span>&#160;</div>
<div class="line"><a name="l00123"></a><span class="lineno"> 123</span>&#160; random_generator uuid_generator;</div>
<div class="line"><a name="l00124"></a><span class="lineno"> 124</span>&#160; uuid <span class="keywordtype">id</span> = uuid_generator();</div>
<div class="line"><a name="l00125"></a><span class="lineno"> 125</span>&#160; res.client_resource_id.hi = *<span class="keyword">reinterpret_cast&lt;</span><a class="code" href="classuint64__t.html">uint64_t</a>*<span class="keyword">&gt;</span>(&amp;<span class="keywordtype">id</span>.data[0]);</div>
<div class="line"><a name="l00126"></a><span class="lineno"> 126</span>&#160; res.client_resource_id.lo = *<span class="keyword">reinterpret_cast&lt;</span><a class="code" href="classuint64__t.html">uint64_t</a>*<span class="keyword">&gt;</span>(&amp;<span class="keywordtype">id</span>.data[8]);</div>
<div class="line"><a name="l00127"></a><span class="lineno"> 127</span>&#160; res.enforcement = llama::TLocationEnforcement::MUST;</div>
<div class="line"><a name="l00128"></a><span class="lineno"> 128</span>&#160;</div>
<div class="line"><a name="l00129"></a><span class="lineno"> 129</span>&#160; request-&gt;__set_resource(res);</div>
<div class="line"><a name="l00130"></a><span class="lineno"> 130</span>&#160; request-&gt;__set_reservation_id(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a52a3c04f04788be93866deaf6309b44a">reservation_id_</a>);</div>
<div class="line"><a name="l00131"></a><span class="lineno"> 131</span>&#160; request-&gt;__set_request_timeout(<a class="code" href="query-resource-mgr_8cc.html#a24bf3427d3423dc9acca2d2db1df1f6b">DEFAULT_EXPANSION_REQUEST_TIMEOUT_MS</a>);</div>
<div class="line"><a name="l00132"></a><span class="lineno"> 132</span>&#160;</div>
<div class="line"><a name="l00133"></a><span class="lineno"> 133</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classimpala_1_1Status.html#a580565665ea944eb64f3f495b1bee1e0">Status::OK</a>;</div>
<div class="line"><a name="l00134"></a><span class="lineno"> 134</span>&#160;}</div>
<div class="line"><a name="l00135"></a><span class="lineno"> 135</span>&#160;</div>
<div class="line"><a name="l00136"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a787bfa8a6ea43e0a0b1185932cd18127"> 136</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a787bfa8a6ea43e0a0b1185932cd18127">QueryResourceMgr::AboveVcoreSubscriptionThreshold</a>() {</div>
<div class="line"><a name="l00137"></a><span class="lineno"> 137</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#affd052e7e921b2685fc5e74f3278aa87">threads_running_</a> &gt; <a class="code" href="classimpala_1_1QueryResourceMgr.html#aa5447f64f910edc628fb5e258a507289">vcores_</a> * (<a class="code" href="classimpala_1_1QueryResourceMgr.html#a2826351b009db29e80a4452cca727c55">max_vcore_oversubscription_ratio_</a> * 0.8);</div>
<div class="line"><a name="l00138"></a><span class="lineno"> 138</span>&#160;}</div>
<div class="line"><a name="l00139"></a><span class="lineno"> 139</span>&#160;</div>
<div class="line"><a name="l00140"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a6fbd0b722ff0c7ac21a965fabcadebf0"> 140</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a6fbd0b722ff0c7ac21a965fabcadebf0">QueryResourceMgr::NotifyThreadUsageChange</a>(<span class="keywordtype">int</span> delta) {</div>
<div class="line"><a name="l00141"></a><span class="lineno"> 141</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#ad53f4d4d0e96e60fb81b5e67647ee6ea">threads_running_lock_</a>);</div>
<div class="line"><a name="l00142"></a><span class="lineno"> 142</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#affd052e7e921b2685fc5e74f3278aa87">threads_running_</a> += delta;</div>
<div class="line"><a name="l00143"></a><span class="lineno"> 143</span>&#160; DCHECK(<a class="code" href="classimpala_1_1QueryResourceMgr.html#affd052e7e921b2685fc5e74f3278aa87">threads_running_</a> &gt;= 0L);</div>
<div class="line"><a name="l00144"></a><span class="lineno"> 144</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1QueryResourceMgr.html#a787bfa8a6ea43e0a0b1185932cd18127">AboveVcoreSubscriptionThreshold</a>()) <a class="code" href="classimpala_1_1QueryResourceMgr.html#a1b3954e2ba70da252f96b734ba61a0fe">threads_changed_cv_</a>.notify_all();</div>
<div class="line"><a name="l00145"></a><span class="lineno"> 145</span>&#160;}</div>
<div class="line"><a name="l00146"></a><span class="lineno"> 146</span>&#160;</div>
<div class="line"><a name="l00147"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a88c3279b6bbe8d782bf272ec4756df07"> 147</a></span>&#160;int32_t <a class="code" href="classimpala_1_1QueryResourceMgr.html#a88c3279b6bbe8d782bf272ec4756df07">QueryResourceMgr::AddVcoreAvailableCb</a>(<span class="keyword">const</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a70fd20e3113f5d57944f17dae0054511">VcoreAvailableCb</a>&amp; callback) {</div>
<div class="line"><a name="l00148"></a><span class="lineno"> 148</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a88a5c03e7cf068424d7db0786384758e">callbacks_lock_</a>);</div>
<div class="line"><a name="l00149"></a><span class="lineno"> 149</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>[<a class="code" href="classimpala_1_1QueryResourceMgr.html#a1235cb65b3b55db534301daaeb138ebc">callback_count_</a>] = callback;</div>
<div class="line"><a name="l00150"></a><span class="lineno"> 150</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#afb0baff7dd5ffc9df898c24d2c0b472e">callbacks_it_</a> = <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.begin();</div>
<div class="line"><a name="l00151"></a><span class="lineno"> 151</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a1235cb65b3b55db534301daaeb138ebc">callback_count_</a>++;</div>
<div class="line"><a name="l00152"></a><span class="lineno"> 152</span>&#160;}</div>
<div class="line"><a name="l00153"></a><span class="lineno"> 153</span>&#160;</div>
<div class="line"><a name="l00154"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a03784ec11fcb18de5edfb28a481949ef"> 154</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a03784ec11fcb18de5edfb28a481949ef">QueryResourceMgr::RemoveVcoreAvailableCb</a>(int32_t callback_id) {</div>
<div class="line"><a name="l00155"></a><span class="lineno"> 155</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a88a5c03e7cf068424d7db0786384758e">callbacks_lock_</a>);</div>
<div class="line"><a name="l00156"></a><span class="lineno"> 156</span>&#160; CallbackMap::iterator it = <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.find(callback_id);</div>
<div class="line"><a name="l00157"></a><span class="lineno"> 157</span>&#160; DCHECK(it != <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.end()) &lt;&lt; <span class="stringliteral">&quot;Could not find callback with id: &quot;</span> &lt;&lt; callback_id;</div>
<div class="line"><a name="l00158"></a><span class="lineno"> 158</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.erase(it);</div>
<div class="line"><a name="l00159"></a><span class="lineno"> 159</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#afb0baff7dd5ffc9df898c24d2c0b472e">callbacks_it_</a> = <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.begin();</div>
<div class="line"><a name="l00160"></a><span class="lineno"> 160</span>&#160;}</div>
<div class="line"><a name="l00161"></a><span class="lineno"> 161</span>&#160;</div>
<div class="line"><a name="l00162"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#ad570e3ce975997e94bc5bc68fca7a76a"> 162</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#ad570e3ce975997e94bc5bc68fca7a76a">QueryResourceMgr::AcquireVcoreResources</a>(</div>
<div class="line"><a name="l00163"></a><span class="lineno"> 163</span>&#160; shared_ptr&lt;<a class="code" href="classimpala_1_1AtomicInt.html">AtomicInt&lt;int16_t&gt;</a> &gt; thread_in_expand,</div>
<div class="line"><a name="l00164"></a><span class="lineno"> 164</span>&#160; shared_ptr&lt;<a class="code" href="classimpala_1_1AtomicInt.html">AtomicInt&lt;int16_t&gt;</a> &gt; early_exit) {</div>
<div class="line"><a name="l00165"></a><span class="lineno"> 165</span>&#160; <span class="comment">// Take a copy because we&#39;d like to print it in some cases after the destructor.</span></div>
<div class="line"><a name="l00166"></a><span class="lineno"> 166</span>&#160; TUniqueId reservation_id = <a class="code" href="classimpala_1_1QueryResourceMgr.html#a52a3c04f04788be93866deaf6309b44a">reservation_id_</a>;</div>
<div class="line"><a name="l00167"></a><span class="lineno"> 167</span>&#160; <a class="code" href="logging_8h.html#a916e38366cee7c32fd5fae7e2ee5e4a9">VLOG_QUERY</a> &lt;&lt; <span class="stringliteral">&quot;Starting Vcore acquisition for: &quot;</span> &lt;&lt; reservation_id;</div>
<div class="line"><a name="l00168"></a><span class="lineno"> 168</span>&#160; <span class="keywordflow">while</span> (!<a class="code" href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220">ShouldExit</a>()) {</div>
<div class="line"><a name="l00169"></a><span class="lineno"> 169</span>&#160; {</div>
<div class="line"><a name="l00170"></a><span class="lineno"> 170</span>&#160; unique_lock&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#ad53f4d4d0e96e60fb81b5e67647ee6ea">threads_running_lock_</a>);</div>
<div class="line"><a name="l00171"></a><span class="lineno"> 171</span>&#160; <span class="keywordflow">while</span> (!<a class="code" href="classimpala_1_1QueryResourceMgr.html#a787bfa8a6ea43e0a0b1185932cd18127">AboveVcoreSubscriptionThreshold</a>() &amp;&amp; !<a class="code" href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220">ShouldExit</a>()) {</div>
<div class="line"><a name="l00172"></a><span class="lineno"> 172</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a1b3954e2ba70da252f96b734ba61a0fe">threads_changed_cv_</a>.wait(l);</div>
<div class="line"><a name="l00173"></a><span class="lineno"> 173</span>&#160; }</div>
<div class="line"><a name="l00174"></a><span class="lineno"> 174</span>&#160; }</div>
<div class="line"><a name="l00175"></a><span class="lineno"> 175</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220">ShouldExit</a>()) <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00176"></a><span class="lineno"> 176</span>&#160;</div>
<div class="line"><a name="l00177"></a><span class="lineno"> 177</span>&#160; TResourceBrokerExpansionRequest request;</div>
<div class="line"><a name="l00178"></a><span class="lineno"> 178</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a174aae4b50f2577d6608a2d709658da1">CreateExpansionRequest</a>(0L, 1, &amp;request);</div>
<div class="line"><a name="l00179"></a><span class="lineno"> 179</span>&#160; TResourceBrokerExpansionResponse response;</div>
<div class="line"><a name="l00180"></a><span class="lineno"> 180</span>&#160; <a class="code" href="logging_8h.html#a916e38366cee7c32fd5fae7e2ee5e4a9">VLOG_QUERY</a> &lt;&lt; <span class="stringliteral">&quot;Expanding VCore allocation: &quot;</span> &lt;&lt; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a52a3c04f04788be93866deaf6309b44a">reservation_id_</a>;</div>
<div class="line"><a name="l00181"></a><span class="lineno"> 181</span>&#160;</div>
<div class="line"><a name="l00182"></a><span class="lineno"> 182</span>&#160; <span class="comment">// First signal that we are about to enter a blocking Expand() call.</span></div>
<div class="line"><a name="l00183"></a><span class="lineno"> 183</span>&#160; thread_in_expand-&gt;FetchAndUpdate(1L);</div>
<div class="line"><a name="l00184"></a><span class="lineno"> 184</span>&#160; <span class="comment">// TODO: Could cause problems if called during or after a system-wide shutdown</span></div>
<div class="line"><a name="l00185"></a><span class="lineno"> 185</span>&#160; <a class="code" href="classimpala_1_1Status.html">Status</a> status = <a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>()-&gt;<a class="code" href="classimpala_1_1ExecEnv.html#a069a3da92141cfb1b2ecef658d894392">resource_broker</a>()-&gt;<a class="code" href="classimpala_1_1ResourceBroker.html#a4bdb13443a9e76bf23a2ff7635df179b">Expand</a>(request, &amp;response);</div>
<div class="line"><a name="l00186"></a><span class="lineno"> 186</span>&#160; thread_in_expand-&gt;FetchAndUpdate(-1L);</div>
<div class="line"><a name="l00187"></a><span class="lineno"> 187</span>&#160; <span class="comment">// If signalled to exit quickly by the destructor, exit the loop now. It&#39;s important</span></div>
<div class="line"><a name="l00188"></a><span class="lineno"> 188</span>&#160; <span class="comment">// to do so without accessing any class variables since they may no longer be valid.</span></div>
<div class="line"><a name="l00189"></a><span class="lineno"> 189</span>&#160; <span class="keywordflow">if</span> (early_exit-&gt;FetchAndUpdate(0L) != 0) {</div>
<div class="line"><a name="l00190"></a><span class="lineno"> 190</span>&#160; <a class="code" href="logging_8h.html#a916e38366cee7c32fd5fae7e2ee5e4a9">VLOG_QUERY</a> &lt;&lt; <span class="stringliteral">&quot;Fragment finished during Expand(): &quot;</span> &lt;&lt; reservation_id;</div>
<div class="line"><a name="l00191"></a><span class="lineno"> 191</span>&#160; <span class="keywordflow">break</span>;</div>
<div class="line"><a name="l00192"></a><span class="lineno"> 192</span>&#160; }</div>
<div class="line"><a name="l00193"></a><span class="lineno"> 193</span>&#160; <span class="keywordflow">if</span> (!status.<a class="code" href="classimpala_1_1Status.html#a95ba859e42fe93445b340533220836ac">ok</a>()) {</div>
<div class="line"><a name="l00194"></a><span class="lineno"> 194</span>&#160; <a class="code" href="logging_8h.html#a916e38366cee7c32fd5fae7e2ee5e4a9">VLOG_QUERY</a> &lt;&lt; <span class="stringliteral">&quot;Could not expand CPU resources for query &quot;</span> &lt;&lt; <a class="code" href="namespaceimpala.html#a19e01fc90bc956ac7e1a735d2bea5a5e">PrintId</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#ab52333a16e143bce561d056f36f8a609">query_id_</a>)</div>
<div class="line"><a name="l00195"></a><span class="lineno"> 195</span>&#160; &lt;&lt; <span class="stringliteral">&quot;, reservation: &quot;</span> &lt;&lt; <a class="code" href="namespaceimpala.html#a19e01fc90bc956ac7e1a735d2bea5a5e">PrintId</a>(reservation_id_) &lt;&lt; <span class="stringliteral">&quot;. Error was: &quot;</span></div>
<div class="line"><a name="l00196"></a><span class="lineno"> 196</span>&#160; &lt;&lt; status.<a class="code" href="classimpala_1_1Status.html#adf1a3ee82776f6102bfe873925183159">GetDetail</a>();</div>
<div class="line"><a name="l00197"></a><span class="lineno"> 197</span>&#160; <span class="comment">// Sleep to avoid flooding the resource broker, particularly if requests are being</span></div>
<div class="line"><a name="l00198"></a><span class="lineno"> 198</span>&#160; <span class="comment">// rejected quickly (and therefore we stay oversubscribed)</span></div>
<div class="line"><a name="l00199"></a><span class="lineno"> 199</span>&#160; <span class="comment">// TODO: configurable timeout</span></div>
<div class="line"><a name="l00200"></a><span class="lineno"> 200</span>&#160; <a class="code" href="namespaceimpala.html#a57debe017e657e4692b405fa183f7ca8">SleepForMs</a>(250);</div>
<div class="line"><a name="l00201"></a><span class="lineno"> 201</span>&#160; <span class="keywordflow">continue</span>;</div>
<div class="line"><a name="l00202"></a><span class="lineno"> 202</span>&#160; }</div>
<div class="line"><a name="l00203"></a><span class="lineno"> 203</span>&#160;</div>
<div class="line"><a name="l00204"></a><span class="lineno"> 204</span>&#160; <span class="keyword">const</span> llama::TAllocatedResource&amp; resource =</div>
<div class="line"><a name="l00205"></a><span class="lineno"> 205</span>&#160; response.allocated_resources.begin()-&gt;second;</div>
<div class="line"><a name="l00206"></a><span class="lineno"> 206</span>&#160; DCHECK(resource.v_cpu_cores == 1)</div>
<div class="line"><a name="l00207"></a><span class="lineno"> 207</span>&#160; &lt;&lt; <span class="stringliteral">&quot;Asked for 1 core, got: &quot;</span> &lt;&lt; resource.v_cpu_cores;</div>
<div class="line"><a name="l00208"></a><span class="lineno"> 208</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#aa5447f64f910edc628fb5e258a507289">vcores_</a> += resource.v_cpu_cores;</div>
<div class="line"><a name="l00209"></a><span class="lineno"> 209</span>&#160;</div>
<div class="line"><a name="l00210"></a><span class="lineno"> 210</span>&#160; <a class="code" href="classimpala_1_1ExecEnv.html">ExecEnv</a>* exec_env = <a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>();</div>
<div class="line"><a name="l00211"></a><span class="lineno"> 211</span>&#160; <span class="keyword">const</span> <span class="keywordtype">string</span>&amp; cgroup =</div>
<div class="line"><a name="l00212"></a><span class="lineno"> 212</span>&#160; exec_env-&gt;<a class="code" href="classimpala_1_1ExecEnv.html#adab640721575c6afe9074faf5ef11925">cgroups_mgr</a>()-&gt;<a class="code" href="classimpala_1_1CgroupsMgr.html#a5701489ab164cd3b884a9224642e20b5">UniqueIdToCgroup</a>(<a class="code" href="namespaceimpala.html#a19e01fc90bc956ac7e1a735d2bea5a5e">PrintId</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#ab52333a16e143bce561d056f36f8a609">query_id_</a>, <span class="stringliteral">&quot;_&quot;</span>));</div>
<div class="line"><a name="l00213"></a><span class="lineno"> 213</span>&#160; int32_t num_shares = exec_env-&gt;<a class="code" href="classimpala_1_1ExecEnv.html#adab640721575c6afe9074faf5ef11925">cgroups_mgr</a>()-&gt;<a class="code" href="classimpala_1_1CgroupsMgr.html#adfeeb00cc7ae88cd90c7119046c268dd">VirtualCoresToCpuShares</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#aa5447f64f910edc628fb5e258a507289">vcores_</a>);</div>
<div class="line"><a name="l00214"></a><span class="lineno"> 214</span>&#160; exec_env-&gt;<a class="code" href="classimpala_1_1ExecEnv.html#adab640721575c6afe9074faf5ef11925">cgroups_mgr</a>()-&gt;<a class="code" href="classimpala_1_1CgroupsMgr.html#a0dcf5e114e1bc41a8762f001c0388b49">SetCpuShares</a>(cgroup, num_shares);</div>
<div class="line"><a name="l00215"></a><span class="lineno"> 215</span>&#160;</div>
<div class="line"><a name="l00216"></a><span class="lineno"> 216</span>&#160; <span class="comment">// TODO: Only call one callback no matter how many VCores we just added; maybe call</span></div>
<div class="line"><a name="l00217"></a><span class="lineno"> 217</span>&#160; <span class="comment">// all of them?</span></div>
<div class="line"><a name="l00218"></a><span class="lineno"> 218</span>&#160; {</div>
<div class="line"><a name="l00219"></a><span class="lineno"> 219</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a88a5c03e7cf068424d7db0786384758e">callbacks_lock_</a>);</div>
<div class="line"><a name="l00220"></a><span class="lineno"> 220</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.size() != 0) {</div>
<div class="line"><a name="l00221"></a><span class="lineno"> 221</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#afb0baff7dd5ffc9df898c24d2c0b472e">callbacks_it_</a>-&gt;second();</div>
<div class="line"><a name="l00222"></a><span class="lineno"> 222</span>&#160; <span class="keywordflow">if</span> (++<a class="code" href="classimpala_1_1QueryResourceMgr.html#afb0baff7dd5ffc9df898c24d2c0b472e">callbacks_it_</a> == <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.end()) <a class="code" href="classimpala_1_1QueryResourceMgr.html#afb0baff7dd5ffc9df898c24d2c0b472e">callbacks_it_</a> = <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.begin();</div>
<div class="line"><a name="l00223"></a><span class="lineno"> 223</span>&#160; }</div>
<div class="line"><a name="l00224"></a><span class="lineno"> 224</span>&#160; }</div>
<div class="line"><a name="l00225"></a><span class="lineno"> 225</span>&#160; }</div>
<div class="line"><a name="l00226"></a><span class="lineno"> 226</span>&#160; <a class="code" href="logging_8h.html#a916e38366cee7c32fd5fae7e2ee5e4a9">VLOG_QUERY</a> &lt;&lt; <span class="stringliteral">&quot;Leaving VCore acquisition thread: &quot;</span> &lt;&lt; reservation_id;</div>
<div class="line"><a name="l00227"></a><span class="lineno"> 227</span>&#160;}</div>
<div class="line"><a name="l00228"></a><span class="lineno"> 228</span>&#160;</div>
<div class="line"><a name="l00229"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220"> 229</a></span>&#160;<span class="keywordtype">bool</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220">QueryResourceMgr::ShouldExit</a>() {</div>
<div class="line"><a name="l00230"></a><span class="lineno"> 230</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#aa268ca963b06b52a72f8f8e2f257f463">exit_lock_</a>);</div>
<div class="line"><a name="l00231"></a><span class="lineno"> 231</span>&#160; <span class="keywordflow">return</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a5f57f77ffadbe9de80222dbee4e71602">exit_</a>;</div>
<div class="line"><a name="l00232"></a><span class="lineno"> 232</span>&#160;}</div>
<div class="line"><a name="l00233"></a><span class="lineno"> 233</span>&#160;</div>
<div class="line"><a name="l00234"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a8e522ace9edb5b4d956cdec70e4be121"> 234</a></span>&#160;<span class="keywordtype">void</span> <a class="code" href="classimpala_1_1QueryResourceMgr.html#a8e522ace9edb5b4d956cdec70e4be121">QueryResourceMgr::Shutdown</a>() {</div>
<div class="line"><a name="l00235"></a><span class="lineno"> 235</span>&#160; {</div>
<div class="line"><a name="l00236"></a><span class="lineno"> 236</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#aa268ca963b06b52a72f8f8e2f257f463">exit_lock_</a>);</div>
<div class="line"><a name="l00237"></a><span class="lineno"> 237</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1QueryResourceMgr.html#a5f57f77ffadbe9de80222dbee4e71602">exit_</a>) <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00238"></a><span class="lineno"> 238</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a5f57f77ffadbe9de80222dbee4e71602">exit_</a> = <span class="keyword">true</span>;</div>
<div class="line"><a name="l00239"></a><span class="lineno"> 239</span>&#160; }</div>
<div class="line"><a name="l00240"></a><span class="lineno"> 240</span>&#160; {</div>
<div class="line"><a name="l00241"></a><span class="lineno"> 241</span>&#160; lock_guard&lt;mutex&gt; l(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a88a5c03e7cf068424d7db0786384758e">callbacks_lock_</a>);</div>
<div class="line"><a name="l00242"></a><span class="lineno"> 242</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">callbacks_</a>.clear();</div>
<div class="line"><a name="l00243"></a><span class="lineno"> 243</span>&#160; }</div>
<div class="line"><a name="l00244"></a><span class="lineno"> 244</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a1b3954e2ba70da252f96b734ba61a0fe">threads_changed_cv_</a>.notify_all();</div>
<div class="line"><a name="l00245"></a><span class="lineno"> 245</span>&#160;</div>
<div class="line"><a name="l00246"></a><span class="lineno"> 246</span>&#160; <span class="comment">// Delete all non-reservation requests associated with this reservation ID. If this the</span></div>
<div class="line"><a name="l00247"></a><span class="lineno"> 247</span>&#160; <span class="comment">// coordinator, the SimpleScheduler will actually release the resources by releasing the</span></div>
<div class="line"><a name="l00248"></a><span class="lineno"> 248</span>&#160; <span class="comment">// original reservation ID.</span></div>
<div class="line"><a name="l00249"></a><span class="lineno"> 249</span>&#160; <a class="code" href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">ExecEnv::GetInstance</a>()-&gt;<a class="code" href="classimpala_1_1ExecEnv.html#a069a3da92141cfb1b2ecef658d894392">resource_broker</a>()-&gt;<a class="code" href="classimpala_1_1ResourceBroker.html#a3a5711b7000bc4574c632b078fa735c4">ClearRequests</a>(<a class="code" href="classimpala_1_1QueryResourceMgr.html#a52a3c04f04788be93866deaf6309b44a">reservation_id_</a>, <span class="keyword">false</span>);</div>
<div class="line"><a name="l00250"></a><span class="lineno"> 250</span>&#160;}</div>
<div class="line"><a name="l00251"></a><span class="lineno"> 251</span>&#160;</div>
<div class="line"><a name="l00252"></a><span class="lineno"><a class="line" href="classimpala_1_1QueryResourceMgr.html#a120ac55fc791fbea24db9e76444a8f77"> 252</a></span>&#160;<a class="code" href="classimpala_1_1QueryResourceMgr.html#a120ac55fc791fbea24db9e76444a8f77">QueryResourceMgr::~QueryResourceMgr</a>() {</div>
<div class="line"><a name="l00253"></a><span class="lineno"> 253</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1QueryResourceMgr.html#a1554ae6f6f3faee9bc82a82d59c7c305">acquire_vcore_thread_</a>.get() == NULL) <span class="keywordflow">return</span>;</div>
<div class="line"><a name="l00254"></a><span class="lineno"> 254</span>&#160; <span class="keywordflow">if</span> (!<a class="code" href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220">ShouldExit</a>()) <a class="code" href="classimpala_1_1QueryResourceMgr.html#a8e522ace9edb5b4d956cdec70e4be121">Shutdown</a>();</div>
<div class="line"><a name="l00255"></a><span class="lineno"> 255</span>&#160; <span class="comment">// First, set the early exit flag. Then check to see if the thread is in Expand(). If</span></div>
<div class="line"><a name="l00256"></a><span class="lineno"> 256</span>&#160; <span class="comment">// so, the acquisition thread is guaranteed to see early_exit_ == 1L once it finishes</span></div>
<div class="line"><a name="l00257"></a><span class="lineno"> 257</span>&#160; <span class="comment">// Expand(), and will exit immediately. It&#39;s therefore safe not to wait for it.</span></div>
<div class="line"><a name="l00258"></a><span class="lineno"> 258</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a951a2b1bbb52218964c7209343b09e57">early_exit_</a>-&gt;FetchAndUpdate(1L);</div>
<div class="line"><a name="l00259"></a><span class="lineno"> 259</span>&#160; <span class="keywordflow">if</span> (<a class="code" href="classimpala_1_1QueryResourceMgr.html#aa0ab13828f77267b6c5138e3f4d7acba">thread_in_expand_</a>-&gt;FetchAndUpdate(0L) == 0L) {</div>
<div class="line"><a name="l00260"></a><span class="lineno"> 260</span>&#160; <a class="code" href="classimpala_1_1QueryResourceMgr.html#a1554ae6f6f3faee9bc82a82d59c7c305">acquire_vcore_thread_</a>-&gt;Join();</div>
<div class="line"><a name="l00261"></a><span class="lineno"> 261</span>&#160; }</div>
<div class="line"><a name="l00262"></a><span class="lineno"> 262</span>&#160;}</div>
<div class="ttc" id="classimpala_1_1ResourceResolver_html_a9a8422510df7f059d96f3963df2078db"><div class="ttname"><a href="classimpala_1_1ResourceResolver.html#a9a8422510df7f059d96f3963df2078db">impala::ResourceResolver::GetResourceHostport</a></div><div class="ttdeci">void GetResourceHostport(const TNetworkAddress &amp;src, TNetworkAddress *dst)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00049">query-resource-mgr.cc:49</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a2b32dc607712d540a47085e9395efe38"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a2b32dc607712d540a47085e9395efe38">impala::QueryResourceMgr::local_resource_location_</a></div><div class="ttdeci">TNetworkAddress local_resource_location_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00151">query-resource-mgr.h:151</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_aa5447f64f910edc628fb5e258a507289"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#aa5447f64f910edc628fb5e258a507289">impala::QueryResourceMgr::vcores_</a></div><div class="ttdeci">int64_t vcores_</div><div class="ttdoc">The number of VCores acquired for this node for this query. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00181">query-resource-mgr.h:181</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_aa0ab13828f77267b6c5138e3f4d7acba"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#aa0ab13828f77267b6c5138e3f4d7acba">impala::QueryResourceMgr::thread_in_expand_</a></div><div class="ttdeci">boost::shared_ptr&lt; AtomicInt&lt; int16_t &gt; &gt; thread_in_expand_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00201">query-resource-mgr.h:201</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a88c3279b6bbe8d782bf272ec4756df07"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a88c3279b6bbe8d782bf272ec4756df07">impala::QueryResourceMgr::AddVcoreAvailableCb</a></div><div class="ttdeci">int32_t AddVcoreAvailableCb(const VcoreAvailableCb &amp;callback)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00147">query-resource-mgr.cc:147</a></div></div>
<div class="ttc" id="classimpala_1_1Status_html_adf1a3ee82776f6102bfe873925183159"><div class="ttname"><a href="classimpala_1_1Status.html#adf1a3ee82776f6102bfe873925183159">impala::Status::GetDetail</a></div><div class="ttdeci">const std::string GetDetail() const </div><div class="ttdef"><b>Definition:</b> <a href="status_8cc_source.html#l00184">status.cc:184</a></div></div>
<div class="ttc" id="namespaceimpala_html_a29b1cad3b2efbbe5d64a9f18417e7708"><div class="ttname"><a href="namespaceimpala.html#a29b1cad3b2efbbe5d64a9f18417e7708">impala::TNetworkAddressToString</a></div><div class="ttdeci">string TNetworkAddressToString(const TNetworkAddress &amp;address)</div><div class="ttdoc">Utility method to print address as address:port. </div><div class="ttdef"><b>Definition:</b> <a href="network-util_8cc_source.html#l00126">network-util.cc:126</a></div></div>
<div class="ttc" id="classimpala_1_1CgroupsMgr_html_adfeeb00cc7ae88cd90c7119046c268dd"><div class="ttname"><a href="classimpala_1_1CgroupsMgr.html#adfeeb00cc7ae88cd90c7119046c268dd">impala::CgroupsMgr::VirtualCoresToCpuShares</a></div><div class="ttdeci">int32_t VirtualCoresToCpuShares(int16_t v_cpu_cores)</div><div class="ttdef"><b>Definition:</b> <a href="cgroups-mgr_8cc_source.html#l00059">cgroups-mgr.cc:59</a></div></div>
<div class="ttc" id="query-resource-mgr_8cc_html_a4d9e5bafce4d149eb6a0a4ff93ba09c2"><div class="ttname"><a href="query-resource-mgr_8cc.html#a4d9e5bafce4d149eb6a0a4ff93ba09c2">DEFINE_double</a></div><div class="ttdeci">DEFINE_double(max_vcore_oversubscription_ratio, 2.5,&quot;(Advanced) The maximum ratio &quot;&quot;allowed between running threads and acquired VCore resources for a query's fragments&quot;&quot; on a single node&quot;)</div></div>
<div class="ttc" id="classimpala_1_1ResourceResolver_html_ae4fbc74771bbd9204917fd778cfdee36"><div class="ttname"><a href="classimpala_1_1ResourceResolver.html#ae4fbc74771bbd9204917fd778cfdee36">impala::ResourceResolver::ResourceResolver</a></div><div class="ttdeci">ResourceResolver(const boost::unordered_set&lt; TNetworkAddress &gt; &amp;unique_hosts)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00043">query-resource-mgr.cc:43</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a787bfa8a6ea43e0a0b1185932cd18127"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a787bfa8a6ea43e0a0b1185932cd18127">impala::QueryResourceMgr::AboveVcoreSubscriptionThreshold</a></div><div class="ttdeci">bool AboveVcoreSubscriptionThreshold()</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00136">query-resource-mgr.cc:136</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_aa268ca963b06b52a72f8f8e2f257f463"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#aa268ca963b06b52a72f8f8e2f257f463">impala::QueryResourceMgr::exit_lock_</a></div><div class="ttdeci">boost::mutex exit_lock_</div><div class="ttdoc">Used to control shutdown of AcquireCpuResources(). </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00154">query-resource-mgr.h:154</a></div></div>
<div class="ttc" id="classimpala_1_1Thread_html"><div class="ttname"><a href="classimpala_1_1Thread.html">impala::Thread</a></div><div class="ttdoc">TODO: Consider allowing fragment IDs as category parameters. </div><div class="ttdef"><b>Definition:</b> <a href="thread_8h_source.html#l00045">thread.h:45</a></div></div>
<div class="ttc" id="time_8h_html"><div class="ttname"><a href="time_8h.html">time.h</a></div></div>
<div class="ttc" id="namespaceimpala_html_acf144f0a59543984e935c4afb3525cbc"><div class="ttname"><a href="namespaceimpala.html#acf144f0a59543984e935c4afb3525cbc">impala::query_id_</a></div><div class="ttdeci">TUniqueId query_id_</div><div class="ttdef"><b>Definition:</b> <a href="coordinator_8h_source.html#l00194">coordinator.h:194</a></div></div>
<div class="ttc" id="namespaceimpala_html_af9bbe2e7657f31e00eb4adbf126c2ce1"><div class="ttname"><a href="namespaceimpala.html#af9bbe2e7657f31e00eb4adbf126c2ce1">impala::query_id</a></div><div class="ttdeci">const TUniqueId &amp; query_id() const </div><div class="ttdef"><b>Definition:</b> <a href="coordinator_8h_source.html#l00152">coordinator.h:152</a></div></div>
<div class="ttc" id="classimpala_1_1CgroupsMgr_html_a5701489ab164cd3b884a9224642e20b5"><div class="ttname"><a href="classimpala_1_1CgroupsMgr.html#a5701489ab164cd3b884a9224642e20b5">impala::CgroupsMgr::UniqueIdToCgroup</a></div><div class="ttdeci">std::string UniqueIdToCgroup(const std::string &amp;unique_id) const </div><div class="ttdef"><b>Definition:</b> <a href="cgroups-mgr_8cc_source.html#l00054">cgroups-mgr.cc:54</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a1b3954e2ba70da252f96b734ba61a0fe"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a1b3954e2ba70da252f96b734ba61a0fe">impala::QueryResourceMgr::threads_changed_cv_</a></div><div class="ttdeci">boost::condition_variable threads_changed_cv_</div><div class="ttdoc">Waited on by AcquireCpuResources(), and notified by NotifyThreadUsageChange(). </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00175">query-resource-mgr.h:175</a></div></div>
<div class="ttc" id="query-resource-mgr_8h_html"><div class="ttname"><a href="query-resource-mgr_8h.html">query-resource-mgr.h</a></div></div>
<div class="ttc" id="classimpala_1_1ResourceResolver_html_a8f6643c91e9f67880d082693744db578"><div class="ttname"><a href="classimpala_1_1ResourceResolver.html#a8f6643c91e9f67880d082693744db578">impala::ResourceResolver::CreateLocalLlamaNodeMapping</a></div><div class="ttdeci">void CreateLocalLlamaNodeMapping(const boost::unordered_set&lt; TNetworkAddress &gt; &amp;unique_hosts)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00059">query-resource-mgr.cc:59</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a8e522ace9edb5b4d956cdec70e4be121"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a8e522ace9edb5b4d956cdec70e4be121">impala::QueryResourceMgr::Shutdown</a></div><div class="ttdeci">void Shutdown()</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00234">query-resource-mgr.cc:234</a></div></div>
<div class="ttc" id="classimpala_1_1CgroupsMgr_html_a0dcf5e114e1bc41a8762f001c0388b49"><div class="ttname"><a href="classimpala_1_1CgroupsMgr.html#a0dcf5e114e1bc41a8762f001c0388b49">impala::CgroupsMgr::SetCpuShares</a></div><div class="ttdeci">Status SetCpuShares(const std::string &amp;cgroup, int32_t num_shares)</div><div class="ttdef"><b>Definition:</b> <a href="cgroups-mgr_8cc_source.html#l00101">cgroups-mgr.cc:101</a></div></div>
<div class="ttc" id="namespaceimpala_html_a309108c8b3eaf4e5b154bc4eb4624880"><div class="ttname"><a href="namespaceimpala.html#a309108c8b3eaf4e5b154bc4eb4624880">impala::MakeNetworkAddress</a></div><div class="ttdeci">TNetworkAddress MakeNetworkAddress(const string &amp;hostname, int port)</div><div class="ttdef"><b>Definition:</b> <a href="network-util_8cc_source.html#l00096">network-util.cc:96</a></div></div>
<div class="ttc" id="classimpala_1_1AtomicInt_html"><div class="ttname"><a href="classimpala_1_1AtomicInt.html">impala::AtomicInt</a></div><div class="ttdef"><b>Definition:</b> <a href="atomic_8h_source.html#l00046">atomic.h:46</a></div></div>
<div class="ttc" id="namespaceimpala_html_a19e01fc90bc956ac7e1a735d2bea5a5e"><div class="ttname"><a href="namespaceimpala.html#a19e01fc90bc956ac7e1a735d2bea5a5e">impala::PrintId</a></div><div class="ttdeci">string PrintId(const TUniqueId &amp;id, const string &amp;separator)</div><div class="ttdef"><b>Definition:</b> <a href="debug-util_8cc_source.html#l00097">debug-util.cc:97</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_affd052e7e921b2685fc5e74f3278aa87"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#affd052e7e921b2685fc5e74f3278aa87">impala::QueryResourceMgr::threads_running_</a></div><div class="ttdeci">int64_t threads_running_</div><div class="ttdoc">The number of threads we know to be running on behalf of this query. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00178">query-resource-mgr.h:178</a></div></div>
<div class="ttc" id="namespaceimpala_html_a57debe017e657e4692b405fa183f7ca8"><div class="ttname"><a href="namespaceimpala.html#a57debe017e657e4692b405fa183f7ca8">impala::SleepForMs</a></div><div class="ttdeci">void SleepForMs(const int64_t duration_ms)</div><div class="ttdoc">Sleeps the current thread for at least duration_ms milliseconds. </div><div class="ttdef"><b>Definition:</b> <a href="time_8cc_source.html#l00021">time.cc:21</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a8b83e88776213d3bc9c1a8ae1de6812a"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a8b83e88776213d3bc9c1a8ae1de6812a">impala::QueryResourceMgr::QueryResourceMgr</a></div><div class="ttdeci">QueryResourceMgr(const TUniqueId &amp;reservation_id, const TNetworkAddress &amp;local_resource_location, const TUniqueId &amp;query_id)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00076">query-resource-mgr.cc:76</a></div></div>
<div class="ttc" id="classimpala_1_1ExecEnv_html_a069a3da92141cfb1b2ecef658d894392"><div class="ttname"><a href="classimpala_1_1ExecEnv.html#a069a3da92141cfb1b2ecef658d894392">impala::ExecEnv::resource_broker</a></div><div class="ttdeci">ResourceBroker * resource_broker()</div><div class="ttdef"><b>Definition:</b> <a href="exec-env_8h_source.html#l00095">exec-env.h:95</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a52a3c04f04788be93866deaf6309b44a"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a52a3c04f04788be93866deaf6309b44a">impala::QueryResourceMgr::reservation_id_</a></div><div class="ttdeci">TUniqueId reservation_id_</div><div class="ttdoc">ID of the single reservation corresponding to this query. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00143">query-resource-mgr.h:143</a></div></div>
<div class="ttc" id="classimpala_1_1ResourceBroker_html_a3a5711b7000bc4574c632b078fa735c4"><div class="ttname"><a href="classimpala_1_1ResourceBroker.html#a3a5711b7000bc4574c632b078fa735c4">impala::ResourceBroker::ClearRequests</a></div><div class="ttdeci">void ClearRequests(const TUniqueId &amp;reservation_id, bool include_reservation)</div><div class="ttdef"><b>Definition:</b> <a href="resource-broker_8cc_source.html#l00636">resource-broker.cc:636</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_afb0baff7dd5ffc9df898c24d2c0b472e"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#afb0baff7dd5ffc9df898c24d2c0b472e">impala::QueryResourceMgr::callbacks_it_</a></div><div class="ttdeci">CallbackMap::iterator callbacks_it_</div><div class="ttdoc">Round-robin iterator to notify callbacks about new VCores one at a time. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00165">query-resource-mgr.h:165</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a70fd20e3113f5d57944f17dae0054511"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a70fd20e3113f5d57944f17dae0054511">impala::QueryResourceMgr::VcoreAvailableCb</a></div><div class="ttdeci">boost::function&lt; void()&gt; VcoreAvailableCb</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00122">query-resource-mgr.h:122</a></div></div>
<div class="ttc" id="classimpala_1_1Status_html"><div class="ttname"><a href="classimpala_1_1Status.html">impala::Status</a></div><div class="ttdef"><b>Definition:</b> <a href="status_8h_source.html#l00081">status.h:81</a></div></div>
<div class="ttc" id="classimpala_1_1ExecEnv_html_adab640721575c6afe9074faf5ef11925"><div class="ttname"><a href="classimpala_1_1ExecEnv.html#adab640721575c6afe9074faf5ef11925">impala::ExecEnv::cgroups_mgr</a></div><div class="ttdeci">CgroupsMgr * cgroups_mgr()</div><div class="ttdef"><b>Definition:</b> <a href="exec-env_8h_source.html#l00088">exec-env.h:88</a></div></div>
<div class="ttc" id="logging_8h_html_a916e38366cee7c32fd5fae7e2ee5e4a9"><div class="ttname"><a href="logging_8h.html#a916e38366cee7c32fd5fae7e2ee5e4a9">VLOG_QUERY</a></div><div class="ttdeci">#define VLOG_QUERY</div><div class="ttdef"><b>Definition:</b> <a href="logging_8h_source.html#l00057">logging.h:57</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_ad53f4d4d0e96e60fb81b5e67647ee6ea"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#ad53f4d4d0e96e60fb81b5e67647ee6ea">impala::QueryResourceMgr::threads_running_lock_</a></div><div class="ttdeci">boost::mutex threads_running_lock_</div><div class="ttdoc">Protects threads_running_, threads_changed_cv_ and vcores_. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00172">query-resource-mgr.h:172</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a120ac55fc791fbea24db9e76444a8f77"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a120ac55fc791fbea24db9e76444a8f77">impala::QueryResourceMgr::~QueryResourceMgr</a></div><div class="ttdeci">~QueryResourceMgr()</div><div class="ttdoc">Waits for the VCore acquisition thread to stop. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00252">query-resource-mgr.cc:252</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_ab52333a16e143bce561d056f36f8a609"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#ab52333a16e143bce561d056f36f8a609">impala::QueryResourceMgr::query_id_</a></div><div class="ttdeci">TUniqueId query_id_</div><div class="ttdoc">Query ID of the query this class manages resources for. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00146">query-resource-mgr.h:146</a></div></div>
<div class="ttc" id="promise_8h_html"><div class="ttname"><a href="promise_8h.html">promise.h</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a1235cb65b3b55db534301daaeb138ebc"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a1235cb65b3b55db534301daaeb138ebc">impala::QueryResourceMgr::callback_count_</a></div><div class="ttdeci">int32_t callback_count_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00169">query-resource-mgr.h:169</a></div></div>
<div class="ttc" id="classuint64__t_html"><div class="ttname"><a href="classuint64__t.html">uint64_t</a></div></div>
<div class="ttc" id="resource-broker_8h_html"><div class="ttname"><a href="resource-broker_8h.html">resource-broker.h</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a5f57f77ffadbe9de80222dbee4e71602"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a5f57f77ffadbe9de80222dbee4e71602">impala::QueryResourceMgr::exit_</a></div><div class="ttdeci">bool exit_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00155">query-resource-mgr.h:155</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a519c6f01d964a8e3b2d46900bd665528"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a519c6f01d964a8e3b2d46900bd665528">impala::QueryResourceMgr::callbacks_</a></div><div class="ttdeci">CallbackMap callbacks_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00162">query-resource-mgr.h:162</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a03784ec11fcb18de5edfb28a481949ef"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a03784ec11fcb18de5edfb28a481949ef">impala::QueryResourceMgr::RemoveVcoreAvailableCb</a></div><div class="ttdeci">void RemoveVcoreAvailableCb(int32_t callback_id)</div><div class="ttdoc">Removes the callback with the given ID. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00154">query-resource-mgr.cc:154</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a1554ae6f6f3faee9bc82a82d59c7c305"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a1554ae6f6f3faee9bc82a82d59c7c305">impala::QueryResourceMgr::acquire_vcore_thread_</a></div><div class="ttdeci">boost::scoped_ptr&lt; Thread &gt; acquire_vcore_thread_</div><div class="ttdoc">Runs AcquireVcoreResources() after InitVcoreAcquisition() is called. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00189">query-resource-mgr.h:189</a></div></div>
<div class="ttc" id="classimpala_1_1ExecEnv_html_af75aeec37f5b3b5eb9b531453af0c553"><div class="ttname"><a href="classimpala_1_1ExecEnv.html#af75aeec37f5b3b5eb9b531453af0c553">impala::ExecEnv::GetInstance</a></div><div class="ttdeci">static ExecEnv * GetInstance()</div><div class="ttdef"><b>Definition:</b> <a href="exec-env_8h_source.html#l00063">exec-env.h:63</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_ad570e3ce975997e94bc5bc68fca7a76a"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#ad570e3ce975997e94bc5bc68fca7a76a">impala::QueryResourceMgr::AcquireVcoreResources</a></div><div class="ttdeci">void AcquireVcoreResources(boost::shared_ptr&lt; AtomicInt&lt; int16_t &gt; &gt; thread_in_expand, boost::shared_ptr&lt; AtomicInt&lt; int16_t &gt; &gt; early_exit)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00162">query-resource-mgr.cc:162</a></div></div>
<div class="ttc" id="network-util_8h_html"><div class="ttname"><a href="network-util_8h.html">network-util.h</a></div></div>
<div class="ttc" id="query-resource-mgr_8cc_html_a24bf3427d3423dc9acca2d2db1df1f6b"><div class="ttname"><a href="query-resource-mgr_8cc.html#a24bf3427d3423dc9acca2d2db1df1f6b">DEFAULT_EXPANSION_REQUEST_TIMEOUT_MS</a></div><div class="ttdeci">const int64_t DEFAULT_EXPANSION_REQUEST_TIMEOUT_MS</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00037">query-resource-mgr.cc:37</a></div></div>
<div class="ttc" id="container-util_8h_html"><div class="ttname"><a href="container-util_8h.html">container-util.h</a></div></div>
<div class="ttc" id="classimpala_1_1Status_html_a580565665ea944eb64f3f495b1bee1e0"><div class="ttname"><a href="classimpala_1_1Status.html#a580565665ea944eb64f3f495b1bee1e0">impala::Status::OK</a></div><div class="ttdeci">static const Status OK</div><div class="ttdef"><b>Definition:</b> <a href="status_8h_source.html#l00087">status.h:87</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a6fbd0b722ff0c7ac21a965fabcadebf0"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a6fbd0b722ff0c7ac21a965fabcadebf0">impala::QueryResourceMgr::NotifyThreadUsageChange</a></div><div class="ttdeci">void NotifyThreadUsageChange(int delta)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00140">query-resource-mgr.cc:140</a></div></div>
<div class="ttc" id="classimpala_1_1ResourceResolver_html"><div class="ttname"><a href="classimpala_1_1ResourceResolver.html">impala::ResourceResolver</a></div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00040">query-resource-mgr.h:40</a></div></div>
<div class="ttc" id="classimpala_1_1ResourceBroker_html_a4bdb13443a9e76bf23a2ff7635df179b"><div class="ttname"><a href="classimpala_1_1ResourceBroker.html#a4bdb13443a9e76bf23a2ff7635df179b">impala::ResourceBroker::Expand</a></div><div class="ttdeci">Status Expand(const TResourceBrokerExpansionRequest &amp;request, TResourceBrokerExpansionResponse *response)</div><div class="ttdef"><b>Definition:</b> <a href="resource-broker_8cc_source.html#l00503">resource-broker.cc:503</a></div></div>
<div class="ttc" id="names_8h_html"><div class="ttname"><a href="names_8h.html">names.h</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a6b75c55f1e81093a971665211c5d99ff"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a6b75c55f1e81093a971665211c5d99ff">impala::QueryResourceMgr::InitVcoreAcquisition</a></div><div class="ttdeci">void InitVcoreAcquisition(int32_t init_vcores)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00084">query-resource-mgr.cc:84</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a951a2b1bbb52218964c7209343b09e57"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a951a2b1bbb52218964c7209343b09e57">impala::QueryResourceMgr::early_exit_</a></div><div class="ttdeci">boost::shared_ptr&lt; AtomicInt&lt; int16_t &gt; &gt; early_exit_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00196">query-resource-mgr.h:196</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a88a5c03e7cf068424d7db0786384758e"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a88a5c03e7cf068424d7db0786384758e">impala::QueryResourceMgr::callbacks_lock_</a></div><div class="ttdeci">boost::mutex callbacks_lock_</div><div class="ttdoc">Protects callbacks_ and callbacks_it_. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00158">query-resource-mgr.h:158</a></div></div>
<div class="ttc" id="classimpala_1_1ExecEnv_html"><div class="ttname"><a href="classimpala_1_1ExecEnv.html">impala::ExecEnv</a></div><div class="ttdef"><b>Definition:</b> <a href="exec-env_8h_source.html#l00053">exec-env.h:53</a></div></div>
<div class="ttc" id="classimpala_1_1Status_html_a95ba859e42fe93445b340533220836ac"><div class="ttname"><a href="classimpala_1_1Status.html#a95ba859e42fe93445b340533220836ac">impala::Status::ok</a></div><div class="ttdeci">bool ok() const </div><div class="ttdef"><b>Definition:</b> <a href="status_8h_source.html#l00172">status.h:172</a></div></div>
<div class="ttc" id="classimpala_1_1ResourceBroker_html_a31c0aefde39c980a0ac942508c6e4ac8"><div class="ttname"><a href="classimpala_1_1ResourceBroker.html#a31c0aefde39c980a0ac942508c6e4ac8">impala::ResourceBroker::llama_nodes</a></div><div class="ttdeci">const std::vector&lt; std::string &gt; &amp; llama_nodes()</div><div class="ttdef"><b>Definition:</b> <a href="resource-broker_8h_source.html#l00091">resource-broker.h:91</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a174aae4b50f2577d6608a2d709658da1"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a174aae4b50f2577d6608a2d709658da1">impala::QueryResourceMgr::CreateExpansionRequest</a></div><div class="ttdeci">Status CreateExpansionRequest(int64_t memory_mb, int64_t vcores, TResourceBrokerExpansionRequest *request)</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00107">query-resource-mgr.cc:107</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a2826351b009db29e80a4452cca727c55"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a2826351b009db29e80a4452cca727c55">impala::QueryResourceMgr::max_vcore_oversubscription_ratio_</a></div><div class="ttdeci">float max_vcore_oversubscription_ratio_</div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8h_source.html#l00186">query-resource-mgr.h:186</a></div></div>
<div class="ttc" id="classimpala_1_1QueryResourceMgr_html_a5962e3717bf3f357e5c7073a3f2c3220"><div class="ttname"><a href="classimpala_1_1QueryResourceMgr.html#a5962e3717bf3f357e5c7073a3f2c3220">impala::QueryResourceMgr::ShouldExit</a></div><div class="ttdeci">bool ShouldExit()</div><div class="ttdoc">Notifies acquire_cpu_thread_ that it should terminate. Does not block. </div><div class="ttdef"><b>Definition:</b> <a href="query-resource-mgr_8cc_source.html#l00229">query-resource-mgr.cc:229</a></div></div>
<div class="ttc" id="exec-env_8h_html"><div class="ttname"><a href="exec-env_8h.html">exec-env.h</a></div></div>
</div><!-- fragment --></div><!-- contents -->
</div><!-- doc-content -->
<!-- start footer part -->
<div id="nav-path" class="navpath"><!-- id is needed for treeview function! -->
<ul>
<li class="navelem"><a class="el" href="dir_e5d120be6b5e8a44336cbfd013b25604.html">be</a></li><li class="navelem"><a class="el" href="dir_68cf7cafb51a962d5bc4848b83cab0de.html">src</a></li><li class="navelem"><a class="el" href="dir_aa61820f947c9a81fdd16b1964e72790.html">statestore</a></li><li class="navelem"><a class="el" href="query-resource-mgr_8cc.html">query-resource-mgr.cc</a></li>
<li class="footer">Generated on Thu May 7 2015 16:10:37 for Impala by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.8.6 </li>
</ul>
</div>
</body>
</html>