场景复现
代码如下(源自网络):
import openai
openai.api_key = 'sk-xxxx'
def chat_gpt(prompt):
prompt = prompt
model_engine = "text-davinci-003"
completion = openai.Completion.create(
engine=model_engine,
prompt=prompt,
max_tokens=1024,
n=1,
stop=None,
temperature=0.5,
timeout=1000,
)
response = completion.choices[0].text
print(response)
chat_gpt("现在几点了")
执行报错:
APIConnectionError: Error communicating with OpenAI: HTTPSConnectionPool(host='api.openai.com', port=443): Max retries exceeded with url: /v1/chat/completions (Caused by SSLError(SSLEOFError(8, 'EOF occurred in violation of protocol (_ssl.c:1125)')))
解决办法
1、urllib3降低版本到1.25.11
pip install urllib3==1.25.11
参考大佬文章:传送门
简单来说就是1.26.0版本的urllib3添加了HTTPS支持,但代理服务器不支持HTTPS,所以报错(pip走代理报错也差不多类似原因,具体请参考上文,有详细解读)
这个方法对部分人有用,但很不幸我是另一部分(哭)!
2、修改openai源码(亲测成功)
查看堆栈找到报错库的路径:
打开api_requestor.py,找到:
if not hasattr(_thread_context, "session")
分别在它上面和下面添加以下两行:
proxy = {
'http': 'http://localhost:7890',
'https': 'http://localhost:7890'
}
proxies=proxy
保存搞定,重新运行代码:
3、代码里设置环境变量(亲测成功)
添加以下代码:文章来源:https://www.toymoban.com/news/detail-458557.html
import os
os.environ["http_proxy"] = "http://localhost:7890"
os.environ["https_proxy"] = "http://localhost:7890"
以上解决办法均来自网络,我只是个搬运工兼汇总~文章来源地址https://www.toymoban.com/news/detail-458557.html
到了这里,关于OpenAI调用API报错 time out:HTTPSConnectionPool(host=‘api.openai.com‘, port=443)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!