专栏首页python3Python之 ansible 动态In

Python之 ansible 动态In

1.Ansible Inventory  介绍;

Ansible Inventory 是包含静态 Inventory动态 Inventory 两部分的,静态 Inventory 指的是在文件中指定的主机和组,动态 Inventory 指通过外部脚本获取主机列表,并按照 ansible 所要求的格式返回给 ansilbe 命令的。这部分一般会结合 CMDB 资管系统、云计算平台等获取主机信息。由于主机资源一般会动态的进行增减,而这些系统一般会智能更新。我们可以通过这些工具提供的 API 或者接入库查询等方式返回主机列表。

2.mysql数据结构如下;

3.本章节演示从mysql数据作为数据源生成动态ansible 主机;

#!/usr/bin/env python36

def commmysql():
    import mysql.connector
    import json
    mydb = mysql.connector.connect(
        host="192.168.1.23",  # 数据库主机地址
        user="root",  # 数据库用户名
        passwd="123456",
        database="test"
    )
    mycursor = mydb.cursor()
    mycursor.execute(" select host,`group` from ansible_hosts;")
    #mycursor.
    myresult = mycursor.fetchall()
    data = dict()
    #####查询出group分组并去重#############
    groups = list(set([i[1].decode() for i in myresult]))
    data["all"] = {"children": groups}
    data["_meta"] = {"hostvars": {}}
    for group in groups:
        data[group] = dict()
        data[group]["hosts"] = list()
        for x in myresult:
            if x[1].decode("utf-8") == group:
                data[group]["hosts"].append(x[0].decode("utf-8"))
    return json.dumps(data,indent=3)


def main():
    from optparse import OptionParser
    parse = OptionParser()
    parse.add_option("-l", "--list", action="store_true", dest="list", default=False)
    (option, arges) = parse.parse_args()
    if option.list:
        print(commmysql())
    else:
        print("abc")



if __name__ == '__main__':
    from optparse import OptionParser
    parse = OptionParser()
    parse.add_option("-l", "--list", action="store_true", dest="list", default=False)
    (option, arges) = parse.parse_args()
    if option.list:
        print(commmysql())
    else:
        print("test")

4.数据格式结果如下;

5.ansible 执行动态主机如下;

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • Python3 urllib.parse

    py3study
  • 我的python学习--第三天

        2、后面跟上for循环,可以有多个for循环,也可以在for循环后面再加个if条件

    py3study
  • 第六篇:python中numpy.zer

    py3study
  • 特征锦囊:如何对类别变量进行独热编码?

    很多时候我们需要对类别变量进行独热编码,然后才可以作为入参给模型使用,独热的方式有很多种,这里介绍一个常用的方法 get_dummies吧,这个方法可以让类别变...

    Sam Gor
  • JAVA中的单例模式分析(doublecheck和枚举实现)

    所为饿汉模式,即一开始就创建一个静态的对象,之后该对象一直存在。这种模式不会有线程安全问题。

    冬天里的懒猫
  • 001仓储物流自动化这行是干嘛的?

    物资各式各样,仓库可大可小,存储的方法当然也是多种多样。仓储其实就每天发生在我们生活中的每一天,比如小到我们的衣物存储到衣柜里,书籍存放到书架里,文件存放到档案...

    老King
  • AlphaZero完胜三大世界冠军棋类程序:5000个TPU、自学一天

    Root 编译整理 量子位 出品 | 公众号 QbitAI 昨天,DeepMind团队又在arXiv上扔了个重磅炸弹,新一代AlphaZero在用了强劲的计算资...

    量子位
  • r语言空间可视化绘制道路交通安全事故地图

    拓端
  • jquery获取select多选框选中的值

    蓓蕾心晴
  • 听说你的PyCharm&IDEA挂掉了呀,永久激活了解一下

    To be beautiful means to be yourself. You don't need to be accepted by others. Y...

    小闫同学啊

扫码关注云+社区

领取腾讯云代金券