Gevent - SSL WSGIServer 在不应该的时候阻止



所以我正在创建一个服务器,并向它发出请求,所有这些都在同一个文件中。

这工作正常:

import gevent
import gevent.monkey
gevent.monkey.patch_all()
import requests
from gevent.pywsgi import WSGIServer
from flask import Flask

app = Flask(__name__)
app.debug = True
# Simple catch-all server
@app.route('/', defaults={'path': ''}, methods=['GET', 'POST'])
@app.route('/<path:path>', methods=['GET', 'POST'])
def catch_all(path):
    return 'It is Working!'

if __name__ == '__main__':
    http_server = WSGIServer(('', 8080), app)
    srv_greenlet = gevent.spawn(http_server.start)
    gevent.sleep(0.5)
    resp = requests.get('http://127.0.0.1:8080/')
    print resp.text
    http_server.stop()
    gevent.joinall([srv_greenlet])

输出:

(py2sni)user@host$ python question.py 
127.0.0.1 - - [2013-10-01 11:48:46] "GET / HTTP/1.1" 200 130 0.000614
It is Working!

但是这会阻止,我必须在外部终止该过程:

import gevent
import gevent.monkey
gevent.monkey.patch_all()
import requests
from gevent.pywsgi import WSGIServer
from flask import Flask

app = Flask(__name__)
app.debug = True
# Simple catch-all server
@app.route('/', defaults={'path': ''}, methods=['GET', 'POST'])
@app.route('/<path:path>', methods=['GET', 'POST'])
def catch_all(path):
    return 'It is Working!'

if __name__ == '__main__':
    http_server = WSGIServer(('', 4430), app, keyfile='server.key', certfile='server.crt')
    srv_greenlet = gevent.spawn(http_server.start)
    gevent.sleep(0.5)
    resp = requests.get('https://127.0.0.1:4430/')
    print resp.text
    http_server.stop()
    gevent.joinall([srv_greenlet])

这两个脚本的唯一区别是一个使用 SSL,另一个不使用。我在这里犯了哪里的错误?如果有帮助,我正在使用 gevent 0.13.8 并请求 2.0

问题就在这里。

它仅在使用pyopenssl和gevent/greenlet时发生。由于握手的重试没有 IO,因此控制权永远不会交给 greenlet 运行瓶,因此握手永远不会成功。

我已经在shazow/urllib3#250上为此打开了一个错误报告/拉取请求。向后移植自己或等待请求的下一个次要版本应该很简单。

相关内容

  • 没有找到相关文章

最新更新