使用Kaggle来当作http服务器部署服务😂

18 天前(已编辑)
4
AI 生成的摘要

使用Kaggle来当作http服务器部署服务😂

刚刚去了解了一下Kaggle,一周有30h的免费GPU算力,但是是使用jupyter notebook提供服务的,我不太习惯使用notebook来使用python环境,感觉适合使用单文件代码来快速实现想法的工具,对于层级很多的工程化代码,有一股代码分割感,所以我想试试是否可以SSH连上去

可行方案

使用ngrok内网穿透将kaggle中的SSH服务器暴露出来,以下是notebook cell代码

# 1. 安装并配置ngrok
!pip install pyngrok
from pyngrok import ngrok

# 设置ngrok认证token
ngrok.set_auth_token("your_auth_token")

# 2. 启动SSH服务
!DEBIAN_FRONTEND=noninteractive apt-get install -y openssh-server
!mkdir -p /var/run/sshd

# 配置SSH服务,允许root登录并启用密码认证
!echo "root:your_password" | chpasswd
!echo 'PermitRootLogin yes' >> /etc/ssh/sshd_config
!echo 'PasswordAuthentication yes' >> /etc/ssh/sshd_config
!service ssh start

# 3. 使用ngrok暴露SSH端口
ssh_tunnel = ngrok.connect(22, "tcp")
print("SSH Tunnel:", ssh_tunnel.public_url)

# 4. 输出本地SSH连接命令
ssh_host, ssh_port = ssh_tunnel.public_url.replace("tcp://", "").split(":")
print(f"Use the following command to connect via SSH:\nssh root@{ssh_host} -p {ssh_port}")

限制

运行发现,ngrok需要绑定信用卡或者借记卡才能使用TCP端口,然而大陆的卡好像无法验证通过

使用HTTP代理服务出去

将Kaggle上的HTTP服务穿透出去

%cd ../../
%cd kaggle
%ls
%cp -r input/testfilebox /my
%cd /my
%cd fcb-fronted
!npm  install
!npm run build
%cd ../
%pip install -r requirements.txt


# 设置ngrok认证token
ngrok.set_auth_token("your token")

# 2. 使用ngrok暴露FastAPI服务的HTTP端口
http_tunnel = ngrok.connect(12345, "http")
print("Public URL:", http_tunnel.public_url)

!python main.py
  • Loading...
  • Loading...
  • Loading...
  • Loading...
  • Loading...