如何解决 Google Cloud Function 上的“No module named 'frontend'”错误消息
Posted
技术标签:
【中文标题】如何解决 Google Cloud Function 上的“No module named \'frontend\'”错误消息【英文标题】:How do I resolve "No module named 'frontend'" error message on Google Cloud Function如何解决 Google Cloud Function 上的“No module named 'frontend'”错误消息 【发布时间】:2022-01-14 12:59:09 【问题描述】:我正在尝试使用 Python 3.9 部署云功能,但是当我运行时
gcloud functions deploy my_function --project my_project --runtime python39 --trigger-resource bucket_name --trigger-event google.storage.object.finalize
部署失败并出现以下错误:
Traceback (most recent call last):
File "/layers/google.python.pip/pip/bin/functions-framework", line 8, in <module>
sys.exit(_cli())
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/click/core.py", line 1128, in __call__
return self.main(*args, **kwargs)
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/click/core.py", line 1053, in main
rv = self.invoke(ctx)
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/click/core.py", line 1395, in invoke
return ctx.invoke(self.callback, **ctx.params)
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/click/core.py", line 754, in invoke
return __callback(*args, **kwargs)
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/functions_framework/_cli.py", line 37, in _cli
app = create_app(target, source, signature_type)
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/functions_framework/__init__.py", line 288, in create_app
spec.loader.exec_module(source_module)
File "<frozen importlib._bootstrap_external>", line 843, in exec_module
File "<frozen importlib._bootstrap>", line 219, in _call_with_frames_removed
File "/workspace/main.py", line 2, in <module>
import fitz
File "/layers/google.python.pip/pip/lib/python3.8/site-packages/fitz/__init__.py", line 1, in <module>
from frontend import *
ModuleNotFoundError: No module named 'frontend'
我发现了一个类似的问题here,但是如何在云功能中安装 PyMuPDF?不应该是通过requirements.txt文件自己安装吗?
这是我的目录结构:
── folder
├── main.py
├── requirements.txt
这是我的 main.py:
import numpy as np
import fitz
import os
from google.cloud import storage
def my_function()
do stuff with fitz
这是我的 requirements.txt 文件:
cachetools==4.2.4 certifi==2021.10.8 charset-normalizer==2.0.9 ci-info==0.2.0 click==8.0.3 configobj==5.0.6 configparser==5.2.0 etelemetry==0.2.2 filelock==3.4.0 fitz==0.0.1.dev2 future==0.18.2 google-api-core==2.3.0 google-auth==2.3.3 google-cloud-core==2.2.1 google-cloud-storage==1.43.0 google-crc32c==1.3.0 google-resumable-media==2.1.0 googleapis-common-protos==1.54.0 httplib2==0.20.2 idna==3.3 isodate==0.6.0 lxml==4.6.4 networkx==2.6.3 nibabel==3.2.1 nipype==1.7.0 numpy==1.21.4 packaging==21.3 pandas==1.3.4 pathlib==1.0.1 protobuf==3.19.1 prov==2.0.0 pyasn1==0.4.8 pyasn1-modules==0.2.8 pydot==1.4.2 PyMuPDF==1.19.2 pyparsing==3.0.6 python-dateutil==2.8.2 pytz==2021.3 pyxnat==1.4 rdflib==6.0.2 requests==2.26.0 rsa==4.8 scipy==1.7.3 simplejson==3.17.6 six==1.16.0 traits==6.3.2 urllib3==1.26.7 joblib~=1.1.0
我通过pip freeze> requirements.txt
创建了这个列表
【问题讨论】:
【参考方案1】:在您链接的线程中,有几种解决方案,interesting one 似乎是一个名为fitz
的包与PyMuPDF
冲突,因为它们在脚本中都使用相同的***名称(@987654325 @)。我看到这两个库都在您的requirements.txt
中,所以这可能是导致此错误的原因。我测试了在 Cloud Function 中添加这两个库并收到相同的错误,在从文件中删除 fitz 0.0.1.dev2
并仅使用 PyMuPDF
后解决了该错误。
您可以从this GitHub 问题中看到此行为的另一个示例。
【讨论】:
谢谢,我从requirements.txt
文件中删除了fitz 0.0.1.dev2
,一切正常。以上是关于如何解决 Google Cloud Function 上的“No module named 'frontend'”错误消息的主要内容,如果未能解决你的问题,请参考以下文章
同时创建多个具有私有 IP 的 Google Cloud SQL 实例时如何解决“发生未知错误”?
如何将 Google Cloud SQL 与 Google Big Query 集成
如何解决 Google Cloud [Compute Engine] 中的持续非活动计费状态并恢复暂停的 VM 实例?
如何在 Google Cloud Functions 和 Google App Engine 之间进行选择?