2015-10-25 75 views
1

我目前使用Twilio API,Python Flask來製作一個簡單的SMS應用程序。 我正在用heroku部署這個應用程序。 當我部署對Heroku的應用程序,它導致錯誤說:AttributeError,Heroku的gunicorn錯誤

AttributeError: 'dict' object has no attribute 'iteritems'

File "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", line 459, in reap_workers

2015-10-25T09:53:57.727074+00:00 app[web.1]: raise HaltServer(reason, self.WORKER_BOOT_ERROR) 2015-10-25T09:53:57.727123+00:00 app[web.1]: gunicorn.errors.HaltServer:

整個Heroku的日誌,就像下面:

> 2015-10-25T09:53:57.695725+00:00 app[web.1]: [2015-10-25 09:53:57 
> +0000] [7] [INFO] Worker exiting (pid: 7) 2015-10-25T09:53:57.725119+00:00 app[web.1]: Traceback (most recent 
> call last): 2015-10-25T09:53:57.725131+00:00 app[web.1]: File 
> "/app/.heroku/python/bin/gunicorn", line 11, in <module> 
> 2015-10-25T09:53:57.725453+00:00 app[web.1]:  sys.exit(run()) 
> 2015-10-25T09:53:57.725457+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", 
> line 74, in run 2015-10-25T09:53:57.725622+00:00 app[web.1]:  
> WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]").run() 
> 2015-10-25T09:53:57.725626+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/base.py", 
> line 189, in run 2015-10-25T09:53:57.725832+00:00 app[web.1]:  
> super(Application, self).run() 2015-10-25T09:53:57.725836+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/base.py", 
> line 72, in run 2015-10-25T09:53:57.725968+00:00 app[web.1]:  
> Arbiter(self).run() 2015-10-25T09:53:57.725971+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 174, in run 2015-10-25T09:53:57.726129+00:00 app[web.1]:  
> self.manage_workers() 2015-10-25T09:53:57.726133+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 477, in manage_workers 2015-10-25T09:53:57.726385+00:00 
> app[web.1]:  self.spawn_workers() 2015-10-25T09:53:57.726387+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 541, in spawn_workers 2015-10-25T09:53:57.726632+00:00 
> app[web.1]:  time.sleep(0.1 * random.random()) 
> 2015-10-25T09:53:57.726636+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 214, in handle_chld 2015-10-25T09:53:57.726809+00:00 app[web.1]: 
> self.reap_workers() 2015-10-25T09:53:57.726813+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 459, in reap_workers 2015-10-25T09:53:57.727074+00:00 app[web.1]: 
> raise HaltServer(reason, self.WORKER_BOOT_ERROR) 
> 2015-10-25T09:53:57.727123+00:00 app[web.1]: 
> gunicorn.errors.HaltServer: <HaltServer 'Worker failed to boot.' 3> 
> 2015-10-25T09:53:58.432435+00:00 heroku[web.1]: Process exited with 
> status 1 2015-10-25T09:53:58.448971+00:00 heroku[web.1]: State changed 
> from starting to crashed 2015-10-25T09:54:02.514159+00:00 
> heroku[router]: at=error code=H10 desc="App crashed" method=GET 
> path="/" host=(heroku app url) 
> request_id=2ed6f5b7-551c-4039-a511-fc205d8a422c fwd="192.77.239.237" 
> dyno= connect= service= status=503 bytes= 
> 2015-10-25T09:55:29.244387+00:00 heroku[slug-compiler]: Slug 
> compilation started 2015-10-25T09:55:29.244395+00:00 
> heroku[slug-compiler]: Slug compilation finished 
> 2015-10-25T09:55:29.176924+00:00 heroku[api]: Deploy 3602dc4 by 
> (email address) 2015-10-25T09:55:29.176924+00:00 heroku[api]: 
> Release v26 created by (email address) 
> 2015-10-25T09:55:29.488257+00:00 heroku[web.1]: State changed from 
> crashed to starting 2015-10-25T09:55:32.630390+00:00 heroku[web.1]: 
> Starting process with command `gunicorn run:app` 
> 2015-10-25T09:55:34.284215+00:00 heroku[web.1]: State changed from 
> starting to up 2015-10-25T09:55:34.219364+00:00 app[web.1]: 
> [2015-10-25 09:55:34 +0000] [3] [INFO] Listening at: 
> http://0.0.0.0:7013 (3) 2015-10-25T09:55:34.219451+00:00 app[web.1]: 
> [2015-10-25 09:55:34 +0000] [3] [INFO] Using worker: sync 
> 2015-10-25T09:55:34.222305+00:00 app[web.1]: [2015-10-25 09:55:34 
> +0000] [7] [INFO] Booting worker with pid: 7 2015-10-25T09:55:34.218674+00:00 app[web.1]: [2015-10-25 09:55:34 
> +0000] [3] [INFO] Starting gunicorn 19.3.0 2015-10-25T09:55:34.233927+00:00 app[web.1]: [2015-10-25 09:55:34 
> +0000] [7] [ERROR] Exception in worker process: 2015-10-25T09:55:34.233930+00:00 app[web.1]: Traceback (most recent 
> call last): 2015-10-25T09:55:34.233932+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 507, in spawn_worker 2015-10-25T09:55:34.233932+00:00 app[web.1]: 
> worker.init_process() 2015-10-25T09:55:34.233933+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/workers/base.py", 
> line 118, in init_process 2015-10-25T09:55:34.233934+00:00 app[web.1]: 
> self.wsgi = self.app.wsgi() 2015-10-25T09:55:34.233935+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/base.py", 
> line 67, in wsgi 2015-10-25T09:55:34.233935+00:00 app[web.1]:  
> self.callable = self.load() 2015-10-25T09:55:34.233936+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", 
> line 65, in load 2015-10-25T09:55:34.233936+00:00 app[web.1]:  
> return self.load_wsgiapp() 2015-10-25T09:55:34.233937+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", 
> line 52, in load_wsgiapp 2015-10-25T09:55:34.233939+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/util.py", 
> line 355, in import_app 2015-10-25T09:55:34.233938+00:00 app[web.1]: 
> return util.import_app(self.app_uri) 2015-10-25T09:55:34.233940+00:00 
> app[web.1]: File "/app/run.py", line 1, in <module> 
> 2015-10-25T09:55:34.233939+00:00 app[web.1]:  __import__(module) 
> 2015-10-25T09:55:34.233940+00:00 app[web.1]:  from flask import 
> Flask, request, redirect 2015-10-25T09:55:34.233941+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/flask/__init__.py", 
> line 17, in <module> 2015-10-25T09:55:34.233942+00:00 app[web.1]:  
> from werkzeug.exceptions import abort 2015-10-25T09:55:34.233942+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/werkzeug/__init__.py", 
> line 109, in <module> 2015-10-25T09:55:34.233943+00:00 app[web.1]:  
> for module, items in all_by_module.iteritems(): 
> 2015-10-25T09:55:34.233944+00:00 app[web.1]: AttributeError: 'dict' 
> object has no attribute 'iteritems' 2015-10-25T09:55:34.233945+00:00 
> app[web.1]: Traceback (most recent call last): 
> 2015-10-25T09:55:34.233946+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 507, in spawn_worker 2015-10-25T09:55:34.233946+00:00 app[web.1]: 
> worker.init_process() 2015-10-25T09:55:34.233947+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/workers/base.py", 
> line 118, in init_process 2015-10-25T09:55:34.233948+00:00 app[web.1]: 
> self.wsgi = self.app.wsgi() 2015-10-25T09:55:34.233949+00:00 
> app[web.1]:  self.callable = self.load() 
> 2015-10-25T09:55:34.233949+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/base.py", 
> line 67, in wsgi 2015-10-25T09:55:34.233950+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", 
> line 65, in load 2015-10-25T09:55:34.233951+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", 
> line 52, in load_wsgiapp 2015-10-25T09:55:34.233950+00:00 app[web.1]: 
> return self.load_wsgiapp() 2015-10-25T09:55:34.233952+00:00 
> app[web.1]:  return util.import_app(self.app_uri) 
> 2015-10-25T09:55:34.233953+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/util.py", 
> line 355, in import_app 2015-10-25T09:55:34.233953+00:00 app[web.1]: 
> __import__(module) 2015-10-25T09:55:34.233954+00:00 app[web.1]: File "/app/run.py", line 1, in <module> 2015-10-25T09:55:34.233955+00:00 
> app[web.1]:  from flask import Flask, request, redirect 
> 2015-10-25T09:55:34.233955+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/flask/__init__.py", 
> line 17, in <module> 2015-10-25T09:55:34.233956+00:00 app[web.1]:  
> from werkzeug.exceptions import abort 2015-10-25T09:55:34.233957+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/werkzeug/__init__.py", 
> line 109, in <module> 2015-10-25T09:55:34.233957+00:00 app[web.1]:  
> for module, items in all_by_module.iteritems(): 
> 2015-10-25T09:55:34.233961+00:00 app[web.1]: AttributeError: 'dict' 
> object has no attribute 'iteritems' 2015-10-25T09:55:34.234066+00:00 
> app[web.1]: [2015-10-25 09:55:34 +0000] [7] [INFO] Worker exiting 
> (pid: 7) 2015-10-25T09:55:34.259788+00:00 app[web.1]: Traceback (most 
> recent call last): 2015-10-25T09:55:34.259794+00:00 app[web.1]: File 
> "/app/.heroku/python/bin/gunicorn", line 11, in <module> 
> 2015-10-25T09:55:34.260153+00:00 app[web.1]:  sys.exit(run()) 
> 2015-10-25T09:55:34.260158+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/wsgiapp.py", 
> line 74, in run 2015-10-25T09:55:34.260366+00:00 app[web.1]:  
> WSGIApplication("%(prog)s [OPTIONS] [APP_MODULE]").run() 
> 2015-10-25T09:55:34.260413+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/base.py", 
> line 189, in run 2015-10-25T09:55:34.261080+00:00 app[web.1]:  
> super(Application, self).run() 2015-10-25T09:55:34.261083+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/app/base.py", 
> line 72, in run 2015-10-25T09:55:34.262271+00:00 app[web.1]:  
> Arbiter(self).run() 2015-10-25T09:55:34.262276+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 174, in run 2015-10-25T09:55:34.262277+00:00 app[web.1]:  
> self.manage_workers() 2015-10-25T09:55:34.262278+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 477, in manage_workers 2015-10-25T09:55:34.262279+00:00 
> app[web.1]:  self.spawn_workers() 2015-10-25T09:55:34.262280+00:00 
> app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 541, in spawn_workers 2015-10-25T09:55:34.262280+00:00 
> app[web.1]:  time.sleep(0.1 * random.random()) 
> 2015-10-25T09:55:34.262281+00:00 app[web.1]: File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 214, in handle_chld 2015-10-25T09:55:34.262329+00:00 app[web.1]: 
> self.reap_workers() 2015-10-25T09:55:34.262333+00:00 app[web.1]: 
> File 
> "/app/.heroku/python/lib/python3.5/site-packages/gunicorn/arbiter.py", 
> line 459, in reap_workers 2015-10-25T09:55:34.262607+00:00 app[web.1]: 
> raise HaltServer(reason, self.WORKER_BOOT_ERROR) 
> 2015-10-25T09:55:34.262626+00:00 app[web.1]: 
> gunicorn.errors.HaltServer: <HaltServer 'Worker failed to boot.' 3> 
> 2015-10-25T09:55:35.007220+00:00 heroku[web.1]: Process exited with 
> status 1 2015-10-25T09:55:35.023047+00:00 heroku[web.1]: State changed 
> from up to crashed 2015-10-25T09:55:39.958365+00:00 heroku[router]: 
> at=error code=H10 desc="App crashed" method=GET path="/" 
> host=(heroku app url) 
> request_id=bd5ad9de-421d-418c-aa43-eaf4d26b21bf fwd="192.77.239.237" 
> dyno= connect= service= status=503 bytes= 
> 2015-10-25T09:58:12.278592+00:00 heroku[router]: at=error code=H10 
> desc="App crashed" method=GET path="/" 
> host=(heroku app url) 
> request_id=c71bd1d4-f810-4c08-9017-82dff28aa19f fwd="192.77.239.237" 
> dyno= connect= service= status=503 bytes= 

這裏是requirements.txt:

> Flask==0.10.1 gunicorn==19.3.0 httplib2==0.9.2 itsdangerous==0.24 
> Jinja2==2.6 MarkupSafe==0.23 PySocks==1.5.6 pytz==2015.6 six==1.10.0 
> twilio==4.6.0 Werkzeug==0.8.3 wheel==0.24.0 

這裏是runtime.txt:

最後,這裏是我的run.py文件,該文件是一個應用程序我試圖部署 這是硬編碼使用Twilio API 應用:

from flask import Flask, request, redirect 
import twilio.twiml 

app = Flask(__name__) 

# Try adding your own number to this list! 
callers = { 
    "(number)": "(name)", 
} 

subjects = ["math", "science", "english"] 

@app.route("/", methods=['GET', 'POST']) 
def answering_algorithm(): 
    body = request.values.get('Body', None).lower() 
    from_number = request.values.get('From', None) 

    if from_number in callers: 
     if body in subjects: 
      if body == "math": 
       message = "You have selected Math." 
       + " We have from Grade 1 to Grade 6." 
       + " Which Grade do you want to view?" 
       + " Type like following example: math grade 1" 

    if from_number in callers: 
     if body == "math grade 1": 
      message = "Welcome to Math Grade 1." 
      + "We have Addition, Addition Part 2, Addition Part 3, " 
      + "Subtraction, Subtraction Part 2." 
      + " Please input the lesson you want to view. Ex) Addition." 

    resp = twilio.twiml.Response() 
    resp.message(message) 

    return str(resp) 

if __name__ == "__main__": 
    app.run(debug=True) 

我真的不知道是什麼原因造成的錯誤時,我正在部署我的heroku應用程序。任何幫助表示讚賞

回答

3

您使用Python 3.5部署在Heroku上。 Python 3.x中的字典沒有iteritemsiterkeysitervalues方法。您需要改爲使用items,keysvalues

問題的根源似乎是您的Werkzeug版本。在0.9版本中添加了初始Python 3支持。你應該升級到更新的版本。 10.4是目前最新的。

+0

謝謝。就是這樣! – Kahsn