• 如何使用Docker本地部署Jupyter+Notebook容器并结合内网穿透实现远程访问



    本文主要介绍如何在Ubuntu系统中使用Docker本地部署Jupyter Notebook,并结合cpolar内网穿透工具实现任意浏览器公网远程访问本地部署的Jupyter Notebook界面。

    Jupyter Notebook是一个交互式笔记本,支持运行40多种编程语言。可以使用它来创建和共享程序文档,支持实时代码,数学方程,可视化和 markdown。具有数据清理和转换,数值模拟,统计建模,机器学习等等用途。

    要使用Docker部署Jupyter Notebook非常简单,只需要选择并拉取你想要安装的版本镜像,然后在容器中进行参数设置就可以启动容器,运行Jupyter Notebook了。

    1704872364094

    1. 选择与拉取镜像

    本文中使用的操作系统为Ubuntu,在终端中执行命令:

    如何在Ubuntu使用docker部署Jupyter Notebook并实现公网远程访问

    sudo docker search Jupyter
    
    • 1

    即可看到各种版本的Jupyter Notebook镜像,可以根据自己不同的需求选择想要安装的镜像。

    1704872704867

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

    执行命令:

    sudo docker pull jupyter/base-notebook
    
    • 1

    1704873206171

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

    执行命令:

    sudo docker images
    
    • 1

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

    1704873403426

    2. 创建容器

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

    执行命令:

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

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

    执行命令:

    sudo docker ps -a
    
    • 1

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

    1704874339782

    3. 访问Jupyter工作台

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

    http://127.0.0.1:8888
    
    • 1

    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,即可登出,之后再登录工作台就可以在顶部输入刚才设置的密码登录了。

    4. 远程访问Jupyter工作台

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

    1704877388029

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

    1704877526621

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

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

    4.1 内网穿透工具安装

    下面是安装cpolar步骤:

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

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

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

    image-20230831171159175

    4.2 创建远程连接公网地址

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

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

    点击创建

    1704879225242

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

    1704879329122

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

    1704879409719

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

    image-20240110173836900

    小结

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

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

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

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

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

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

    点击保留

    1704879970277

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

    1704880021100

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

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

    点击更新

    1704880161012

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

    1704880220608

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

    1704880312401

  • 相关阅读:
    VPN相关概念:VPN和VPS、SSR、加速器有什么区别?
    手把手教你搭建maven私有中央仓库对各种jar包管理
    现代企业杂志现代企业杂志社现代企业编辑部2022年第8期目录
    蛋白质深度学习
    Nginx反向代理
    基于Socket编程下 实现Linux-Linux、Linux-Windows tcp通信
    进一步了解视频美颜SDK:美颜SDK的技术原理
    Effective C++条款18:让接口容易被正确使用,不容易被误用
    mysql、oracle 构建数据
    【Java设计模式】第6讲--代理模式
  • 原文地址:https://blog.csdn.net/qq_25749749/article/details/136232449