您现在的位置是:首页 > 技术教程 正文

OpenAI调用API报错 time out:HTTPSConnectionPool(host=‘api.openai.com‘, port=443)

admin 阅读: 2024-03-25
后台-插件-广告管理-内容页头部广告(手机)

场景复现

代码如下(源自网络):

  1. import openai
  2. openai.api_key = 'sk-xxxx'
  3. def chat_gpt(prompt):
  4. prompt = prompt
  5. model_engine = "text-davinci-003"
  6. completion = openai.Completion.create(
  7. engine=model_engine,
  8. prompt=prompt,
  9. max_tokens=1024,
  10. n=1,
  11. stop=None,
  12. temperature=0.5,
  13. timeout=1000,
  14. )
  15. response = completion.choices[0].text
  16. print(response)
  17. 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")

分别在它上面和下面添加以下两行:

  1. proxy = {
  2. 'http': 'http://localhost:7890',
  3. 'https': 'http://localhost:7890'
  4. }
  5. proxies=proxy

 保存搞定,重新运行代码:

3、代码里设置环境变量(亲测成功)

添加以下代码:

  1. import os
  2. os.environ["http_proxy"] = "http://localhost:7890"
  3. os.environ["https_proxy"] = "http://localhost:7890"

以上解决办法均来自网络,我只是个搬运工兼汇总~

标签:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

在线投稿:投稿 站长QQ:1888636

后台-插件-广告管理-内容页尾部广告(手机)
关注我们

扫一扫关注我们,了解最新精彩内容

搜索