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

[经验分享] ansible 的callback插件自定义

[复制链接]

尚未签到

发表于 2018-1-2 18:45:05 | 显示全部楼层 |阅读模式
#coding=utf-8  
#author:evil
  

  
import os
  
import time
  
import json
  
import requests
  

  
Data_Fail_List=['UNREACHABLE','SKIPPED']
  

  

  
def log(host, category,task_id, data):
  
     if type(data) == dict:
  
         if 'verbose_override' in data:
  
             # avoid logging extraneous data from facts
  
             data = 'omitted'
  
         else:
  
             data = data.copy()
  
             invocation = data.pop('invocation', None)
  
             task_status='success'
  
             task_res=data['stdout']
  
             task_id=task_id
  
             task_host=host
  
             payload={'task_status':'success','task_res':task_res,'task_id':task_id,'task_host':task_host}
  
             requests.post("http://10.13.168.153:8000/task_callback/", data=payload)
  
     else:
  
         task_status='fail'
  
         task_res=data
  
         task_id=task_id
  
"log_plays.py" 118L, 3419C written
  
[iyunv@localhost callback_plugins]# cat log_plays.py
  
#coding=utf-8
  
#author:evil
  

  
import os
  
import time
  
import json
  
import requests
  

  
Data_Fail_List=['UNREACHABLE','SKIPPED']
  

  

  
def log(host, category,task_id, data):
  
     if type(data) == dict:
  
         if 'verbose_override' in data:
  
             # avoid logging extraneous data from facts
  
             data = 'omitted'
  
         else:
  
             data = data.copy()
  
             invocation = data.pop('invocation', None)
  
             task_status='success'
  
             task_res=data['stdout']
  
             task_id=task_id
  
             task_host=host
  
             payload={'task_status':'success','task_res':task_res,'task_id':task_id,'task_host':task_host}
  
             requests.post("http://10.13.168.153:8000/task_callback/", data=payload)
  
     else:
  
         task_status='fail'
  
         task_res=data
  
         task_id=task_id
  
         task_host=host
  
         payload={'task_status':'fail','task_res':data,'task_id':task_id,'task_host':task_host}
  
         requests.post("http://10.13.168.153:8000/task_callback/", data=payload)
  

  
         #path = os.path.join("/export/bjliumeide/log/ansible/hosts", host)
  
         #now = time.strftime(TIME_FORMAT, time.localtime())
  
         #fd = open(path, "a")
  
         #fd.write(MSG_FORMAT % dict(now=now, category=category,task_id=task_id, data=data))
  
         #fd.close()
  


  
>  
     """
  
     logs playbook results, per host, in /var/log/ansible/hosts
  
     """
  

  
     def on_any(self, *args, **kwargs):
  
         pass
  

  
     def runner_on_failed(self, host, res, ignore_errors=False):
  
         task_obj=getattr(self,'task',None)
  
         task_name=task_obj.name
  
         if task_obj:
  
             log(host, 'FAILED',task_name,res)
  

  
     def runner_on_ok(self, host, res):
  
         task_obj=getattr(self,'task',None)
  
         task_name=task_obj.name
  
         if task_obj:
  
             log(host, 'OK',task_name, res)
  
         else:
  
             pass
  
     def runner_on_skipped(self, host, item=None):
  
         task_obj=getattr(self,'task',None)
  
         task_name=task_obj.name
  
         if task_obj:
  
            log(host, 'SKIPPED',task_name,'...')
  
         else:
  
            pass
  
     def runner_on_unreachable(self, host, res):
  
         task_obj=getattr(self,'task',None)
  
         if task_obj:
  
             log(host,'UNREACHABLE',task_obj.name,res)
  
         else:
  
             pass
  
     def runner_on_no_hosts(self):
  
         pass
  

  
     def runner_on_async_poll(self, host, res, jid, clock):
  
         pass
  

  
     def runner_on_async_ok(self, host, res, jid):
  
         pass
  

  
     def runner_on_async_failed(self, host, res, jid):
  
         log(host, 'ASYNC_FAILED', res)
  

  
     def playbook_on_start(self):
  
         pass
  

  
     def playbook_on_notify(self, host, handler):
  
         pass
  

  
     def playbook_on_no_hosts_matched(self):
  
         pass
  

  
     def playbook_on_no_hosts_remaining(self):
  
         pass
  

  
     def playbook_on_task_start(self, name, is_conditional):
  
         pass
  

  
     def playbook_on_vars_prompt(self, varname, private=True, prompt=None, encrypt=None, confirm=False, salt_size=None, salt=None, default=None):
  
         pass
  

  
     def playbook_on_setup(self):
  
         pass
  

  
     def playbook_on_import_for_host(self, host, imported_file):
  
         log(host, 'IMPORTED', imported_file)
  

  
     def playbook_on_not_import_for_host(self, host, missing_file):
  
         log(host, 'NOTIMPORTED', missing_file)
  

  
     def playbook_on_play_start(self, name):
  
         pass
  

  
     def playbook_on_stats(self, stats):
  
         pass

运维网声明 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-430901-1-1.html 上篇帖子: 【Ansible 文档】【译文】模式 下篇帖子: ansible学习系列1-ansible简介
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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