文档章节

ansible api简单应用

eddy_linux
 eddy_linux
发布于 2015/11/23 22:21
字数 716
阅读 192
收藏 1
点赞 0
评论 0
1.uptime
#!/usr/bin/python
#encoding:utf-8
import ansible.runner
import sys

# construct the ansible runner and execute on all hosts
results = ansible.runner.Runner(
          pattern='client', forks=10,
          module_name='command',
          module_args='/usr/bin/uptime',
          ).run()

if results is None:
   print "No hosts found"
   sys.exit(1)

for (hostname, result) in results['contacted'].items():
        if not 'failed' in result:
                print "UP ***********"
                print "%s >>> %s" % (hostname, result['stdout'])

for (hostname, result) in results['contacted'].items():
        if 'failed' in result:
                print "FAILED *******"
                print "%s >>> %s" % (hostname, result['msg'])

for (hostname, result) in results['dark'].items():
        print "DOWN *********"
        print "%s >>> %s" % (hostname, result)
UP ***********
client1.info.com >>>  21:54:00 up 10 min,  1 user,  load average: 0.02, 0.14, 0.15
UP ***********
puppetmaster.info.com >>>  21:54:00 up 11 min,  1 user,  load average: 0.30, 1.56, 1.41

2.ping
#!/usr/bin/python
#encoding:utf-8
import ansible.runner
import sys

# construct the ansible runner and execute on all hosts
results = ansible.runner.Runner(
          pattern='client', forks=10,
          module_name='ping',
          #module_args='ping',
          ).run()

if results is None:
   print "No hosts found"
   sys.exit(1)

for (hostname, result) in results['contacted'].items():
     if not 'failed' in result:
             print "%s >>>ping:%s" % (hostname, result['ping'])
for (hostname, result) in results['dark'].items():
     if  'failed' in result:
             print "%s >>>ping:%s" % (hostname, result['msg'])
client1.info.com >>>ping:pong
puppetmaster.info.com >>>ping:pong

3.command
#!/usr/bin/python
#encoding:utf-8
import ansible.runner
import sys

command = sys.argv[1]
results = ansible.runner.Runner(
          pattern='client', forks=10,
          module_name='shell',
          module_args=command,
          ).run()

if results is None:
   print "No hosts found"
   sys.exit(1)

for (hostname, result) in results['contacted'].items():
        if not 'failed' in result:
                print "UP ***********"
                print "%s" % (hostname)
                print "%s" %(result['stdout'])
                print ''

for (hostname, result) in results['contacted'].items():
        if 'failed' in result:
                print "FAILED *******"
                print "%s >>> %s" % (hostname, result['msg'])
                print ''
for (hostname, result) in results['dark'].items():
        print "DOWN *********"
        print "%s >>> %s" % (hostname, result)
        print '' 
UP ***********
client1.info.com
2015-11-23-21:56:12

UP ***********
puppetmaster.info.com
2015-11-23-21:56:11


4.install ftp(yum)
#!/usr/bin/python
#encoding:utf-8
import ansible.runner
import sys
def check_ftp():
    check_ftp = ansible.runner.Runner(
              pattern='client', forks=10,
              module_name='shell',
              module_args='rpm -q vsftpd',
              ).run()
    if check_ftp is None:
       print "No hosts found"
       sys.exit(1)
    for (hostname, result) in check_ftp['contacted'].items():
            if not 'failed' in result:
                print "%s" % (hostname)
                print "%s" %(result['stdout'])
    		print ''
                return 1
    for (hostname, result) in check_ftp['contacted'].items():
            if 'failed' in result:
                print "%s >>> %s" % (hostname, result['msg'])
    		print ''
    for (hostname, result) in check_ftp['dark'].items():
        print "%s >>> %s" % (hostname, result)
        print ''
def install():
    install_ftp = ansible.runner.Runner(
              pattern='client', forks=10,
              module_name='yum',
              module_args='name=vsftpd state=latest',
              ).run()
    if check_ftp is None:
       print "No hosts found"
       sys.exit(1)
    for (hostname, result) in install_ftp['contacted'].items():
            if not 'failed' in result:
                print "%s" % (hostname)
                for v in result['results']:
                    print v
                return 1
    for (hostname, result) in install_ftp['contacted'].items():
            if 'failed' in result:
                print "%s >>> %s" % (hostname, result['msg'])
                print ''
    for (hostname, result) in install_ftp['dark'].items():
        print "%s >>> %s" % (hostname, result)
        print ''
def start():
    start_ftp = ansible.runner.Runner(
              pattern='client', forks=10,
              module_name='shell',
              module_args='/etc/init.d/vsftpd start',
              ).run()
    if start_ftp is None:
       print "No hosts found"
       sys.exit(1)
    for (hostname, result) in start_ftp['contacted'].items():
            if not 'failed' in result:
                print "%s" % (hostname)
                print "%s" %(result['stdout'])
                print ''
                return 1
    for (hostname, result) in start_ftp['contacted'].items():
            if 'failed' in result:
                print "%s >>> %s" % (hostname, result['msg'])
                print ''
    for (hostname, result) in start_ftp['dark'].items():
        print "%s >>> %s" % (hostname, result)
        print ''
if __name__ == '__main__':
    check_ftp()
    install()
    start()


client1.info.com
package vsftpd is not installed

client1.info.com
Loaded plugins: product-id, subscription-manager
Updating certificate-based repositories.
Setting up Install Process
Resolving Dependencies
--> Running transaction check
---> Package vsftpd.x86_64 0:2.2.2-11.el6 will be installed
--> Finished Dependency Resolution

Dependencies Resolved

================================================================================
 Package         Arch            Version                Repository         Size
================================================================================
Installing:
 vsftpd          x86_64          2.2.2-11.el6           rhel-iso          151 k

Transaction Summary
================================================================================
Install       1 Package(s)

Total download size: 151 k
Installed size: 331 k
Downloading Packages:
Running rpm_check_debug
Running Transaction Test
Transaction Test Succeeded
Running Transaction
  Installing : vsftpd-2.2.2-11.el6.x86_64                                   1/1 
Installed products updated.
  Verifying  : vsftpd-2.2.2-11.el6.x86_64                                   1/1 

Installed:
  vsftpd.x86_64 0:2.2.2-11.el6                                                  

Complete!

client1.info.com
All packages providing vsftpd are up to date
client1.info.com
Starting vsftpd for vsftpd: [  OK  ]












© 著作权归作者所有

共有 人打赏支持
eddy_linux
粉丝 18
博文 135
码字总数 188789
作品 0
成都
程序员
为什么Ansible在自动化编排成为王者!

Ansible是一个广泛应用的自动化平台,在devops和自动化方面具有特别的优势。 如果有“改进的IT编排和配置管理工具最多”的奖项,红帽的Ansible将成为最具竞争力的竞争者。自2012年由Michael...

云技术实践 ⋅ 05/09 ⋅ 0

企业级自动化运维工具应用实战-ansible

一:ansible的简介ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。a...

931015 ⋅ 2017/12/09 ⋅ 0

在AWS中部署OpenShift平台

OpenShift是RedHat出品的PAAS平台。OpenShift做为PAAS平台最大的特点是它是完全容器化的PAAS平台,底层封装了Docker和Kubernetes,上层暴露了对开发者友好的接口来完成对应用程序的集成、部署...

无敌西瓜 ⋅ 2017/08/23 ⋅ 0

自动化运维ansible的简单配置与使用

介绍 Ansible是当前较新的自动化运维工具,基于Python开发,集合了众多运维工具(puppet,chef,func,fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。Ansible本身...

一号花匠 ⋅ 2017/12/11 ⋅ 0

ansible调用callbacks插件实现结果nosql输出回调

前言: ansible的结果默认是输出到cli终端和日志里面的,用惯了saltsatck的returners数据回调后,也很是喜欢ansible也有,一开始不知道有这个功能,自己也简单实现了这样的功能。 我的实现方...

rfyiamcool ⋅ 2014/07/20 ⋅ 0

我的python学习--第十四天(二)

一、ansible api 在了解python的ansible api之前,先简单了解一下ansible。 ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)...

yaoliang833 ⋅ 2016/11/14 ⋅ 0

Ansible Dynamic Inventory 介绍

Ansible Inventory实际上是包含静态Inventory和动态Inventory两部分,静态Inventory指的是在文件/etc/ansible/hosts中指定的主机和组,Dynamic Inventory指通过外部脚本获取主机列表,并按照...

linux-tao ⋅ 05/16 ⋅ 0

LinchPin:一个使用 Ansible 的简化的编配工具

2016 年末开始的 LinchPin,现在已经拥有一个 Python API 和一个成长中的社区。 去年,我的团队公布了 LinchPin,这是一个使用 Ansible 的混合云编配orchestration工具。配给provision云资源...

作者: Clint Savage ⋅ 2017/12/21 ⋅ 0

ansible动态inventory 获取自定义的主机列表

一、简单说明 Ansible,默认是调用“/etc/ansible/hosts”配置的主机组或者主机,同时也可以通过 -i 参数指定自定义的hosts文件。 Ansible Inventory实际上是包含静态Inventory和动态Invento...

科技小能手 ⋅ 2017/11/12 ⋅ 0

ansible之介绍

一.ansible介绍常用的自动化运维工具Puppet —基于 Ruby 开发,采用 C/S 架构,扩展性强,基于 SSL,远程命令执行相对较弱SaltStack —基于 Python 开发,采用 C/S 架构,相对 puppet 更轻量...

演员的blog ⋅ 01/01 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

JavaScript零基础入门——(十一)JavaScript的DOM操作

JavaScript零基础入门——(十一)JavaScript的DOM操作 大家好,欢迎回到我们的JavaScript零基础入门。最近有些同学问我说,我讲的的比书上的精简不少。其实呢,我主要讲的是我在开发中经常会...

JandenMa ⋅ 22分钟前 ⋅ 0

volatile和synchronized的区别

volatile和synchronized的区别 在讲这个之前需要先了解下JMM(Java memory Model :java内存模型):并发过程中如何处理可见性、原子性、有序性的问题--建立JMM模型 详情请看:https://baike.b...

MarinJ_Shao ⋅ 49分钟前 ⋅ 0

深入分析Kubernetes Critical Pod(一)

Author: xidianwangtao@gmail.com 摘要:大家在部署Kubernetes集群AddOn组件的时候,经常会看到Annotation scheduler.alpha.kubernetes.io/critical-pod"="",以表示这是一个关键服务,那你知...

WaltonWang ⋅ 57分钟前 ⋅ 0

原子性 - synchronized关键词

原子性概念 原子性提供了程序的互斥操作,同一时刻只能有一个线程能对某块代码进行操作。 原子性的实现方式 在jdk中,原子性的实现方式主要分为: synchronized:关键词,它依赖于JVM,保证了同...

dotleo ⋅ 今天 ⋅ 0

【2018.06.22学习笔记】【linux高级知识 14.4-15.3】

14.4 exportfs命令 14.5 NFS客户端问题 15.1 FTP介绍 15.2/15.3 使用vsftpd搭建ftp

lgsxp ⋅ 今天 ⋅ 0

JeeSite 4.0 功能权限管理基础(Shiro)

Shiro是Apache的一个开源框架,是一个权限管理的框架,实现用户认证、用户授权等。 只要有用户参与一般都要有权限管理,权限管理实现对用户访问系统的控制,按照安全规则或者安全策略控制用户...

ThinkGem ⋅ 昨天 ⋅ 0

python f-string 字符串格式化

主要内容 从Python 3.6开始,f-string是格式化字符串的一种很好的新方法。与其他格式化方式相比,它们不仅更易读,更简洁,不易出错,而且速度更快! 在本文的最后,您将了解如何以及为什么今...

阿豪boy ⋅ 昨天 ⋅ 0

Python实现自动登录站点

如果我们想要实现自动登录,那么我们就需要能够驱动浏览器(比如谷歌浏览器)来实现操作,ChromeDriver 刚好能够帮助我们这一点(非谷歌浏览器的驱动有所不同)。 一、确认软件版本 首先我们...

blackfoxya ⋅ 昨天 ⋅ 0

线性回归原理和实现基本认识

一:介绍 定义:线性回归在假设特证满足线性关系,根据给定的训练数据训练一个模型,并用此模型进行预测。为了了解这个定义,我们先举个简单的例子;我们假设一个线性方程 Y=2x+1, x变量为商...

wangxuwei ⋅ 昨天 ⋅ 0

容器之查看minikue的environment——minikube的环境信息

执行如下命令 mjduan@mjduandeMacBook-Pro:~/Docker % minikube docker-envexport DOCKER_TLS_VERIFY="1"export DOCKER_HOST="tcp://192.168.99.100:2376"export DOCKER_CERT_PATH="/U......

汉斯-冯-拉特 ⋅ 昨天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部