通过flask框架写成http接口调用Ansible

#*******一、flask_ansible.py文件
#!/usr/bin/env python
#_*_ coding:utf-8 _*_
import json
from flask import Flask,request
from ansible_api_job import Ansibles

app = Flask(__name__)

@app.route(‘/ansible/command‘, methods=[‘GET‘,‘POST‘])
def command():
    if request.method == ‘POST‘:
        jsondata = request.get_data()
        dictdata = json.loads(jsondata)
        ansible = Ansibles(dictdata[‘host‘]) #实例化Ansible对象
        res = ansible.shell(dictdata[‘command‘])
        return res
    else:
        return ‘<h1>Access error</h1>‘

@app.route(‘/ansible/copyfile‘, methods=[‘GET‘,‘POST‘])
def copyfile():
    if request.method == ‘POST‘:
        jsondata = request.get_data()
        dictdata = json.loads(jsondata)
        ansible = Ansibles(dictdata[‘targethost‘]) #实例化Ansible对象
        res = ansible.copyfile(str(dictdata[‘srcfile‘]),str(dictdata[‘dectdir‘]))
        return res
    else:
        return ‘<h1>Access error</h1>‘

@app.route(‘/ansible/pullfile‘,methods=[‘GET‘,‘POST‘])
def pullfile():
    if request.method == ‘POST‘:
        jsondata = request.get_data()
        dictdata = json.loads(jsondata)
        ansible = Ansibles(dictdata[‘srchost‘])
        res = ansible.pull(dictdata[‘pullsrcfile‘], dictdata[‘savelocaldir‘])
        return res
    else:
        return ‘<h1>Access error</h1>‘
if __name__ ==‘__main__‘:
    app.run(debug=True,host=‘0.0.0.0‘)

#************二、ansible_api_job.py文件
#!/user/bin/eng python
# -*- coding=utf-8 -*-
import ansible.runner

class Ansibles(object):
    def __init__(self,hostname):
        self.hostname = hostname
        hostlist = self.hostname.split(‘,‘)
        hostfile = open(‘host.txt‘, ‘w+‘)
        hostfile.writelines(‘[vmserver]‘ + ‘\n‘)
        for line in hostlist:
            hostfile.writelines(line + ‘\n‘)
        hostfile.close()

    def shell(self,command):
        results = ansible.runner.Runner(
            host_list= ‘host.txt‘,
            remote_user = ‘root‘,
            remote_pass = ‘1qaz#EDC‘,
            module_name = ‘shell‘,
            module_args = command,
            pattern = ‘vmserver‘,
            forks = 10
            ).run()
        for (hostname,result) in results[‘contacted‘].items():
            if result[‘stdout‘] == "":
                return "HOST:%s, ERROR>>(%s)" % (hostname, result[‘stderr‘])
            else:
                return "HOST:%s, RESULTS>>(%s)" % (hostname, result[‘stdout‘])

    def copyfile(self,srcfile,dectdir):
        results = ansible.runner.Runner(
            host_list=‘host.txt‘,
            remote_user=‘root‘,
            remote_pass=‘1qaz#EDC‘,
            module_name=‘copy‘,
            module_args=‘src=%s dest=%s‘ % (srcfile,dectdir),
            pattern=‘vmserver‘,
            forks=10
        ).run()
        for (hostname,result) in results[‘contacted‘].items():
            if ‘failed‘ in result:
                return "HOST:%s, ERROR>>(%s)" % (hostname,result[‘msg‘])
            else:
                return "HOST:%s, copy ok" % (hostname)

    # 文件拉取到本地
    def pull(self,pullsrcfile,savelocaldir):
        pullfileres = ansible.runner.Runner(
            host_list=‘host.txt‘,
            remote_user=‘root‘,
            remote_pass=‘1qaz#EDC‘,
            module_name=‘fetch‘,
            module_args=‘src=%s dest=%s flat=yes‘ % (pullsrcfile, savelocaldir),
            pattern=‘vmserver‘,
            forks=10
        ).run()
        for (hostname,result) in pullfileres[‘contacted‘].items():
            if ‘msg‘ in result:
                return "HOST:%s ERROR>>(%s)" % (hostname,result[‘msg‘])
            else:
                return ‘HOST:%s pull ok‘ % (hostname)
if __name__ == "__main__":
    pass
    
#*********三、urlib2调用http接口
#_*_coding:utf-8_*_
import urllib2
import json

#调用执行命令HTTP接口
def ansible_http_post_command(host,command):
    url = ‘http://192.168.89.8:5000/ansible/command‘
    data = {‘host‘: host, ‘command‘: command}
    headers = {‘Content-Type‘: ‘application/json‘}
    req = urllib2.Request(url=url, headers=headers, data=json.dumps(data))
    response = urllib2.urlopen(req)
    return response.read()
#res = ansible_http_post_command(‘vm5‘,"uname -a")
#print res

#调用传送文件到目标主机的HTTP接口
def ansible_http_post_copyfile(srcfile,targethost,dectdir):
    url = ‘http://192.168.89.8:5000/ansible/copyfile‘
    data = {‘srcfile‘: srcfile, ‘targethost‘: targethost,‘dectdir‘:dectdir}
    headers = {‘Content-Type‘: ‘application/json‘}
    req = urllib2.Request(url=url, headers=headers, data=json.dumps(data))
    response = urllib2.urlopen(req)
    return response.read()
res = ansible_http_post_copyfile(‘/tmp/12345.txt‘,‘vm4‘,‘/root/‘)
print res

#调用从目标主机中拉取文件到本地的HTTP接口
def ansible_http_post_pullsend(srchost,pullsrcfile,savelocaldir):
    url = ‘http://192.168.89.8:5000/ansible/pullfile‘
    data = {‘srchost‘:srchost,‘pullsrcfile‘:pullsrcfile,‘savelocaldir‘:savelocaldir}
    headers = {‘Content-Type‘: ‘application/json‘}
    req = urllib2.Request(url=url, headers=headers, data=json.dumps(data))
    response = urllib2.urlopen(req)
    return response.read()
#res = ansible_http_post_pullsend(‘vm2‘,‘/tmp/12345.txt‘,‘/tmp/‘)
#print res
时间: 2024-08-06 19:49:30

通过flask框架写成http接口调用Ansible的相关文章

使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(四)——对 run.py 的调整

使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(三)——使用Flask-Login库实现登录功能 为了方便以后的应用切换,所以需要对 run.py 里的代码进行调整下. 1.在/demo 目录下创建 app_start.py /demo/app_start.py # config=utf-8 from demo

使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(三)——使用Flask-Login库实现登录功能

使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用 使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化 本次示例的源码下载:点击下载 Flask-Login 库的中文文档:点击进入 Flask-Login 库的新版英文文档:点击进入 一.导入并初始化 Flask-Login 库 在项目根目录下的/demo/__init__.py 文件的头部,import 进 flask_login 库 from flask_login imp

python调用powershell,flask框架实现操作RemoteAPP接口

1.Get_RemoteAPP.ps1 set-executionpolicy remotesigned Import-Module RemoteDesktopServices function GetAPP(){     $result = ls -l RDS:\RemoteApp\RemoteAppPrograms    $res = $result | ForEach-Object {$_.Name}     return $res } GetAPP 2.New_RemoteAPP.ps1

使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(一)——创建应用

Flask 中文文档 Flask_Login 文档 Flask-sqlalchemy 文档 Jinja2 模板文档 为了熟悉 Python 的 Web 开发,找到这个框架.在这里记录下使用它来写一个简单的登录 Demo 功能过程中碰到的问题. 上面几个链接就是使用到相关的库的文档. Flask_Login 这个是官方实现的一套登录验证的库. Flask_sqlalchemy 是官方对 sqlalchemy 库的一个封装,它是一个ORM,用于做数据库访问. 这里使用的开发工具是 PyCharm,使

使用 Flask 框架写用户登录功能的Demo时碰到的各种坑(二)——使用蓝图功能进行模块化

关于蓝图的使用,可以查看文档:点击进入 一.创建蓝图 1.在 demo 目录下创建一个 modules 目录,做为模块的目录. 2.在 modules 目录下,创建一个 home 目录,做为主页模块. 3.在 home 目录下创建一个 views.py 文件,用来编写路由与请求处理.(相当于 ASP.NET MVC 里的 Routes 和 Controllers) 4.在 home 目录下创建一个 templates 目录,做为 home 模块的模板存放目录,并在这下面创建一个空的 index.

Python:hashlib加密模块,flask模块写登录接口

hashlib模块 主要用于加密相关的操作,(比如说加密字符串)在python3的版本里,代替了md5和sha模块,主要提供 sha1, sha224, sha256, sha384, sha512 ,md5 这些加密方式 import  hashlib m = hashlib.md5()   #用md5加密的方式(md5加密后无法解密),创建一个md5的对象 m.update(b"Hello")  #b代表二进制字节bytes,把字符串hello转成字节,然后加密:用b给一个变量转换

(原创)多系统间需要对接,我写了一个接口框架。实用性非常强,写出来大家交流。需要的可以直接搬过去用。(第1篇)

业务是这样:有个手机app,在ios或者android上开发的,他需要访问服务器数据.我在服务器上,做了一个接口,专门开放一些数据给app去用. 我写的接口优势:我写的这个接口,全部是面向对象结构,代码简单而非常好用,极易扩展.可读性很强,容错性高. 个人建议有需要的同学可以直接拿去用到项目中..我会一步步讲他的制作方法. 第1步,创建一个工程,在工程中,创建一个网站,以及一个业务操作类库.如下图: 上图是网站. 上图是类库 第2步,创建几个根类.cs文件.如上图,创建:Post.cs文件:用于

java 后台框架 支持APP接口调用 APP后台 手机后台框架java springmvc mybaits mysql oracle html5 后台框架

获取[下载地址]   QQ: 313596790   [免费支持更新]A 代码生成器(开发利器);全部是源码     增删改查的处理类,service层,mybatis的xml,SQL( mysql   和oracle)脚本,   jsp页面 都生成   就不用写搬砖的代码了,生成的放到项目里,可以直接运行B 阿里巴巴数据库连接池druid;  数据库连接池  阿里巴巴的 druid.Druid在监控.可扩展性.稳定性和性能方面都有明显的优势C 安全权限框架shiro ;  Shiro 是一个用

java 后台框架 支持APP接口调用 APP后台

获取[下载地址]   QQ: 313596790   [免费支持更新]支持三大数据库 mysql  oracle  sqlsever   更专业.更强悍.适合不同用户群体[新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统]A 代码生成器(开发利器);      增删改查的处理类,service层,mybatis的xml,SQL( mysql   和oracle)脚本,   jsp页面 都生成   就不用写搬砖的代码了,生成的放到项目里,可以直接运行B 阿里巴巴数据库连接池druid