Rozwiązywanie problemów z TemplateNotFound z Flask pod Gunicorn

Mam aplikację Flask, którą próbuję wdrożyć za pomocą Gunicorn i nginx. Jednak mimo że działa dobrze lokalnie, zgłasza błąd TemplateNotFound, gdy uruchamiam program Gunicorn na moim zdalnym serwerze.

Nie wiem, jak nawet zacząć to debugować, nie mówiąc już o tym, dlaczego to się nie powiedzie ... bardzo by mi pomogło na pierwszym, jeśli nie na drugim. Myślałem, że może to był problem z uprawnieniami, więc chmodował folder szablonów do 777 ... bez powodzenia. Oto wszystkie istotne szczegóły:

zainstaluj skrypt

Począwszy od czystej instalacji Ubuntu 10.04, uruchamiam to, aby skonfigurować serwer i pobrać mój kod:https://github.com/total-impact/total-impact-deploy/blob/master/deploy.sh. Następnie umieściłem ten plik konfiguracyjny nginx w / etc / nginx / sites-available / total-impact:

server {
    location / {
        proxy_pass http://127.0.0.1:8000;
    }
}

Wreszcie poruszam się po katalogu aplikacji i uruchamiamgunicorn web:appi naciśnij adres IP serwera. Generuje to 500 w przeglądarce, a to wyjście w wierszu poleceń:

Ślad stosu:
root@jc:/home/ti/total-impact-webapp/totalimpactwebapp# gunicorn web:app2012-05-28 23:15:06 [15313] [INFO] Starting gunicorn 0.14.3
2012-05-28 23:15:06 [15313] [INFO] Listening at: http://127.0.0.1:8000 (15313)
2012-05-28 23:15:06 [15313] [INFO] Using worker: sync
2012-05-28 23:15:06 [15316] [INFO] Booting worker with pid: 15316
2012-05-28 23:15:12,274 - totalimpactwebapp.core - ERROR - Exception on / [GET]
Traceback (most recent call last):
  File "/usr/local/lib/python2.6/dist-packages/flask/app.py", line 1292, in wsgi_app
    response = self.full_dispatch_request()
  File "/usr/local/lib/python2.6/dist-packages/flask/app.py", line 1062, in full_dispatch_request
    rv = self.handle_user_exception(e)
  File "/usr/local/lib/python2.6/dist-packages/flask/app.py", line 1060, in full_dispatch_request
    rv = self.dispatch_request()
  File "/usr/local/lib/python2.6/dist-packages/flask/app.py", line 1047, in dispatch_request
    return self.view_functions[rule.endpoint](**req.view_args)
  File "/home/ti/total-impact-webapp/totalimpactwebapp/web.py", line 60, in home
    return render_template('index.html', commits=False)
  File "/usr/local/lib/python2.6/dist-packages/flask/templating.py", line 120, in render_template
    return _render(ctx.app.jinja_env.get_template(template_name),
  File "/usr/local/lib/python2.6/dist-packages/jinja2/environment.py", line 719, in get_template
    return self._load_template(name, self.make_globals(globals))
  File "/usr/local/lib/python2.6/dist-packages/jinja2/environment.py", line 693, in _load_template
    template = self.loader.load(self, name, globals)
  File "/usr/local/lib/python2.6/dist-packages/jinja2/loaders.py", line 115, in load source, filename, uptodate = self.get_source(environment, name)
  File "/usr/local/lib/python2.6/dist-packages/flask/templating.py", line 61, in get_source
    raise TemplateNotFound(template)
TemplateNotFound: index.html

questionAnswers(3)

yourAnswerToTheQuestion