首页 > 代码库 > ansible 自动化(3)
ansible 自动化(3)
批量执行playbooks
远程批量命令执行的另外一种方式是用playbooks;
这里是playbooks的官方文档:http://docs.ansible.com/playbooks.html
这里有ansible的playbooks示例:https://github.com/ansible/ansible-examples
在python中使用ansbile API
以上执行ansible模块的方式都是在命令行中直接调用,如果对返回结果需要进一步处理,可以在程序中通过API调用的方式来使用ansible模块:
比如,以上在命令行中调用scripts的模块的方式在API中调用:
import ansible.runner
results = ansible.runner.Runner(
pattern=‘myservers‘, forks=5,
module_name=‘script‘, module_args=‘/opt/app/target.sh‘,
).run()
这里是官方给出的一个详细示例,直接运行一次,将result全部打印出来,会有直观的了解:
#!/usr/bin/python
import ansible.runner
import sys
# construct the ansible runner and execute on all hosts
results = ansible.runner.Runner(
pattern=‘*‘, forks=10,
module_name=‘command‘, module_args=‘/usr/bin/uptime‘,
).run()
if results is None:
print "No hosts found"
sys.exit(1)
print "UP ***********"
for (hostname, result) in results[‘contacted‘].items():
if not ‘failed‘ in result:
print "%s >>> %s" % (hostname, result[‘stdout‘])
print "FAILED *******"
for (hostname, result) in results[‘contacted‘].items():
if ‘failed‘ in result:
print "%s >>> %s" % (hostname, result[‘msg‘])
print "DOWN *********"
for (hostname, result) in results[‘dark‘].items():
print "%s >>> %s" % (hostname, result)
ansible 自动化(3)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。