Jupyter Notebook远程代码魔术师:cpolar内网穿透实验室第524个成功挑战

在这里插入图片描述

软件名称:Jupyter Notebook

操作系统支持:

  • 硬件平台:Windows/macOS/Linux(安装Python环境即可)
  • 客户端兼容性:浏览器访问,手机/平板秒变“云工作站”

软件介绍

Jupyter就像一个会写作文的程序员——一边敲代码、一边配文字解释、还能画图表,简直是“代码界的PPT”。它能玩Python/R/Julia等40+语言,支持实时运算,适合数据分析、机器学习建模、教学演示。

在这里插入图片描述

Jupyter Notebook的出色功能

“代码游乐场+文档神器=效率倍增”

  • 魔法笔记本:一行代码+一段文字+一张图,像写日记一样记录思路。
  • 实时演算:敲完代码立刻看结果,数学公式直接渲染(再也不用对着Excel发呆)。
  • 多人协作:团队共享Notebook链接,边改代码边唠嗑(比微信批注优雅多了)。

在这里插入图片描述

实用场景——谁说内网是牢笼?

场景1:学生党深夜赶作业

  • 痛点:“在宿舍写Python代码到崩溃,回寝室还要重装环境?”
  • 爽点:用cpolar把Jupyter“搬”上云端,在图书馆/便利店随时继续战斗!

场景2:跨城市团队协作

  • 痛点:“A在上海跑数据,B在北京等结果,C在纽约改代码——沟通成本比数据还大!”
  • 爽点:共享cpolar链接,三地同事同时编辑同一个Notebook,像开视频会议一样“远程写代码”。

在这里插入图片描述

cpolar内网穿透把Jupyter变成随身笔记本的秘诀

  1. 零配置上云:不用申请公网IP或折腾服务器,一条命令让Notebook秒变可访问网页。
  2. 安全加密:给链接加个密码,别人找不到你的代码“小秘密”。
  3. 手机端友好:地铁上刷手机就能看模型结果(虽然可能手抖敲错字)。
  4. 兼容性无敌:Jupyter的Python环境、GPU加速?CPolar直接穿透不卡顿。
为代码安上自由的翅膀

Jupyter是程序员的“瑞士军刀”,但它的局限性就像被关在笼子里的鸟。加上CPolar这根“魔法杖”,就能让它飞向任何角落!无论是远程办公、在线教学,还是和队友隔空写代码,这套组合拳让“本地限制”彻底退休!
在这里插入图片描述

下面就是详细的安装流程,请参阅。

本文中使用的操作系统为Ubuntu 22.04

1. 安装Docker步骤

添加Docker源

# Add Docker's official GPG key:
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg
sudo install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /etc/apt/keyrings/docker.gpg

# Add the repository to Apt sources:
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
  $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
  sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update

安装 Docker 包

sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

通过运行映像来验证 Docker 引擎安装是否成功

sudo docker run hello-world

此命令下载测试映像并在容器中运行它。当容器运行,它打印确认消息并退出。

2. 选择与拉取镜像

本教程中我们以jupyter/base-notebook这个基础版本镜像为例,进行镜像拉取。

执行命令:

sudo docker pull jupyter/base-notebook

1704873206171

执行命令后稍等一会儿就可以看到jupyter/base-notebook镜像已经拉取完毕。

执行命令:

sudo docker images

可以看到本地所有镜像,其中就有刚才拉取的jupyter/base-notebook镜像。

1704873403426

3. 创建容器

在拉取了Jupyter镜像后,我们就可以使用Docker创建容器来运行Jupyter Notebook了。

执行命令:

sudo docker run -d -p 8888:8888 jupyter/base-notebook

即可创建一个在后台运行的名为jupyter的容器,并将本地端口8888映射到容器的8888端口。

执行命令:

sudo docker ps

可以看到容器已经成功运行了。

1704874339782

4. 访问Jupyter工作台

此时,我们在浏览器中输入本机ip地址加端口即可访问Jupyter工作台:

http://127.0.0.1:8888

1704876066962

可以看到,顶部显示我们需要输入密码或者token进行登录。

token获取可以在终端中执行命令sudo docker logs 你的Jupyter容器id进行查看:

1704876294919

在显示的信息底部,可以看到一长串的字符构成的token,下图红框中67f4开头,ec38结尾的这个即是。

1704876361155

将这串字符复制下来,回到刚才打开的浏览器中进行粘贴:

1704876453420

点击log in登录,即可进入Jupyter工作台:

1704876568036

如上图显示,则表示已经成功登录。

不过由于token不方便记忆,所以可以登出后重新登录界面,使用token来设置或修改密码,之后即可使用密码登录。

1704876901474

确认后,会自动跳转到工作台界面:

1704877136738

点击功能导航中的File,选择Log Out,即可登出,之后再登录工作台就可以在顶部输入刚才设置的密码登录了。

5. 远程访问Jupyter工作台

现在,我们可以在本地使用浏览器登录使用Docker部署的Jupyter工作台了。

1704877388029

在工作台中选择Notebook下的Python3(ipykernel),即可创建一个.ipynb文件,开始愉快的使用Jupyer Notebook了。

1704877526621

不过我们只能在本地使用刚刚部署的Jupyer Notebook,如果身在异地,想要远程访问在本地部署的Jupyer Notebook容器,但又没有公网ip怎么办呢?

我们可以使用cpolar内网穿透工具来实现无公网ip环境下的远程访问需求。

5.1 内网穿透工具安装

下面是安装cpolar步骤:

cpolar官网地址: https://www.cpolar.com

  • 使用一键脚本安装命令
curl -L https://www.cpolar.com/static/downloads/install-release-cpolar.sh | sudo bash
  • 向系统添加服务
sudo systemctl enable cpolar
  • 启动cpolar服务
sudo systemctl start cpolar

cpolar安装成功后,在外部浏览器上访问Linux 的9200端口即:【http://服务器的局域网ip:9200】,使用cpolar账号登录,登录后即可看到cpolar web 配置界面,结下来在web 管理界面配置即可。

image-20230831171159175

5.2 创建远程连接公网地址

登录cpolar web UI管理界面后,点击左侧仪表盘的隧道管理——创建隧道:

  • 隧道名称:可自定义,注意不要与已有的隧道名称重复,本例使用了:jup
  • 协议:http
  • 本地地址:8888
  • 域名类型:随机域名
  • 地区:选择China Top

点击创建

1704879225242

创建成功后,打开左侧在线隧道列表,查看刚刚创建隧道后生成两个公网地址,接下来就可以在其他电脑(异地)上,使用任意一个地址复制到浏览器访问即可。

1704879329122

可以看到,能够正常公网远程访问。

1704879409719

输入密码后即可实现在公网远程登录本地内网部署的Jupyer Notebook工作台界面。

image-20240110173836900

小结

为了方便演示,我们在上边的操作过程中使用了cpolar生成的http公网地址隧道,其公网地址是随机生成的。

这种随机地址的优势在于建立速度快,可以立即使用。然而,它的缺点是网址是随机生成,这个地址在24小时内会发生随机变化,更适合于临时使用。

如果有长期远程访问Jupyter Notebook的需求,但又不想每天重新配置公网地址,还想地址好看又好记,那我推荐大家选择使用固定二级子域名地址的方式来远程访问。

5.3 使用固定二级子域名地址远程访问

接下来保留一个固定http地址,登录cpolar官网,点击左侧的预留,找到保留二级子域名,为远程服务器连接保留一个固定二级子域名地址:

  • 地区:选择China VIP
  • 描述:即备注,可自定义,本例使用jup123

点击保留

1704879970277

地址保留成功后,复制生成的公网地址,打开cpolar web ui管理界面,点击左侧仪表盘的隧道管理——隧道列表,找到我们刚才创建的随机公网地址隧道 jup,点击编辑

1704880021100

修改隧道信息,将刚才保留成功的固定http地址:jup123 配置到隧道中

  • 域名类型:选择二级子域名
  • 预留的http地址:复制粘贴官网保留成功的地址,本例中为:jup123
  • 地区选择:China VIP

点击更新

1704880161012

隧道更新成功后,点击左侧仪表盘的状态——在线隧道列表,可以看到公网地址已经更新为了两个固定二级子域名地址。

1704880220608

接下来与之前的操作一样,可以在其他电脑(异地)上,使用任意一个固定二级子域名地址复制到浏览器访问即可。

1704880312401

如上图所示,即为配置成功。我们现在就能在公网使用cpolar内网穿透工具生成的永久不变的固定二级子域名,使用任意浏览器远程访问Jupyter Notebook工作台了,无需购买域名服务器,也不用设置路由器那么麻烦,轻松实现大家远程访问本地服务的需求!

通过Jupyter Notebook、Docker容器化部署与cpolar内网穿透技术的协同应用,开发者能够构建出既安全可靠又高度灵活的工作流。无论是远程教学场景下的实时代码演示,还是分布式团队的模型迭代协作,这种组合方案都展现了强大的生产力提升潜力——它不仅是工具链的简单叠加,更是现代开发范式下资源管理与网络访问的最佳实践。

cpolar官网-安全的内网穿透工具 | 无需公网ip | 远程访问 | 搭建网站

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值