# -*- coding:utf8 -*-
'''
Created on 2017年1月13日 @author: qiancheng
''' import os
import json
from collections import namedtuple
from ansible.inventory import Inventory
from ansible.vars import VariableManager
from ansible.parsing.dataloader import DataLoader
from ansible.executor.playbook_executor import PlaybookExecutor
from ansible.plugins.callback import CallbackBase
from ansible.errors import AnsibleParserError class mycallback(CallbackBase):
#这里是状态回调,各种成功失败的状态,里面的各种方法其实都是从写于CallbackBase父类里面的,其实还有很多,可以根据需要拿出来用
def __init__(self,*args):
super(mycallback,self).__init__(display=None)
self.status_ok=json.dumps({})
self.status_fail=json.dumps({})
self.status_unreachable=json.dumps({})
self.status_playbook=''
self.status_no_hosts=False
self.host_ok = {}
self.host_failed={}
self.host_unreachable={}
def v2_runner_on_ok(self,result):
host=result._host.get_name()
self.runner_on_ok(host, result._result)
#self.status_ok=json.dumps({host:result._result},indent=4)
self.host_ok[host] = result
def v2_runner_on_failed(self, result, ignore_errors=False):
host = result._host.get_name()
self.runner_on_failed(host, result._result, ignore_errors)
#self.status_fail=json.dumps({host:result._result},indent=4)
self.host_failed[host] = result
def v2_runner_on_unreachable(self, result):
host = result._host.get_name()
self.runner_on_unreachable(host, result._result)
#self.status_unreachable=json.dumps({host:result._result},indent=4)
self.host_unreachable[host] = result
def v2_playbook_on_no_hosts_matched(self):
self.playbook_on_no_hosts_matched()
self.status_no_hosts=True
def v2_playbook_on_play_start(self, play):
self.playbook_on_play_start(play.name)
self.playbook_path=play.name class my_ansible_play():
#这里是ansible运行
#初始化各项参数,大部分都定义好,只有几个参数是必须要传入的
def __init__(self, playbook, extra_vars={},
host_list='/etc/ansible/hosts',
connection='ssh',
become=False,
become_user=None,
module_path=None,
fork=50,
ansible_cfg=None, #os.environ["ANSIBLE_CONFIG"] = None
passwords={},
check=False):
self.playbook_path=playbook
self.passwords=passwords
self.extra_vars=extra_vars
Options = namedtuple('Options',
['listtags', 'listtasks', 'listhosts', 'syntax', 'connection','module_path',
'forks', 'private_key_file', 'ssh_common_args', 'ssh_extra_args', 'sftp_extra_args',
'scp_extra_args', 'become', 'become_method', 'become_user', 'verbosity', 'check'])
self.options = Options(listtags=False, listtasks=False,
listhosts=False, syntax=False,
connection=connection, module_path=module_path,
forks=fork, private_key_file=None,
ssh_common_args=None, ssh_extra_args=None,
sftp_extra_args=None, scp_extra_args=None,
become=become, become_method=None,
become_user=become_user,
verbosity=None, check=check)
if ansible_cfg != None:
os.environ["ANSIBLE_CONFIG"] = ansible_cfg
self.variable_manager=VariableManager()
self.loader=DataLoader()
self.inventory=Inventory(loader=self.loader,variable_manager=self.variable_manager,host_list=host_list)
#定义运行的方法和返回值
def run(self):
complex_msg={}
if not os.path.exists(self.playbook_path):
code=1000
results={'playbook':self.playbook_path,'msg':self.playbook_path+' playbook is not exist','flag':False}
#results=self.playbook_path+'playbook is not existed'
#return code,complex_msg,results
pbex= PlaybookExecutor(playbooks=[self.playbook_path],
inventory=self.inventory,
variable_manager=self.variable_manager,
loader=self.loader,
options=self.options,
passwords=self.passwords)
self.results_callback=mycallback()
pbex._tqm._stdout_callback=self.results_callback
try:
code=pbex.run()
except AnsibleParserError:
code=1001
results={'playbook':self.playbook_path,'msg':self.playbook_path+' playbook have syntax error','flag':False}
#results='syntax error in '+self.playbook_path #语法错误
return code,results
if self.results_callback.status_no_hosts:
code=1002
results={'playbook':self.playbook_path,'msg':self.results_callback.status_no_hosts,'flag':False,'executed':False}
#results='no host match in '+self.playbook_path
return code,results
def get_result(self):
self.result_all={'success':{},'fail':{},'unreachable':{}}
#print result_all
#print dir(self.results_callback)
for host, result in self.results_callback.host_ok.items():
self.result_all['success'][host] = result._result for host, result in self.results_callback.host_failed.items():
self.result_all['failed'][host] = result._result['msg'] for host, result in self.results_callback.host_unreachable.items():
self.result_all['unreachable'][host]= result._result['msg'] for i in self.result_all['success'].keys():
print i,self.result_all['success'][i]
print self.result_all['fail']
print self.result_all['unreachable'] if __name__ =='__main__':
play_book=my_ansible_play('/etc/ansible/default_group/main.yml')
play_book.run()
play_book.get_result()
---
- hosts: all
remote_user: root
vars:
- user: devuser
- passwd: $1$0.XYbms/$YJjrhMEM.ld/bzCs20Fpv1
tasks:
- name: create user
user: name={{ user }} password={{ passwd }}
- name: ensure_yum_packages
yum: pkg={{ item }} state=latest
with_items:
- gcc-c++
- java
- ntpdate
- texinfo
- make
- gcc-c++
- net-tools
- lsof
ignore_errors: True
- name: update time
command: ntpdate time.windows.com
- include: /etc/ansible/check_system_version/main.yml
...

另附一段playbook。

这段代码就是调用palybook去执行,然后把执行的结果返回回来,能够用于自动化平台的开发,生成playbook后,按组执行,然后根据得到返回的数据来判断执行情况,总的来说就是输入playbook,返回结果。代码东拼西凑了来自ansible权威指南,一些gitlab,一些百度文章。感觉callback类里面东西还有很多,如果做自动化平台开发,还可以再深入研究。

python调用ansible api 2.0 运行playbook带callback返回的更多相关文章

  1. Python调用ansible API系列(三)带有callback的执行adhoc和playbook

    在第二篇文章中虽然可以执行adhoc和playbook但是执行结果的输出并不是特别直观,虽然没有报错但是到底什么结果其实你是不知道的尤其是在执行adhoc的时候,这时候我们要利用callback来设置 ...

  2. Python调用ansible API系列(五)综合使用

    如何把动态生成资产信息.执行playbook以及自定义结果结合起来用呢? #!/usr/bin/env python # -*- coding: utf-8 -*- """ ...

  3. Python调用ansible API系列(四)动态生成hosts文件

    方法一:通过最原始的操作文件的方式 #!/usr/bin/env python # -*- coding: utf-8 -*- """ 通过操作文件形式动态生成ansib ...

  4. Python调用ansible API系列(一)获取资产信息

    你想让ansible工作首先就需要设置资产信息,那么我们如何通过使用Python调取Ansible的API来获取资产信息呢? 要提前准备一个hosts文件 获取组或者主机 #!/usr/bin/env ...

  5. Python调用ansible API系列(二)执行adhoc和playbook

    执行adhoc #!/usr/bin/env python # -*- coding: utf-8 -*- import sys from collections import namedtuple ...

  6. 基于python调用libvirt API

    基于python调用libvirt API 1.程序代码 #!/usr/bin/python import libvirt import sys def createConnection(): con ...

  7. 关于python调用zabbix api接口

    因公司业务需要,引进了自动化运维,所用到的监控平台为zbbix3.2,最近正在学习python,计划使用python调用zabbix api接口去做些事情,如生成报表,我想最基本的是要取得zabbix ...

  8. Python调用win32 API绘制正弦波

    Python调用win32 API新建窗口与直接创建窗口的流程相同 流程:注册窗口→创建窗口→显示窗口→更新窗口→消息循环 代码: # -*- coding: utf-8 -*- import win ...

  9. 使用Python调用Flickr API抓取图片数据

    Flickr是雅虎旗下的图片分享网站,上面有全世界网友分享的大量精彩图片,被认为是专业的图片网站.其API也很友好,可以实现多种功能.这里我使用了Python调用其API获得了大量的照片数据.需要注意 ...

随机推荐

  1. WTIR Updating Page

    NO REPLY. ############### #14090704# ###############

  2. Linux--安装过程中的根文件系统的分析

    前言: 在这篇文章中S3C6410公版的Linux BSP和U-Boot为了分析,名词和数据文件的所有内容本文是基于环境为例,所有的代码是在设置的示例进行分析的过程中.哈. 假设有不对或者不完好的地方 ...

  3. [代码收藏]设为首页和加入收藏的JavaScript代码(兼容多浏览器)

    其实不少非IE内核浏览器都仍不支持通过代码将网页设为主页和加入收藏的功能,因此说是兼容,其实只是一个try,catch后的提醒而已. 加入收藏: /* * author : 2010-12-27 11 ...

  4. C#压缩字符串

    在论坛上看到一个压缩字符串的问题,特此记录以备后用! static string GetStringR(string inputStr) { return Regex.Replace(inputStr ...

  5. proxool的配置

    //依赖的包:commons-logging-api-1.1.jar,commons-logging-1.0.4.jar,proxool-0.9.1.jar,proxool-cglib.jar,cgl ...

  6. DDD(领域驱动设计)应对具体业务场景,Domain Model(领域模型)到底如何设计?

    DDD(领域驱动设计)应对具体业务场景,Domain Model(领域模型)到底如何设计? 写在前面 阅读目录: 迷雾森林 找回自我 开源地址 后记 毫无疑问,领域驱动设计的核心是领域模型,领域模型的 ...

  7. 微软 PowerShell Script Explorer

    微软 PowerShell Script Explorer 满血复活,正式发布 一年前的今天,微软在其Windows PowerShell官方博客声明中止 ‘Script Explorer’ 应用程序 ...

  8. MINIGUI 编译 helloworld

    MiniGui 编译hello.c 文件成功!记载一下! MiniGui 版本v3.0 和 2 编译 差异 是极其的大!   源文件代码 :   #include <stdio.h>#in ...

  9. Block formatting context

    不会JS中的OOP,你也太菜了吧!(第一篇)   一.你必须知道的 1) 字面量 2) 原型 3) 原型链 4) 构造函数 5) 稳妥对象(没有公共属性,而且其方法也不引用this的对象.稳妥对象适合 ...

  10. 从异步更新进度想起的事儿——IProgress

    今天,在群里向大家请教了这样一个问题:“两个对象(类.窗体或什么)之间,要完成比较频繁的报告进度更新都有哪些好的方式”,Somebody 跳出来给出了个“IProgress”,没了解过,后面围绕着它讨 ...