美文网首页
一种利用web服务实现模型常驻内存的简单方法

一种利用web服务实现模型常驻内存的简单方法

作者: IrvingBei | 来源:发表于2018-10-02 21:42 被阅读0次

    利用python的web服务快速实现模型常驻内存,本方法很low,但是真的很快速,半个小时都能实现。


    1、背景

    前段时间有这样一个需求,通过php接收微信服务器发送来的消息,然后把消息发送给python功能逻辑处理程序。在前期是直接使用php调用python程序,python程序进行模型加载,消息处理,然后返回给php。利用这种流程,处理过程不慢都难。但是还必须得按照这样的流程走,于是想想能不能将之前训练好的模型常驻内存。查阅网上,解决方法有很多,可以利用socket通信、做成客户/服务器模式等,这些方法都非常好,但是实现起来有一定的复杂。所以想到了这种方法。

    2、整体思路

    主要是用python以及其flask库来实现的。主要思路有以下几点:

    • 将php调用python程序改为php通过get或post方法向python发送请求;
    • python程序改成web服务模式,运行的就加载模型,让它一直运行;
    • python接收请求,处理,并返回结果;

    Flask是一个使用 Python 编写的轻量级 Web 应用框架,使用时,只需要在python中引入即可,因为需要处理get或者post请求,同时引入request,接下来就按照流程来编写代码即可。主要步骤如下:
    (1)flask的简单实验

    • 引入包创建一个flask应用
    from flask import Flask,request
    app = Flask(__name__)
    
    • 定义一个方法
    def hello():
            print("hello world")
    
    • 运行应用
    app.debug = True
    app.run()
    

    完整代码:

    from flask import Flask,request
    app = Flask(__name__)
    
    # 加载模型
    
    # 处理请求
    @app.route('/hello')
    def hello():
        return("hello world")
    
    if __name__ == '__main__':
        app.debug = True
        app.run()
    

    此时运行该程序,在浏览器地址栏输入:127.0.0.1:5000/hello,此时浏览器中就会显示hello world,好了,那么接下来的事情就简单了。只需要把上面加载模型和处理请求部分的代码稍作修改就可以了。

    • 加载模型
    model= load_model_to_memory()  # 原来加载模型的那些代码
    
    • 接收请求并处理
    # 处理请求
    @app.route('/deal', methods=['GET'])
    def deal():
            # 获取php发来的消息
            question = request.args.get('question',"default question")   # 键值 默认值
            # 对消息进行解码
            question=urllib.parse.unquote(question)
            result = main_function(model)  # 该函数就是原来的主要功能逻辑处理函数
            # 返回处理结果
            return (urllib.parse.quote(result))
    

    (2)php与python之间通信
    上面的程序一直运行着,这样,可以通过url地址向python程序发送请求。在php中构造get或者post请求的方法可以见

    相关文章

      网友评论

          本文标题:一种利用web服务实现模型常驻内存的简单方法

          本文链接:https://www.haomeiwen.com/subject/ccwteftx.html