这个仓库是 Fast Reverse Proxy (FRP) 的一个分支,运行在 Gradio 的共享服务器上,用于启用 Gradio 的共享链接。以下是如何设置自己的共享服务器以生成自定义共享链接的说明 🔥
当你创建一个 Gradio 应用并通过 share=True
启动它时,如下所示:
import gradio as gr app = gr.Interface(lambda x: x, "image", "image") app.launch(share=True)
你会得到一个类似 https://07ff8706ab.gradio.live
的共享链接,你的 Gradio 应用现在可以通过互联网被任何人访问(最多 72 小时)。
这是如何实现的? 你的 Gradio 应用在本地运行在 Python 服务器上,但我们使用 FRP 将本地服务器暴露给互联网。FRP 由两部分组成:
FRP 客户端从你的本地机器建立到 FRP 服务器的连接,FRP 服务器可以在互联网上访问。然后 FRP 服务器提供一个公共 URL,将传入的请求转发到 FRP 客户端,后者再将请求发送到你本地运行的 Web 应用。
你可能出于以下几个原因想要运行自己的服务器:
*.gradio.live
这也相当简单。在你的 Gradio 应用中,你只需要在 launch()
中传入共享服务器的 IP 地址作为 share_server_address
参数:
import gradio as gr app = gr.Interface(lambda x: x, "image", "image") app.launch(share=True, share_server_address="my-gpt-wrapper.com:7000")
瞧!
Running on public URL: http://07f56cd0f87061c8a1.my-gpt-wrapper.com
t2-small
)应该足够了,我们建议至少有 2 GB 的 RAM 和 8 GB 的磁盘空间。你需要能够 SSH 到你的服务器。重要:不仅是根域名,所有子域名都应该路由到你服务器的 IP 地址。这通常意味着你应该在 DNS 记录中有一个通配符条目,如这里最下面的条目所示:
<img width="1354" alt="image" src="https://github.com/huggingface/frp/assets/1778297/3b2335bc-3422-4d4f-b0ea-c84b93cc0d07">你可以在 SSH 到服务器后,在终端中依次运行这些命令(本指南假设你运行的是 Ubuntu):
sudo apt update
sudo apt install apt-transport-https ca-certificates curl software-properties-common
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu focal stable"
apt-cache policy docker-ce
sudo apt install docker-ce
通过在终端中运行 docker version
确认已安装 Docker 并且运行的版本是 20.10
或更高。你应该看到类似这样的内容:
Client: Docker Engine - Community
Version: 24.0.6
...
git clone git@github.com:huggingface/frp.git
cd frp
打开 scripts/frps.ini
文件,编辑 subdomain_host
属性的值以反映你的域名(不带任何前缀)。
你还可以设置 bind_port
,这是用于 FRP 连接的默认端口,可以设置为 7000
以外的值,或自定义 404 页面(custom_404_page
),当没有活动的 Gradio 应用连接到共享服务器时会显示该页面。
这里是一个自定义的 .ini
文件示例:
[common] log_level = trace tcp_mux = true bind_port = 7000 dashboard_port = 7001 vhost_http_port = 80 subdomain_host = my-gpt-wrapper.com detailed_errors_to_client = false custom_404_page = /etc/frp/my-404.html
注意:如果你想更改共享链接的过期时间(默认为 72 小时),也要编辑 server/control.go
中的这一行。
注意:这些命令可能需要 sudo
权限:
docker build -f dockerfiles/Dockerfile-for-frps -t frps:0.2 .
docker run --log-opt max-size=100m --memory=1G --cpus=1 --name frps3 -d --restart unless-stopped --network host -v ~/frp/scripts:/etc/frp frps:0.2 -c /etc/frp/frps.ini
为了确保用户可以连接到你的共享服务器,你需要确保在正确的端口允许流量。你需要允许:
7000
(或你在第 3 步中选择的 bind_port
)80
443
注意:如果你愿意,你可以将前者规则的 IP 地址限制为那些应该能够创建共享链接的人,并将后两个规则的 IP 地址限制为那些应该能够查看共享链接的用户。
如果你使用的是 AWS,你的安全规则可能看起来像这样:
<img width="1214" alt="image" src="https://github.com/huggingface/frp/assets/1778297/93760bbb-f10e-47f7-9b7e-2399a743a357">就是这样!你现在有了自己的小共享服务器!如前所述,你可以通过在 launch()
中将 IP 地址和 FRPS 端口作为单个字符串传递给 share_server_address
参数来使用它,如下所示:
import gradio as gr app = gr.Interface(lambda x: x, "image", "image") app.launch(share=True, share_server_address="my-gpt-wrapper.com:7000")
注意:如果你在共享服务器上安装了 HTTPS 证书,并且你的共享链接通过 HTTPS 提供服务,那么你还应该在 launch()
中设置 share_server_protocol="https"
。
AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。
一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
AI办公助手,复杂任务高效处理
AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!
AI辅助编程,代码自动修复
Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。
AI小说写作助手,一站式润色、改写、扩写
蛙蛙写作—国内先进的AI写作平台,涵盖小说、学术、社交媒体等多场景。提供续写、改写、润色等功能,助力创作者高效优化写作流程。界面简洁,功能全面,适合各类写作者提升内容品质和工作效率。
全能AI智能助手,随时解答生活与工作的多样问题
问小白,由元石科技研发的AI智能助手,快速准确地解答各种生活和工作问题,包括但不限于搜索、规划和社交互动,帮助用户在日常生活中提高效率,轻松管理个人事务。
实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。
一键生成PPT和Word,让学习生活更轻松
讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。
深度推理能力全新升级,全面对标OpenAI o1
科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。
一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型
Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。
最新AI工具、AI资讯
独家AI资源、AI项目落地
微信扫一扫关注公众号