您的位置:首页 > 编程语言 > Python开发

python调用ansible接口API执行命令

2018-03-01 13:21 633 查看
python版本:Python 2.6.6

ansible版本:ansible 2.3.1.0

调用脚本: task_exec_v1.py

#!/usr/bin/env python
#coding:utf-8

import os
import sys
import json
import logging
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
from optparse import OptionParser

#定义打印日志
logging.basicConfig(filename='task_exec_v3.log',               #通过logging.basicConfig函数对日志的输出格式及方式做相关配置
format='%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s',datefmt='%Y-%m-%d %H:%M:%S %p',
level=10)

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'])
logging.info(Options)
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)
logging.info(self.options)
if ansible_cfg != None:
os.environ["ANSIBLE_CONFIG"] = ansible_cfg
self.variable_manager=VariableManager()
self.variable_manager.extra_vars=self.extra_vars
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}
logging.info(results)
#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}
return code,results
def get_result(self):
self.result_all={'success':{},'fail':{},'unreachable':{}}
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():
if result._result.has_key("msg"):
self.result_all['fail'][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/playbooks/test_ping.yml')
logging.info(play_book)
play_book.run()
play_book.get_result()


附playbook脚本:test_ping.yml

---
- hosts: test
gather_facts: False
tasks:

- name: test ping
ping:
- name: shell commond
shell: echo "hello world"
register: result
- name: show debug info
debug: var=result.stdout verbosity=0


python3.5调用ansible参考文档:

              https://www.cnblogs.com/stones/p/8252731.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: