设为首页 收藏本站
查看: 1613|回复: 0

[经验分享] ansible-playbook api 2.0 直接运行

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2018-1-2 17:24:49 | 显示全部楼层 |阅读模式
import json  

from collections import namedtuple  

from ansible.parsing.dataloader import DataLoader  

from ansible.vars import VariableManager  

from ansible.inventory import Inventory  

from ansible.playbook.play import Play  

from ansible.executor.task_queue_manager import TaskQueueManager  from ansible.executor.task_result import TaskResult
  

from ansible.plugins.callback import CallbackBase  

  

  

# 自定义 callback,即在运行 api 后调用本类中的 v2_runner_on_ok(),在这里会输出 host 和 result 格式  
class ResultCallback(CallbackBase):
  """A sample callback plugin used for performing an action as results come in
  

  If you want to collect all results into a single object for processing at
  the end of the execution, look into utilizing the ``json`` callback plugin
  or writing your own custom callback plugin
  """
  def v2_runner_on_ok(self, result, **kwargs):
  """Print a json representation of the result
  

  This method could store the result in an instance attribute for retrieval later
  """
  # result 包含'_check_key', '_host', '_result', '_task', 'is_changed', 'is_failed', 'is_skipped', 'is_unreachable'
  host = result._host
  print json.dumps({host.name: result._result}, indent=4)
  """
  def v2_on_any(self, *args, **kwargs):
  if isinstance(args[0], TaskResult):
  print json.dumps({args[0]._host.name: args[0]._result}, indent=4)
  """
  
Options = namedtuple('Options', ['connection', 'module_path', 'forks', 'become', 'become_method', 'become_user', 'check'])
  
# initialize needed objects
  
variable_manager = VariableManager()
  
loader = DataLoader()
  
options = Options(connection='smart', module_path=None, forks=100, become=None, become_method=None, become_user=None, check=False)
  
passwords = dict(conn_pass='mypassword')  # 目前只发现有两个key,conn_pass, become_pass
  

  
# Instantiate our ResultCallback for handling results as they come in
  
results_callback = ResultCallback()
  

  
# create inventory and pass to var manager
  
inventory = Inventory(loader=loader, variable_manager=variable_manager, host_list='hosts')
  # hosts文件,也可以是 ip列表 '10.1.162.18:322, 10.1.167.36' 或者 ['10.1.162.18:322', '10.1.167.36']
  
variable_manager.set_inventory(inventory)
  

  
# create play with tasks
  
play_source =  dict(
  name = "Ansible Play",
  hosts = 'web',   # 对应 playbook 入口yaml文件的 hosts变量,也可以是 ip 10.1.162.18
  gather_facts = 'no',
  tasks = [
  dict(action=dict(module='shell', args='ifconfig'), register='shell_out'),
  #dict(action=dict(module='debug', args=dict(msg='{{shell_out.stdout}}')))
  
         ]
  )
  
play = Play().load(play_source, variable_manager=variable_manager, loader=loader)
  

  
# actually run it
  
# TaskQueueManager 是创建进程池,负责输出结果和多进程间数据结构或者队列的共享协作
  
tqm = None
  
try:
  tqm = TaskQueueManager(
  inventory=inventory,
  variable_manager=variable_manager,
  loader=loader,
  options=options,
  passwords=passwords,
  stdout_callback=results_callback,  # Use our custom callback instead of the ``default`` callback plugin
  # 如果注释掉 callback 则会调用原生的 DEFAULT_STDOUT_CALLBACK,输出 task result的output,同 ansible-playbook debug
  
          )
  result = tqm.run(play)
  print result  # 返回码,只要有一个 host 出错就会返回 非0 数字
  
finally:
  if tqm is not None:
  tqm.cleanup()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-430879-1-1.html 上篇帖子: ansible-playbook 主机变量2 下篇帖子: ansible常用命令大全
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表