erro mod_wsgi - classe .__ dict__ não acessível no modo restrito
Isso começou a nos incomodar muito no nosso servidor de produção. Nós vimos isso ocasionalmente (por 1 pedido por semana). Naquela época, descobrimos que é por causa do mod_wsgi fazendo algumas coisas funky em algumas configurações. Como não conseguimos rastrear o motivo do bug, decidimos que não requeria atenção instantânea.
No entanto, hoje, em um dos nossos servidores de produção, isso realmente ocorreu para 10% de todas as solicitações do servidor; isto é, 10% de todas as solicitações do servidor falharam com o mesmo erro:
<code>mod_wsgi (pid=1718): Target WSGI script '/installation/dir/our-program/prod-dispatch.wsgi' cannot be loaded as Python module. mod_wsgi (pid=1718): Exception occurred processing WSGI script '/installation/dir/our-program/prod-dispatch.wsgi'. Traceback (most recent call last): File "/installation/dir/our-program/prod-dispatch.wsgi", line 7, in <module> from pyramid.paster import get_app File "/installation/dir/venv/local/lib/python2.7/site-packages/pyramid-1.3a6-py2.7.egg/pyramid/paster.py", line 12, in <module> from pyramid.scripting import prepare File "/installation/dir/venv/local/lib/python2.7/site-packages/pyramid-1.3a6-py2.7.egg/pyramid/scripting.py", line 1, in <module> from pyramid.config import global_registries File "/installation/dir/venv/local/lib/python2.7/site-packages/pyramid-1.3a6-py2.7.egg/pyramid/config/__init__.py", line 61, in <module> from pyramid.config.assets import AssetsConfiguratorMixin File "/installation/dir/venv/local/lib/python2.7/site-packages/pyramid-1.3a6-py2.7.egg/pyramid/config/assets.py", line 83, in <module> @implementer(IPackageOverrides) File "/installation/dir/venv/local/lib/python2.7/site-packages/zope.interface-3.8.0-py2.7-linux-x86_64.egg/zope/interface/declarations.py", line 480, in __ classImplements(ob, *self.interfaces) File "/installation/dir/venv/local/lib/python2.7/site-packages/zope.interface-3.8.0-py2.7-linux-x86_64.egg/zope/interface/declarations.py", line 445, in cl spec = implementedBy(cls) File "/installation/dir/venv/local/lib/python2.7/site-packages/zope.interface-3.8.0-py2.7-linux-x86_64.egg/zope/interface/declarations.py", line 285, in im spec = cls.__dict__.get('__implemented__') RuntimeError: class.__dict__ not accessible in restricted mode </code>
Ubuntu Precise, 64 bits, com o mais recente Apache, mod_wsgi, Python 2.7, usando mpm_worker + mod_wsgi emdaemon modo. Este é o único programa em execução no servidor e existe apenas um intérprete wsgi na configuração. É por causa do mpm_worker gerar novos encadeamentos ou o quê? Mais importante - como consertamos isso?
Temos o seguinte para subdividir as solicitações para 4 processos daemon com base em um cookie.
<code>WSGIPythonOptimize 1 WSGIDaemonProcess sticky01 processes=1 threads=16 display-name=%{GROUP} WSGIDaemonProcess sticky02 processes=1 threads=16 display-name=%{GROUP} WSGIDaemonProcess sticky03 processes=1 threads=16 display-name=%{GROUP} WSGIDaemonProcess sticky04 processes=1 threads=16 display-name=%{GROUP} <VirtualHost *:81> ... WSGIRestrictProcess sticky01 sticky02 sticky03 sticky04 WSGIProcessGroup %{ENV:PROCESS} ... WSGIScriptAlias / /installation/dir/our-program/prod-dispatch.wsgi </VirtualHost> </code>