簡體   English   中英

如何在 google appengine Python 中使用 taskqueue.add() 增加 10 分鍾的 http 請求

[英]how to increase 10min http request using taskqueue.add() in google appengine Python

我的 http 請求顯示截止日期錯誤,例如 12 個請求中的 120mb 軟內存。 在這里,我想使用 taskqueue.add() 方法將 http 請求時間增加 10 分鍾。提前致謝。

class ExportHandler(BaseHandler):
    def get(self):
        tables = []
        app_models = [m for m in dir(models.app) if not m.startswith("__")]
        admin_models = [m for m in dir(models.admin) if not m.startswith("__")]
        total = app_models+admin_models
        for mname in total:
            if mname not in REMOVE:
                label = title(mname)
                tables.append({'value':mname, 'label':label})
        fromdate = None
        todate = None
        if "fromdate" in self.request.GET:
            fdate = self.request.GET['fromdate']
            try:
                fromdate = datetime.strptime(fdate, "%m/%d/%Y")
            except Exception as e:
                pass
        if "todate" in self.request.GET:
            tdate = self.request.GET['todate']
            try:
                todate = datetime.strptime(tdate, "%m/%d/%Y")
                todate = todate+timedelta(days=1)
            except Exception as e:
                pass
        if fromdate is not None and todate is not None:
            table = self.request.GET['table']
            model_class = get_class(table, app_models, admin_models)

            model_name = model_class.__name__
            columns = model_class.properties().keys()
            query = model_class.gql("where created_date >= :1 and created_date <= :2", fromdate, todate)
            if 'date_time' in columns:
                query = model_class.gql("where date_time >= :1 and date_time <= :2", fromdate, todate)
 records = [i for i in query.run()]
            if bool(records):
                fmt = "%m/%d/%Y"
                filename = "%s_%s_%s" %(model_name, fromdate.strftime(fmt), todate.strftime(fmt))
                csvfile = self.response


                writer = csv.writer(csvfile, delimiter=",")
                writer.writerow(records[0].json().keys())

                for rec in records:

                    writer.writerow(rec.json().values())

                self.response.content_disposition = 'attachment; filename=%s.csv' % filename
                return self.response
            else:
                self.session.add_flash("No records found", key='error')                                      
        self.render_response("/admin/exportcsv/index.html", tables=tables)  

    def post(self):
        print self.request.POST
        self.render_response("/admin/exportcsv/index.html")  

聽起來您遇到了“在為 Y 個請求總數提供服務后超過 X MB 的軟私有內存限制”錯誤而不是 DeadlineExceededError。 如果是這種情況, GAE 中的“軟私有內存限制”是什么? 有一些提示。

擴展您的實例類可以將您的內存限制提高到 1 GB,應該可以解決這個問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM