我有一个在 nginx/uwsgi 上运行的 django 应用程序。我们最近开始对所有连接使用 SSL。自从迁移到 SSL 后,我经常收到以下消息:
HTTPSConnectionPool(host='foobar.com', port=443):
Max retries exceeded with url: /foo/bar
基本上发生的事情是我让浏览器与 django 服务器代码通信,然后使用 requests 库调用 api。它与生成错误的 api 的连接。此外,我已将所有请求移至一个会话(即请求会话),但这并没有帮助。
因为我认为这可能是问题所在,所以我增加了 uwsgi 侦听器的数量,但我们的负载并没有那么高。此外,在 SSL 之前我们从未遇到过这个问题。有没有人对如何解决这个问题有一些建议?
编辑
我如何调用 API 的代码片段。我已经(大部分)逐字发布。注意它不是实际失败的代码,而是调用时抛出异常的请求库self.session.post
def save_answer(self):
logger.info("Saving answer to question")
url = "%s1.0/exam/learneranswer/" % self.api_url
response = {'success': False}
data = {'questionorder': self.request.POST.get('questionorder'),
'paper': self.request.POST.get('paper')}
data['answer'] = ",".join(self.request.POST.getlist('answer'))
r = self.session.post(url, data=simplejson.dumps(data))
if r.status_code == 201:
logger.info("Answer saved successfully")
response['success'] = True
elif r.status_code == 400:
if r.text == "Paper expired":
logger.warning("Timer has expired")
response['message'] = 'Your time has run out'
if r.text == "Question locked":
response['message'] = \
'This question is locked and cannot be answered anymore'
else:
logger.error("Unknown error")
self.log_error(r, "Unknown Error while saving answer")
else:
logger.error("Internal error")
self.log_error(r, "Internal error in api while saving answer")
return simplejson.dumps(response)