基于 Go 实现的 OpenAI API HTTP 代理
想要快速体验,将 OpenAI API 调用域名从默认的
api.openai.com
调整为open.aiproxy.xyz
即可。你可以在这里看演示效果:https://chat.geekr.dev。
./build.sh
如果不想本地安装 go 环境进行编译打包,可以直接下载根据最新源代码编译打包好的 main.zip
:https://storage.gstatics.cn/chat/main.zip
支持部署到腾讯/阿里云函数、AWS lambda 函数以及任意云服务器,以下以腾讯云函数为例进行演示。
然后在腾讯云云函数代码管理界面上传打包好 zip 包即可完成部署:
你可以通过腾讯云云函数提供的测试工具进行测试,也可以本地通过 curl/postman 进行测试,使用的时候只需要将 api.openai.com
替换成代理域名 open.aiproxy.xyz
即可:
你可以选择自己搭建,也可以直接使用我提供的代理域名 open.aiproxy.xyz
,反正是免费的。关于代理背后的原理,可以看我在极客书房发布的这篇教程:国内无法调用 OpenAI 接口的解决办法。
本地调试走VPN的话可以设置环境变量 ENV=local
,然后直连 api.openai.com
:
// 本地测试通过代理请求 OpenAI 接口
if os.Getenv("ENV") == "local" {
proxyURL, _ := url.Parse("http://127.0.0.1:10809")
client.Transport = &http.Transport{
Proxy: http.ProxyURL(proxyURL),
TLSClientConfig: &tls.Config{InsecureSkipVerify: true},
}
}
这个源代码本身是支持 stream 流式响应代理的,但目前腾讯云函数并不支持分块流式传输。所以,如果你需要实现流式响应,可以把编译后的二进制文件 main
丢到任意海外云服务器运行,这样就变成支持流式响应的 OpenAI HTTP 代理了,如果你不想折腾,可以使用我这边提供的 open.aiproxy.xyz
作为代理进行测试:
如果你是通过 Nginx 这种反向代理对外提供服务,记得通过如下配置项将默认缓冲和缓存关掉才会生效:
proxy_buffering off;
proxy_cache off;