写这篇博客的初衷是:台式机上有GPU,想可以远程访问台式机的jupyter服务器,从而可以在笔记本上远程使用台式机的GPU来做深度学习
阿里云云工开物计划可以领取300元优惠券,经过实测,可以免费购买轻量应用服务器中的新加坡服务器1年,如下图所示,这里我选择系统镜像为 Ubuntu20.04
参考链接 ubuntu下添加新用户
启动云服务器,默认使用admin用户,这里新创建一个用户
sudo useradd -r -m -s /bin/bash your_user_name
其中参数的意义如下:
-r:建立系统账号
-m:自动建立用户的登入目录
-s:指定用户登入后所使用的shell
在 Ubuntu20.04 中,不会在创建用户的时候自动提示设置密码,需要使用以下命令来设置
sudo passwd your_user_name
输入 ls /home/
查看用户是否成功创建,输入 su your_user_name
即可切换用户
ubuntu20.04
,架构为 x86_64
,因此选择 frp_0.50.0_linux_amd64
wget https://github.com/fatedier/frp/releases/download/v0.50.0/frp_0.50.0_linux_amd64.tar.gz tar zxvf frp_0.50.0_linux_amd64.tar.gz cd frp_0.50.0_linux_amd64
frps
和 frps.ini
,我们可以通过修改 frps.ini
来配置功能vim frps.ini
将该文件内容按照下面的格式修改
[common] bind_port = 7000 dashboard_port = 7500 token = 12345678 dashboard_user = admin dashboard_user = admin vhost_http_port = 10080 vhost_https_port = 10443
- 端口均可使用默认值(也可以自定义),token、dashboard_user 和 dashboard_user 项请自行设置。
- bind_port:表示用于客户端和服务器端连接的端口,这个端口号之后在配置客户端的时候要用到
- dashboard_port:是服务器端仪表板的端口,若使用7500端口,在配置完成服务启动后可以通过浏览器访问
x.x.x.x:7500
(其中x.x.x.x
为云服务器的IP)查看frp服务的运行信息- token:是用于客户端和服务端连接的口令,请自行设置并记录,稍后会用到
- dashboard_user 和 dashboard_pwd 表示打开仪表板页面登录的用户名和密码,自行设置即可
- vhost_http_port 和 vhost_https_port 用于反向代理HTTP主机时使用,本文不涉及,因而照抄或者删除这两条均可
./frps -c frps.ini
bind_port
和 dashboard_port
,这里为 7000
和 7500
,如下所示x.x.x.x:7500
并使用自己设置的用户名密码登录,即可看到仪表板界面Ctrl+C
退出 frps,接下来按照下列步骤将 frps 设置为开机自启动
修改 rc-local.service
文件
sudo vim /lib/systemd/system/rc-local.service
在文件的最后面添加 [Install] 段的内容,如下所示
[Unit] Description=/etc/rc.local Compatibility Documentation=man:systemd-rc-local-generator(8) ConditionFileIsExecutable=/etc/rc.local After=network.target [Service] Type=forking ExecStart=/etc/rc.local start TimeoutSec=0 RemainAfterExit=yes GuessMainPID=no #这一段原文件没有,需要自己添加 [Install] WantedBy=multi-user.target Alias=rc-local.service
创建 /etc/rc.local
,Ubuntu 20.04 默认不存在 /etc/rc.local
,需要自己创建
sudo vim /etc/rc.local
向该文件中添加要执行的命令,如下所示
#!/bin/bash # 将你需要执行的命令写在这里,禁止写入死循环命令 frps的绝对路径 -c frps.ini的绝对路径 exit 0
修改 /etc/rc.local
权限
sudo chmod 777 /etc/rc.local
启动 rc-local.service
sudo systemctl enable rc-local.service
检查服务状态:使用 sudo systemctl status rc-local.service
查看 rc-local
服务的状态, 显示 loaded 和 enabled 即可
接下来重启云服务器,访问 x.x.x.x:7500
查看 frps 是否正常运行
因为我需要可以远程访问台式机上的 jupyter,因此台式机就是这里说的客户端。由于台式机上安装了Windows 和 Ubuntu20.04 双系统,因此下面分别按照这两个系统进行示例
frpc
和 frpc.ini
,我们可以通过修改 frpc.ini
来配置功能,如下所示[common] server_addr = x.x.x.x server_port = 7000 token = 12345678 [smb] type = tcp local_ip = 127.0.0.1 local_port = 445 remote_port = 7001 [jupyter] type = tcp local_ip = 127.0.0.1 local_port = 8888 remote_port = 7002 [ssh] type = tcp local_ip = 127.0.0.1 local_port = 22 remote_port = 7003
[common]
字段下的三项为服务端的设置server_addr:为服务端IP地址,填入即可
server_port:为服务器端口,填入你设置的端口号即可,如果未改变就是7000
token:是你在服务器上设置的连接口令,原样填入即可
frp 实际使用时,会按照端口号进行对应的转发,原理如下所示
frpc.ini
的[smb]
、[jupyter]
和[ssh]
字段都是自己定义的规则,自定义端口的格式如下:[xxx]:表示一个规则名称,自己定义,便于查询即可
type:表示转发的协议类型,有TCP和UDP等选项可以选择,如有需要请自行查询frp手册
local_port:是本地应用的端口号,按照实际应用工作在本机的端口号填写即可
remote_port:是该条规则在服务端开放的端口号,自己填写并记录即可
SMB,Windows文件共享所使用的协议,默认端口号445,协议TCP,因此规则
[smb]
可实现远程文件访问jupyter 默认工作在端口
8888
,因此规则[jupyter]
可以实现远程访问 jupyter 服务器
接下来需要在云服务器端配置防火墙,开放 7001
、 7002
和 7003
这三个端口
完成配置后,使用命令行运行 frpc.exe
即可,输出如下所示
可以通过 Windows 的任务计划程序实现 frpc
开机自启动,具体可以搜索网上教程,关键的一步如下所示
确保电脑已经开启共享文件夹,有关教程自行搜索,在手机上安装软件 Solid Explorer
(ES文件浏览器应该也可以)来远程访问电脑上的文件
在 Solid Explorer
中新建云连接,选择连接类型为 LAN/SMB
,输入如下信息,远程主机名填云服务器的IP地址,端口填 7001
(即上面配置的remote_port)
按照流程输入有关信息即可连接
Windows安装SSH可以参考教程:Windows 10 开启ssh服务
VScode上可以安装拓展 Remote - SSH
来远程连接,需要注意的是,输入的命令为 ssh YourUserName@YourServerIP -p 7003
默认情况下 jupyter 不支持密码登录,可以按照下面的步骤开启
Anaconda Prompt
,执行下面的命令来生成一个配置文件,注意记住配置文件路径jupyter notebook --generate-config
jupyter notebook password
进入上面的 json
文件路径,打开 jupyter_notebook_config.json
配置文件,复制 password
对应的密文
然后打开上面 jupyter_notebook_config.py
配置文件,添加以下参数后保存
c.NotebookApp.ip='*' #允许访问的IP地址,设置为*代表允许任何客户端访问 c.NotebookApp.password = u'你的密文'#刚才生成密码时上面复制的密文 c.NotebookApp.open_browser = False c.NotebookApp.port = 8888 #可自行指定一个端口, 访问时使用该端口 c.NotebookApp.allow_remote_access = True c.NotebookApp.notebook_dir = 'Your Work Dir'
接下来在 Anaconda Prompt
中输入 jupyter notebook
启动 jupyter
,或者直接启动 jupyter
也可以
接下来在其他设备(如笔记本)上输入 x.x.x.x:7002
(即云服务器IP地址和上面配置的remote_port),查看是否可以远程访问 jupyter
Jupyter Lab是Jupyter的一个拓展,它提供了更好的用户体验,例如可以同时在一个浏览器页面打开编辑多个Notebook,Ipython console和terminal终端,并且支持预览和编辑更多种类的文件,如代码文件,Markdown文档,json,yml,csv,各种格式的图片,vega文件(一种使用json定义图表的语言)和geojson(用json表示地理对象),还可以使用Jupyter Lab连接Google Drive等云存储服务,极大得提升了生产力。
用 conda 安装 JupyterLab
conda install -cconda-forge jupyterlab # 如果出现类似下面的报错,可以修改 anaconda 安装目录的权限 # EnvironmentNotWritableError: The current user does not have write permissions to the target environment. # environment location: /usr/local/anaconda3 # sudo chown -R YOUR_USER_NAME /usr/local/anaconda3
使用浏览器打开 your_jupyter_server/lab/workspaces/auto-a
即可
使用 Anaconda
创建环境并激活
conda create -n env_1 python=3.7 conda activate env_1
在 env_1
环境下安装 ipykernel
conda install -n env_1 ipykernel --update-deps --force-reinstall
将该环境写入到notebook的kernel中
python -m ipykernel install --user --name env_1 --display-name "env_1"
可以通过下面的命令来查看 jupyter 存在的 kernel
jupyter kernelspec list
如果想删除 env_1 虚拟环境,可通过下面的命令
jupyter kernelspec remove env_1
VSCode 在安装拓展 Jupyter
、Jupyter Keymap
和 Jupyter Notebook Renderers
后,打开 ipynb 文件后可以选择远程的 jupyter
服务器。
需要注意的是,此时代码运行的工作目录是远程 jupyter
服务器的工作目录,可以通过 !chdir
来查看。所有 ipynb 文件中读取或者保存的数据,都是相对远程 jupyter
服务器的工作目录而言的,而不是本机中 ipynb 文件的目录。
待续。。。