327 lines
12 KiB
HTML
327 lines
12 KiB
HTML
|
|
||
|
|
||
|
<!DOCTYPE html>
|
||
|
<!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
|
||
|
<!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
|
||
|
<head>
|
||
|
<meta charset="utf-8">
|
||
|
|
||
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||
|
|
||
|
<title>22. Execution stages — cdist 4.7.0 documentation</title>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<link rel="stylesheet" href="_static/css/theme.css" type="text/css" />
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<link rel="index" title="Index"
|
||
|
href="genindex.html"/>
|
||
|
<link rel="search" title="Search" href="search.html"/>
|
||
|
<link rel="top" title="cdist 4.7.0 documentation" href="index.html"/>
|
||
|
<link rel="next" title="23. Remote exec and copy commands" href="cdist-remote-exec-copy.html"/>
|
||
|
<link rel="prev" title="21. Best practice" href="cdist-best-practice.html"/>
|
||
|
|
||
|
|
||
|
<script src="_static/js/modernizr.min.js"></script>
|
||
|
|
||
|
</head>
|
||
|
|
||
|
<body class="wy-body-for-nav" role="document">
|
||
|
|
||
|
|
||
|
<div class="wy-grid-for-nav">
|
||
|
|
||
|
|
||
|
<nav data-toggle="wy-nav-shift" class="wy-nav-side">
|
||
|
<div class="wy-side-scroll">
|
||
|
<div class="wy-side-nav-search">
|
||
|
|
||
|
|
||
|
|
||
|
<a href="index.html" class="icon icon-home"> cdist
|
||
|
|
||
|
|
||
|
|
||
|
</a>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<div class="version">
|
||
|
4.7.0
|
||
|
</div>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<div role="search">
|
||
|
<form id="rtd-search-form" class="wy-form" action="search.html" method="get">
|
||
|
<input type="text" name="q" placeholder="Search docs" />
|
||
|
<input type="hidden" name="check_keywords" value="yes" />
|
||
|
<input type="hidden" name="area" value="default" />
|
||
|
</form>
|
||
|
</div>
|
||
|
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<ul class="current">
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-intro.html">1. cdist - usable configuration management</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-why.html">2. Why should I use cdist?</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-os.html">3. Supported Operating Systems</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-install.html">4. How to install cdist</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-update.html">5. How to update cdist</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-support.html">6. Support</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-features.html">7. Features</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-quickstart.html">8. Quickstart</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="man1/cdist.html">9. cdist(1)</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-bootstrap.html">10. Bootstrap</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-configuration.html">11. Configuration</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-manifest.html">12. Manifest</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-type.html">13. cdist type</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-types.html">14. cdist types</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-explorer.html">15. Explorer</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-messaging.html">16. Messaging</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-parallelization.html">17. Parallelization</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-inventory.html">18. Inventory</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-integration.html">19. cdist integration / using cdist as library</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-reference.html">20. Reference</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-best-practice.html">21. Best practice</a></li>
|
||
|
<li class="toctree-l1 current"><a class="current reference internal" href="#">22. Execution stages</a><ul>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#description">22.1. Description</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-1-target-information-retrieval">22.2. Stage 1: target information retrieval</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-2-run-the-initial-manifest">22.3. Stage 2: run the initial manifest</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-3-object-information-retrieval">22.4. Stage 3: object information retrieval</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-4-run-the-object-manifest">22.5. Stage 4: run the object manifest</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-5-code-generation">22.6. Stage 5: code generation</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-6-code-execution">22.7. Stage 6: code execution</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#stage-7-cache">22.8. Stage 7: cache</a></li>
|
||
|
<li class="toctree-l2"><a class="reference internal" href="#summary">22.9. Summary</a></li>
|
||
|
</ul>
|
||
|
</li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-remote-exec-copy.html">23. Remote exec and copy commands</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-hacker.html">24. Hacking</a></li>
|
||
|
<li class="toctree-l1"><a class="reference internal" href="cdist-troubleshooting.html">25. Troubleshooting</a></li>
|
||
|
</ul>
|
||
|
|
||
|
|
||
|
|
||
|
</div>
|
||
|
</div>
|
||
|
</nav>
|
||
|
|
||
|
<section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
|
||
|
|
||
|
|
||
|
<nav class="wy-nav-top" role="navigation" aria-label="top navigation">
|
||
|
|
||
|
<i data-toggle="wy-nav-top" class="fa fa-bars"></i>
|
||
|
<a href="index.html">cdist</a>
|
||
|
|
||
|
</nav>
|
||
|
|
||
|
|
||
|
|
||
|
<div class="wy-nav-content">
|
||
|
<div class="rst-content">
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<div role="navigation" aria-label="breadcrumbs navigation">
|
||
|
|
||
|
<ul class="wy-breadcrumbs">
|
||
|
|
||
|
<li><a href="index.html">Docs</a> »</li>
|
||
|
|
||
|
<li>22. Execution stages</li>
|
||
|
|
||
|
|
||
|
<li class="wy-breadcrumbs-aside">
|
||
|
|
||
|
|
||
|
<a href="_sources/cdist-stages.rst.txt" rel="nofollow"> View page source</a>
|
||
|
|
||
|
|
||
|
</li>
|
||
|
|
||
|
</ul>
|
||
|
|
||
|
|
||
|
<hr/>
|
||
|
</div>
|
||
|
<div role="main" class="document" itemscope="itemscope" itemtype="http://schema.org/Article">
|
||
|
<div itemprop="articleBody">
|
||
|
|
||
|
<div class="section" id="execution-stages">
|
||
|
<h1>22. Execution stages<a class="headerlink" href="#execution-stages" title="Permalink to this headline">¶</a></h1>
|
||
|
<div class="section" id="description">
|
||
|
<h2>22.1. Description<a class="headerlink" href="#description" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>When cdist is started, it passes through different stages.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-1-target-information-retrieval">
|
||
|
<h2>22.2. Stage 1: target information retrieval<a class="headerlink" href="#stage-1-target-information-retrieval" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>In this stage information is collected about the target host using so called
|
||
|
explorers. Every existing explorer is run on the target and the output of all
|
||
|
explorers are copied back into the local cache. The results can be used by
|
||
|
manifests and types.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-2-run-the-initial-manifest">
|
||
|
<h2>22.3. Stage 2: run the initial manifest<a class="headerlink" href="#stage-2-run-the-initial-manifest" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>The initial manifest, which should be used for mappings of hosts to types,
|
||
|
is executed. This stage creates objects in a cconfig database that contains
|
||
|
the objects as defined in the manifest for the specific host. In this stage,
|
||
|
no conflicts may occur, i.e. no object of the same type with the same id may
|
||
|
be created, if it has different parameters.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-3-object-information-retrieval">
|
||
|
<h2>22.4. Stage 3: object information retrieval<a class="headerlink" href="#stage-3-object-information-retrieval" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>Every object is checked whether its type has explorers and if so, these are
|
||
|
executed on the target host. The results are transferred back
|
||
|
and can be used in the following stages to decide what changes need to be made
|
||
|
on the target to implement the desired state.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-4-run-the-object-manifest">
|
||
|
<h2>22.5. Stage 4: run the object manifest<a class="headerlink" href="#stage-4-run-the-object-manifest" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>Every object is checked whether its type has a executable manifest. The
|
||
|
manifest script may generate and change the created objects. In other words,
|
||
|
one type can reuse other types.</p>
|
||
|
<p>For instance the object __apache/www.example.org is of type __apache, which may
|
||
|
contain a manifest script, which creates new objects of type __file.</p>
|
||
|
<p>The newly created objects are merged back into the existing tree. No conflicts
|
||
|
may occur during the merge. A conflict would mean that two different objects
|
||
|
try to create the same object, which indicates a broken configuration.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-5-code-generation">
|
||
|
<h2>22.6. Stage 5: code generation<a class="headerlink" href="#stage-5-code-generation" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>In this stage for every created object its type is checked for executable
|
||
|
gencode scripts. The gencode scripts generate the code to be executed on the
|
||
|
target on stdout. If the gencode executables fail, they must print diagnostic
|
||
|
messages on stderr and exit non-zero.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-6-code-execution">
|
||
|
<h2>22.7. Stage 6: code execution<a class="headerlink" href="#stage-6-code-execution" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>For every object the resulting code from the previous stage is transferred to
|
||
|
the target host and executed there to apply the configuration changes.</p>
|
||
|
</div>
|
||
|
<div class="section" id="stage-7-cache">
|
||
|
<h2>22.8. Stage 7: cache<a class="headerlink" href="#stage-7-cache" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>The cache stores the information from the current run for later use.</p>
|
||
|
</div>
|
||
|
<div class="section" id="summary">
|
||
|
<h2>22.9. Summary<a class="headerlink" href="#summary" title="Permalink to this headline">¶</a></h2>
|
||
|
<p>If, and only if, all the stages complete without errors, the configuration
|
||
|
will be applied to the target.</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
|
||
|
</div>
|
||
|
<div class="articleComments">
|
||
|
|
||
|
</div>
|
||
|
</div>
|
||
|
<footer>
|
||
|
|
||
|
<div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
|
||
|
|
||
|
<a href="cdist-remote-exec-copy.html" class="btn btn-neutral float-right" title="23. Remote exec and copy commands" accesskey="n" rel="next">Next <span class="fa fa-arrow-circle-right"></span></a>
|
||
|
|
||
|
|
||
|
<a href="cdist-best-practice.html" class="btn btn-neutral" title="21. Best practice" accesskey="p" rel="prev"><span class="fa fa-arrow-circle-left"></span> Previous</a>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
|
||
|
<hr/>
|
||
|
|
||
|
<div role="contentinfo">
|
||
|
<p>
|
||
|
© Copyright .
|
||
|
|
||
|
</p>
|
||
|
</div>
|
||
|
Built with <a href="http://sphinx-doc.org/">Sphinx</a> using a <a href="https://github.com/snide/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
|
||
|
|
||
|
</footer>
|
||
|
|
||
|
</div>
|
||
|
</div>
|
||
|
|
||
|
</section>
|
||
|
|
||
|
</div>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<script type="text/javascript">
|
||
|
var DOCUMENTATION_OPTIONS = {
|
||
|
URL_ROOT:'./',
|
||
|
VERSION:'4.7.0',
|
||
|
COLLAPSE_INDEX:false,
|
||
|
FILE_SUFFIX:'.html',
|
||
|
HAS_SOURCE: true,
|
||
|
SOURCELINK_SUFFIX: '.txt'
|
||
|
};
|
||
|
</script>
|
||
|
<script type="text/javascript" src="_static/jquery.js"></script>
|
||
|
<script type="text/javascript" src="_static/underscore.js"></script>
|
||
|
<script type="text/javascript" src="_static/doctools.js"></script>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<script type="text/javascript" src="_static/js/theme.js"></script>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<script type="text/javascript">
|
||
|
jQuery(function () {
|
||
|
SphinxRtdTheme.StickyNav.enable();
|
||
|
});
|
||
|
</script>
|
||
|
|
||
|
|
||
|
</body>
|
||
|
</html>
|