在烧瓶中缓存函数

时间:2019-01-12 11:59:18

标签: python caching flask flask-cache

我有这段代码在我的机器上本地执行大约9.2秒。 将其部署到AWS ec2盒后,执行时间最多可提高20秒。

由于我之前没有实现任何缓存,所以我想知道是否可以缓存特定功能的响应,或者我需要缓存从外部获取的每个POST。

本质上,我要问的是如何缓存POST的结果,因此每当我再次运行它时,只要使用相同的参数,它就会使用缓存来加快响应速度。

#!flask/bin/python
from flask import Flask, jsonify
from flask import request
import json
import nltk, string
import operator
from sklearn.feature_extraction.text import TfidfVectorizer
import re
from flask import make_response
import time
import access_json

app = Flask(__name__)

def output(word_list):
    start = time.time()
    #RUNNING ALGORITHM *****************
    comparison_words = get_synonyms(word_list) + word_list
    print(comparison_words)
    dict_sim = {}
    for i in json_list:
        dict_sim[i['jobId']] = cosine_sim(str(comparison_words), i['jobDescription'])
    sorted_sim = sorted(dict_sim.items(), key=operator.itemgetter(1), reverse = True)
    toplist = sorted_sim[:10]
    sort_toplist = list(map(operator.itemgetter(0), toplist))
    filter_toplist = (list(filter(lambda job: job['jobId'] in sort_toplist, json_list)))
    #print('Our top ten suggestion from SkillzMiner are those:\n')
    end = time.time()
    print (end-start)
    # for j in filter_toplist:
    #       print ('JobTitle: ' + j['jobTitle'] +
    #             '\nEmployer Name: ' + j['employerName'] +
    #             '\nLocation: ' + j['locationName'] +
    #             '\nReed Job URL ' + j['jobUrl'] +
    #             '\nJob Description: ' + cleanhtml(j["jobDescription"]))
    return filter_toplist

@app.route('/postjson', methods=['POST'])
def json_handler():
     content = request.get_json(force=True)
     word_list = access_json.read_parsed_JSON(content)
     return jsonify ({'jobs': output(word_list)})

   if __name__ == '__main__':
    app.run(debug=True)
    app.run(host='0.0.0.0', port=80)

P.S。我省略了一些不相关的功能,这不是完整的代码。抱歉,我是这个Web服务的新手。

1 个答案:

答案 0 :(得分:0)

缓存是否需要是本地的和特定于用户的?

您是否尝试过在会话变量(例如session ['my_variable'] = my_response)中进行缓存

只要用户不进行本地访问(例如以隐身模式访问),该方法就应该适用于用户本地会话。