Ошибка сервера при размещении приложения-пирамиды с помощью production.ini
У меня есть проект пирамиды, который прекрасно работает при размещении с development.ini, но как только я использую production.ini, я получаю эту ошибку в браузере:
Internal Server Error
The server encountered an unexpected internal server error
(generated by waitress)
и этот лог в терминале:
Starting subprocess with file monitor
Starting server in PID 5912.
serving on http://0.0.0.0:6543
2014-05-26 16:54:23,139 ERROR [waitress][Dummy-2] Exception when serving /
Traceback (most recent call last):
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/waitress-0.8.9-py2.7.egg/waitress/channel.py", line 337, in service
task.service()
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/waitress-0.8.9-py2.7.egg/waitress/task.py", line 173, in service
self.execute()
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/waitress-0.8.9-py2.7.egg/waitress/task.py", line 392, in execute
app_iter = self.channel.server.application(env, start_response)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/router.py", line 242, in __call__
response = self.invoke_subrequest(request, use_tweens=True)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/router.py", line 217, in invoke_subrequest
response = handle_request(request)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/tweens.py", line 21, in excview_tween
response = handler(request)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid_tm-0.7-py2.7.egg/pyramid_tm/__init__.py", line 82, in tm_tween
reraise(*exc_info)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid_tm-0.7-py2.7.egg/pyramid_tm/__init__.py", line 63, in tm_tween
response = handler(request)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/router.py", line 163, in handle_request
response = view_callable(context, request)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/config/views.py", line 377, in rendered_view
context)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/renderers.py", line 418, in render_view
return self.render_to_response(response, system, request=request)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/renderers.py", line 441, in render_to_response
result = self.render(value, system_values, request=request)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/renderers.py", line 421, in render
renderer = self.renderer
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/decorator.py", line 37, in __get__
val = self.wrapped(inst)
File "/home/roman/Critical_ID/CCG_Map/local/lib/python2.7/site-packages/pyramid/renderers.py", line 404, in renderer
'No such renderer factory %s' % str(self.type))
ValueError: No such renderer factory .mak
Я скопировал поверх моего sqlalchemy.url
а также mako.directories
под [app:main]
раздел в файлах.ini, и я не вижу, что является причиной этой ошибки.
Я запускаю сервер с: ../bin/pserve/production.ini --reload
Что мне не хватает?
1 ответ
Это связано с тем, что в последних версиях Pyramid по умолчанию не требуется / не устанавливается движок шаблонов Mako. Чтобы исправить эту ошибку, как документировано ЗДЕСЬ, вы должны сделать две вещи:
Убедитесь, что
pyramid_mako
пакет установлен. Один из способов сделать это, добавив "pyramid_mako" кinstall_requires
раздел вашего пакетаsetup.py
файл и затем повторный запускsetup.py develop
:setup( #... install_requires=[ 'pyramid_mako', # new dependency 'pyramid', #... ], )
В той части вашего приложения, в которой создается Конфигуратор Pyramid (часто
main()
функция в вашем проекте__init__.py
файл), скажите Пирамиде, чтобы включитьpyramid_mako
включите меня:config = Configurator(.....) config.include('pyramid_mako')