I recently uploaded an Django application with the use off Zappa, which was running perfectly fine.
Now, I wanted to update this application, and It suddenly gives me this error: (The changes I made wasn't really that much, removed a blank=True in my models.py)
ModuleNotFoundError: No module named '_cffi_backend'
Traceback (most recent call last):
File "/var/task/handler.py", line 657, in lambda_handler
return LambdaHandler.lambda_handler(event, context)
File "/var/task/handler.py", line 251, in lambda_handler
handler = cls()
File "/var/task/handler.py", line 160, in __init__
wsgi_app_function = get_django_wsgi(self.settings.DJANGO_SETTINGS)
File "/var/task/zappa/ext/django_zappa.py", line 21, in get_django_wsgi
return get_wsgi_application()
File "/tmp/mysite/django/core/wsgi.py", line 12, in get_wsgi_application
django.setup(set_prefix=False)
File "/tmp/mysite/django/__init__.py", line 24, in setup
apps.populate(settings.INSTALLED_APPS)
File "/tmp/mysite/django/apps/registry.py", line 122, in populate
app_config.ready()
File "/tmp/mysite/core/apps.py", line 8, in ready
from core import signals
File "/tmp/mysite/core/signals.py", line 1, in <module>
import cairosvg
File "/tmp/mysite/cairosvg/__init__.py", line 26, in <module>
from . import surface # noqa isort:skip
File "/tmp/mysite/cairosvg/surface.py", line 9, in <module>
import cairocffi as cairo
File "/tmp/mysite/cairocffi/__init__.py", line 17, in <module>
from ._generated.ffi import ffi
File "/tmp/mysite/cairocffi/_generated/ffi.py", line 2, in <module>
import _cffi_backend
I use a package CairoSVG
and when disabling this, my application works again.
The weird thing is that I was using this package in previous version aswell without any problems.
when updating with zappa update dev
it shows me this:
Calling update for stage dev..
Downloading and installing dependencies..
- reportlab==3.6.6: Using locally cached manylinux wheel
- pyproj==3.3.0: Using locally cached manylinux wheel
- psycopg2-binary==2.9.3: Using locally cached manylinux wheel
'releases'
Packaging project as gzipped tarball.
I've noticed that on previous updates, there was a 4th dependency called "cffi" but is gone now.
I have no idea how it's gone and from where those dependenties come from because I have much more in my requirements.txt
Don't exactly know what went wrong but I got it fixed by:
pip install -r requirements.txt --no-cache-dir
the --no-cache-dir
was really important adding.