我用的是mobaxterm
先打开本地窗口,输入:
bash
ssh -J 你的用户名@gate1的IP(跳板机) 你的用户名@服务器地址 -L 8888:localhost:8888
-
L即,local,格式是 -L [你本地电脑的监听端口] : [从远程服务器的视角看,目标的IP] : [目标的端口]
-
本地监听端口 是在浏览器中打开jupyter时需要输入的,类似一个门牌号,意思是谁打开这扇门,就将谁的数据送进隧道,
中间这个目标服务器IP输入的是 localhost,这是基于目标服务器的视角来看,数据从隧道传过来后,将他转交给谁?转交给jupyter,而jupyter就在目标服务器本身,因此对于目标服务器来说,接收方就是自己-即localhost-或者127.0.0.1
右边的目标端口是在服务器页面输入jupyter时指定的port。即最开始在jupyter中建立的房间,然后隧道出口精准对准这个房间,将数据递给里面的jupyter。
总体是:现在目标服务器中建立jupyter的8888房间,然后我从本地连接到跳板机,通过-J 跳到目标服务器上,我在本地建立入口8888,将数据传到隧道通向目标服务器,然后目标服务器靶向jupyter的8888端口,将数据传输给jupyter(localhost)。
然后就连接到服务器了
可以改为:ssh -J 你的用户名@跳板机 你的用户名@目标服务器 - L 8888:localhost:9999,,即你在本地依然敲自己熟悉的 8888 门,但隧道会自动拐弯,帮你把数据送到服务器上 Jupyter 新搬去的 9999 房间。浏览器里依然输入
http://localhost:8888,丝毫不受影响!,但在输入jupyter notebook的时候需要指定--port 9999。
再在服务器中开一个screen窗口
bash
screen -ls
screen -S scprint
在该窗口中激活能跑jupyter的conda环境后,执行
bash
jupyter notebook --no-browser --port=8888
然后在本地浏览器中打开网址,Home Page - Select or create a notebook
http://localhost:8888/tree?
然后在该页面,即scprint的screen中输出 ctrl+A+D,即退出screen窗口,回到原始服务器中,然后这个screen窗口就一直在后台运行中,下次打开只需要:
在本地中连接到服务器:
bash
ssh -J 你的用户名@gate1的IP(跳板机) 你的用户名@服务器地址 -L 8888:localhost:8888
然后直接打开本地浏览器输入:http://localhost:8888,昨天没跑完的代码、没画完的图,全都在!
如果想查看jupyter的状态,可以Attach到昨天打开的screen窗口:
bash
screen -r scprint
(ง •_•)ง