【发布时间】:2019-05-30 12:16:57
【问题描述】:
尝试使用它们会给我以下错误:
Traceback (most recent call last):
File "/env/lib/python3.7/site-packages/gunicorn/arbiter.py", line 583, in spawn_worker
worker.init_process()
File "/env/lib/python3.7/site-packages/gunicorn/workers/ggevent.py", line 196, in init_process
self.patch()
File "/env/lib/python3.7/site-packages/gunicorn/workers/ggevent.py", line 75, in patch
fileno=s.sock.fileno()))
File "/env/lib/python3.7/site-packages/gevent/_socket3.py", line 114, in __init__
self._sock = self._gevent_sock_class(family, type, proto, fileno)
OSError: [Errno 92] Protocol not available: 'protocol'
python 3 环境不支持套接字吗?这就是它不起作用的原因吗?
我的应用程序在其他 Web 服务器上花费了大量时间,因此使用异步工作器对于获得良好的性能是必要的。同时我会尝试使用eventletworkers。
编辑:包括更多关于使用的上下文
app.yaml
runtime: python37
instance_class: F2
entrypoint: gunicorn -c gunicorn.conf.py -b :$PORT my_project.server:app
gunicorn.conf.py
# Recommended number of workers based on instance size:
# https://cloud.google.com/appengine/docs/standard/python3/runtime#entrypoint_best_practices
workers = 2
# Use an asynchronous worker as most of the work is waiting for websites to load
worker_class = 'gevent'
由于是在 gunicorn 发布期间,我认为应用定义上下文不会有用。但是为了完整起见,我将启动一个基本的烧瓶应用程序。比如:
my_project/server.py
from flask import Flask
from my_project.handlers import run
app = Flask(__name__)
app.register_blueprint(run, url_prefix='/run')
【问题讨论】:
-
你能举一个例子来说明你是如何使用 gevent 的吗?
-
添加了一些上下文,感谢您的快速回复!让我知道是否还有其他用处。有一个关于 gevent 工作人员的note in the appengine flex documentation,但我相信它不再相关,因为链接的问题已关闭。
-
谢谢,我可以重现这个。现在调查一下。
-
我在 gevent、应用引擎标准和 python3 中遇到了同样的错误。我也用 eventlet 作为工人类进行了测试,但它也不能正常工作。
-
是的,gunicorn 的 eventlet worker 几乎没用,因为它实际上并没有修补任何阻塞调用(参见 github.com/benoitc/gunicorn/pull/1884)。我们最终只是切换到了 appengine flex(出于其他原因),这让我们现在可以使用 gevent worker。如果您想查看我们的设置,请查看
prod.yaml、gunicorn.conf.py和gevent_grpc_worker.py此处:github.com/Recidiviz/pulse-data
标签: google-app-engine gunicorn gevent google-app-engine-python