2012-03-07 17:35:18 +01:00
< !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/html; charset=utf-8" / >
2012-03-13 00:13:19 +01:00
< title > Using the Python API — Ansible - SSH-Based Configuration Management & Deployment< / title >
2012-03-07 17:35:18 +01:00
< link rel = "stylesheet" href = "_static/default.css" type = "text/css" / >
< link rel = "stylesheet" href = "_static/pygments.css" type = "text/css" / >
2012-03-09 17:44:14 +01:00
< link rel = "stylesheet" href = "_static/bootstrap.css" type = "text/css" / >
< link rel = "stylesheet" href = "_static/bootstrap-sphinx.css" type = "text/css" / >
2012-03-07 17:35:18 +01:00
< script type = "text/javascript" >
var DOCUMENTATION_OPTIONS = {
URL_ROOT: '',
2012-03-13 00:13:19 +01:00
VERSION: '0.01',
2012-03-07 17:35:18 +01:00
COLLAPSE_INDEX: false,
FILE_SUFFIX: '.html',
2012-03-09 17:50:07 +01:00
HAS_SOURCE: false
2012-03-07 17:35:18 +01:00
};
< / 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 >
2012-03-09 17:44:14 +01:00
< script type = "text/javascript" src = "_static/bootstrap-dropdown.js" > < / script >
< script type = "text/javascript" src = "_static/bootstrap-scrollspy.js" > < / script >
2012-03-13 00:13:19 +01:00
< link rel = "top" title = "Ansible - SSH-Based Configuration Management & Deployment" href = "index.html" / >
2012-03-14 17:50:40 +01:00
< link rel = "next" title = "Module Development Guide" href = "moduledev.html" / >
2012-03-09 17:44:14 +01:00
< link rel = "prev" title = "Playbooks" href = "playbooks.html" / >
< script type = "text/javascript" >
(function () {
/**
* Patch TOC list.
*
* Will mutate the underlying span to have a correct ul for nav.
*
* @param $span: Span containing nested UL's to mutate.
* @param minLevel: Starting level for nested lists. (1: global, 2: local).
*/
var patchToc = function ($span, minLevel) {
var $tocList = $("< ul / > ").attr('class', "dropdown-menu"),
findA;
// Find all a "internal" tags, traversing recursively.
findA = function ($elem, level) {
var level = level || 0,
$items = $elem.find("> li > a.internal, > ul, > li > ul");
// Iterate everything in order.
$items.each(function (index, item) {
var $item = $(item),
tag = item.tagName.toLowerCase(),
pad = 10 + ((level - minLevel) * 10);
if (tag === 'a' & & level >= minLevel) {
// Add to existing padding.
$item.css('padding-left', pad + "px");
// Add list element.
$tocList.append($("< li / > ").append($item));
} else if (tag === 'ul') {
// Recurse.
findA($item, level + 1);
}
});
};
// Start construction and return.
findA($span);
// Wipe out old list and patch in new one.
return $span.empty("ul").append($tocList);
};
$(document).ready(function () {
// Patch the global and local TOC's to be bootstrap-compliant.
patchToc($("span.globaltoc"), 1);
patchToc($("span.localtoc"), 2);
// Activate.
$('#topbar').dropdown();
});
}());
2012-03-10 04:31:54 +01:00
< / script >
< script type = "text/javascript" >
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-29861888-1']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type =
'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' :
'http://www') + '.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(ga, s);
})();
2012-03-09 17:44:14 +01:00
< / script >
2012-03-07 17:35:18 +01:00
< / head >
< body >
2012-03-09 17:44:14 +01:00
< div class = "topbar" data-scrollspy = "scrollspy" >
< div class = "topbar-inner" >
< div class = "container" >
< a class = "brand" href = "index.html" > Ansible< / a >
< ul class = "nav" >
< li class = "dropdown" data-dropdown = "dropdown" >
< a href = "index.html"
class="dropdown-toggle">Site< / a >
< span class = "globaltoc" > < ul class = "current" >
2012-03-10 03:50:00 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "gettingstarted.html" > Downloads & Getting Started< / a > < / li >
2012-03-09 17:44:14 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "patterns.html" > The Inventory File, Patterns, and Groups< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "examples.html" > Command Line Examples< / a > < / li >
< li class = "toctree-l1" > < a class = "reference internal" href = "modules.html" > Ansible Modules< / a > < / li >
2012-03-11 20:34:21 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "YAMLSyntax.html" > YAML Syntax< / a > < / li >
2012-03-09 17:44:14 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "playbooks.html" > Playbooks< / a > < / li >
< li class = "toctree-l1 current" > < a class = "current reference internal" href = "" > Using the Python API< / a > < / li >
2012-03-14 17:50:40 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "moduledev.html" > Module Development Guide< / a > < / li >
2012-03-10 03:50:00 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "faq.html" > Frequently Asked Questions< / a > < / li >
2012-03-09 17:44:14 +01:00
< li class = "toctree-l1" > < a class = "reference internal" href = "man.html" > Man Pages< / a > < / li >
< / ul >
< / span >
< / li >
< li class = "dropdown" data-dropdown = "dropdown" >
< a href = "#"
class="dropdown-toggle">Page< / a >
< span class = "localtoc" > < ul >
< li > < a class = "reference internal" href = "#" > Using the Python API< / a > < ul >
< li > < a class = "reference internal" href = "#detailed-api-example" > Detailed API Example< / a > < / li >
< / ul >
< / li >
< / ul >
< / span >
< / li >
< li > < a href = "playbooks.html"
title="previous chapter">« Playbooks< / a > < / li >
2012-03-14 17:50:40 +01:00
< li > < a href = "moduledev.html"
title="next chapter">Module Development Guide » < / a > < / li >
2012-03-09 17:44:14 +01:00
2012-03-07 17:35:18 +01:00
2012-03-09 17:44:14 +01:00
< / ul >
< ul class = "nav secondary-nav" >
< form class = "pull-left" action = "search.html" method = "get" >
< input type = "text" name = "q" placeholder = "Search" / >
< input type = "hidden" name = "check_keywords" value = "yes" / >
< input type = "hidden" name = "area" value = "default" / >
< / form >
< / ul >
< / div >
< / div >
< / div >
2012-03-10 16:39:34 +01:00
< a href = "https://github.com/ansible/ansible" > < img
style="position: absolute; top: 40px; right: 0; border: 0;"
src="https://a248.e.akamai.net/assets.github.com/img/71eeaab9d563c2b3c590319b398dd35683265e85/687474703a2f2f73332e616d617a6f6e6177732e636f6d2f6769746875622f726962626f6e732f666f726b6d655f72696768745f677261795f3664366436642e706e67"
alt="Fork me on GitHub"
alt="Fork me on GitHub">< / a >
2012-03-09 17:44:14 +01:00
< div class = "container" >
2012-03-09 13:42:53 +01:00
< div class = "section" id = "using-the-python-api" >
< h1 > Using the Python API< a class = "headerlink" href = "#using-the-python-api" title = "Permalink to this headline" > ¶< / a > < / h1 >
2012-03-08 19:36:47 +01:00
< p > The Python API is very powerful, and is how the ansible CLI and ansible-playbook
are implemented.< / p >
< p > It’ s pretty simple:< / p >
< div class = "highlight-python" > < div class = "highlight" > < pre > < span class = "kn" > import< / span > < span class = "nn" > ansible.runner< / span >
< span class = "n" > runner< / span > < span class = "o" > =< / span > < span class = "n" > ansible< / span > < span class = "o" > .< / span > < span class = "n" > runner< / span > < span class = "o" > .< / span > < span class = "n" > Runner< / span > < span class = "p" > (< / span >
< span class = "n" > module_name< / span > < span class = "o" > =< / span > < span class = "s" > ' ping' < / span > < span class = "p" > ,< / span >
< span class = "n" > module_args< / span > < span class = "o" > =< / span > < span class = "s" > ' ' < / span > < span class = "p" > ,< / span >
< span class = "n" > pattern< / span > < span class = "o" > =< / span > < span class = "s" > ' web*' < / span > < span class = "p" > ,< / span >
< span class = "n" > forks< / span > < span class = "o" > =< / span > < span class = "mi" > 10< / span >
< span class = "p" > )< / span >
< span class = "n" > datastructure< / span > < span class = "o" > =< / span > < span class = "n" > runner< / span > < span class = "o" > .< / span > < span class = "n" > run< / span > < span class = "p" > ()< / span >
< / pre > < / div >
< / div >
< p > The run method returns results per host, grouped by whether they
could be contacted or not. Return types are module specific, as
expressed in the ‘ ansible-modules’ documentation.:< / p >
< div class = "highlight-python" > < pre > {
"dark" : {
"web1.example.com" : "failure message"
}
"contacted" : {
"web2.example.com" : 1
}
}< / pre >
< / div >
< p > A module can return any type of JSON data it wants, so Ansible can
be used as a framework to rapidly build powerful applications and scripts.< / p >
2012-03-09 13:42:53 +01:00
< div class = "section" id = "detailed-api-example" >
< h2 > Detailed API Example< a class = "headerlink" href = "#detailed-api-example" title = "Permalink to this headline" > ¶< / a > < / h2 >
< p > The following script prints out the uptime information for all hosts:< / p >
< div class = "highlight-python" > < div class = "highlight" > < pre > < span class = "c" > #!/usr/bin/python< / span >
< span class = "kn" > import< / span > < span class = "nn" > ansible.runner< / span >
< span class = "kn" > import< / span > < span class = "nn" > sys< / span >
< span class = "c" > # construct the ansible runner and execute on all hosts< / span >
< span class = "n" > results< / span > < span class = "o" > =< / span > < span class = "n" > ansible< / span > < span class = "o" > .< / span > < span class = "n" > runner< / span > < span class = "o" > .< / span > < span class = "n" > Runner< / span > < span class = "p" > (< / span >
< span class = "n" > pattern< / span > < span class = "o" > =< / span > < span class = "s" > ' *' < / span > < span class = "p" > ,< / span > < span class = "n" > forks< / span > < span class = "o" > =< / span > < span class = "mi" > 10< / span > < span class = "p" > ,< / span >
< span class = "n" > module_name< / span > < span class = "o" > =< / span > < span class = "s" > ' command' < / span > < span class = "p" > ,< / span > < span class = "n" > module_args< / span > < span class = "o" > =< / span > < span class = "p" > [< / span > < span class = "s" > ' /usr/bin/uptime' < / span > < span class = "p" > ],< / span >
< span class = "p" > )< / span > < span class = "o" > .< / span > < span class = "n" > run< / span > < span class = "p" > ()< / span >
< span class = "k" > if< / span > < span class = "n" > results< / span > < span class = "ow" > is< / span > < span class = "bp" > None< / span > < span class = "p" > :< / span >
< span class = "k" > print< / span > < span class = "s" > " No hosts found" < / span >
< span class = "n" > sys< / span > < span class = "o" > .< / span > < span class = "n" > exit< / span > < span class = "p" > (< / span > < span class = "mi" > 1< / span > < span class = "p" > )< / span >
< span class = "k" > print< / span > < span class = "s" > " UP ***********" < / span >
< span class = "k" > for< / span > < span class = "p" > (< / span > < span class = "n" > hostname< / span > < span class = "p" > ,< / span > < span class = "n" > result< / span > < span class = "p" > )< / span > < span class = "ow" > in< / span > < span class = "n" > results< / span > < span class = "p" > [< / span > < span class = "s" > ' contacted' < / span > < span class = "p" > ]< / span > < span class = "o" > .< / span > < span class = "n" > items< / span > < span class = "p" > ():< / span >
< span class = "k" > if< / span > < span class = "ow" > not< / span > < span class = "s" > ' failed' < / span > < span class = "ow" > in< / span > < span class = "n" > result< / span > < span class = "p" > :< / span >
< span class = "k" > print< / span > < span class = "s" > " < / span > < span class = "si" > %s< / span > < span class = "s" > > > > < / span > < span class = "si" > %s< / span > < span class = "s" > " < / span > < span class = "o" > %< / span > < span class = "p" > (< / span > < span class = "n" > hostname< / span > < span class = "p" > ,< / span > < span class = "n" > result< / span > < span class = "p" > [< / span > < span class = "s" > ' stdout' < / span > < span class = "p" > ])< / span >
< span class = "k" > print< / span > < span class = "s" > " FAILED *******" < / span >
< span class = "k" > for< / span > < span class = "p" > (< / span > < span class = "n" > hostname< / span > < span class = "p" > ,< / span > < span class = "n" > result< / span > < span class = "p" > )< / span > < span class = "ow" > in< / span > < span class = "n" > results< / span > < span class = "p" > [< / span > < span class = "s" > ' contacted' < / span > < span class = "p" > ]< / span > < span class = "o" > .< / span > < span class = "n" > items< / span > < span class = "p" > ():< / span >
< span class = "k" > if< / span > < span class = "s" > ' failed' < / span > < span class = "ow" > in< / span > < span class = "n" > result< / span > < span class = "p" > :< / span >
< span class = "k" > print< / span > < span class = "s" > " < / span > < span class = "si" > %s< / span > < span class = "s" > > > > < / span > < span class = "si" > %s< / span > < span class = "s" > " < / span > < span class = "o" > %< / span > < span class = "p" > (< / span > < span class = "n" > hostname< / span > < span class = "p" > ,< / span > < span class = "n" > result< / span > < span class = "p" > [< / span > < span class = "s" > ' msg' < / span > < span class = "p" > ])< / span >
< span class = "k" > print< / span > < span class = "s" > " DOWN *********" < / span >
< span class = "k" > for< / span > < span class = "p" > (< / span > < span class = "n" > hostname< / span > < span class = "p" > ,< / span > < span class = "n" > result< / span > < span class = "p" > )< / span > < span class = "ow" > in< / span > < span class = "n" > results< / span > < span class = "p" > [< / span > < span class = "s" > ' dark' < / span > < span class = "p" > ]< / span > < span class = "o" > .< / span > < span class = "n" > items< / span > < span class = "p" > ():< / span >
< span class = "k" > print< / span > < span class = "s" > " < / span > < span class = "si" > %s< / span > < span class = "s" > > > > < / span > < span class = "si" > %s< / span > < span class = "s" > " < / span > < span class = "o" > %< / span > < span class = "p" > (< / span > < span class = "n" > hostname< / span > < span class = "p" > ,< / span > < span class = "n" > result< / span > < span class = "p" > )< / span >
< / pre > < / div >
< / div >
< p > Advanced programmers may also wish to read the source to ansible itself, for
it uses the Runner() API (with all available options) to implement the
command line tools < tt class = "docutils literal" > < span class = "pre" > ansible< / span > < / tt > and < tt class = "docutils literal" > < span class = "pre" > ansible-playbook< / span > < / tt > .< / p >
< / div >
2012-03-07 17:35:18 +01:00
< / div >
< / div >
2012-03-09 17:44:14 +01:00
< footer class = "footer" >
< div class = "container" >
< p class = "pull-right" > < a href = "#" > Back to top< / a > < / p >
< p >
© Copyright 2012 Michael DeHaan.< br / >
2012-03-15 01:57:35 +01:00
Last updated on Mar 14, 2012.< br / >
2012-03-10 00:29:01 +01:00
Created using < a href = "http://sphinx.pocoo.org/" > Sphinx< / a > 1.0.8.< br / >
2012-03-09 17:44:14 +01:00
< / p >
< / div >
< / footer >
2012-03-07 17:35:18 +01:00
< / body >
< / html >