内容简介:今天在阿里云 ECS 上配置了一个 Jupyter Server,这样我的 iPad 就可以随时随地利用该工具写文章,撸 Python 代码了(前提是有网络的情况下)。最简单的安装和管理 Jupyter 的方式应该数Anaconda 了,这里以 Linux 操作系统为例,Python 版本为 3.7:安装完成后,你需要产生 jupyter notebook 的配置文件
今天在阿里云 ECS 上配置了一个 Jupyter Server,这样我的 iPad 就可以随时随地利用该 工具 写文章,撸 Python 代码了(前提是有网络的情况下)。
最简单的安装和管理 Jupyter 的方式应该数Anaconda 了,这里以 Linux 操作系统为例,Python 版本为 3.7:
$ wget https://repo.anaconda.com/archive/Anaconda3-2019.03-Linux-x86_64.sh $ sh ./Anaconda3-2019.03-Linux-x86_64.sh 复制代码
安装完成后,你需要产生 jupyter notebook 的配置文件
$ jupyter notebook --generate-config 复制代码
该配置文件存放在 ~/.jupyter/jupyter_notebook_config.py 下,配置该文件
# 重要,允许任何源访问该服务 c.NotebookApp.allow_origin = '*' # 第一次登陆时不弹出修改密码的提示 c.NotebookApp.allow_password_change = False # https 所需签名 c.NotebookApp.certfile = '/your/home/.jupyter/mycert.pem' c.NotebookApp.keyfile = '/your/home/.jupyter/mykey.key' # 监听 ip 和 port c.NotebookApp.ip = '127.0.0.1' c.NotebookApp.port = 8889 # 启动时不打开浏览器 c.NotebookApp.open_browser = False 复制代码
其中 allow_origin 如果不设置,会报 Blocking Cross Origin API request for /api/contents 错误。 certfile 和 keyfile 是 https 协议的签名文件路径,详见下文。
开启远程服务,需设置登录密码:
$ jupyter notebook password Enter password: **** Verify password: **** 复制代码
该密码会记录在 ~/.jupyter/jupyter_notebook_config.json 文件中,当然不可能是明文形式。
接下来我们来设置 https,这样所有交互数据便是加密的
$ cd ~/.jupyter $ openssl req -x509 -nodes -days 3650 -newkey rsa:2048 -keyout mykey.key -out mycert.pem $ jupyter notebook --certfile=mycert.pem --keyfile mykey.key 复制代码
上面的 openssl 命令会产生签名文件,该证书的过期时间是 10 年 (3650天) 后。
接下来,我们设置开机启动 jupyter lab,修改 /etc/rc.local 文件,添加以下行:
jupyter lab --allow-root --no-browser --notebook-dir=/your/workspace/ > /var/log/jupyter.log 2>&1 & 复制代码
注意修改上面的 /your/workspace 为你自己的工作路径,至此,Jupyter 部分就设置完毕了,我们同样可以执行上面的命令将其启动
$ jupyter lab --allow-root --no-browser --notebook-dir=/your/workspace/ > /var/log/jupyter.log 2>&1 & $ cat /var/log/jupyter.log [I 16:50:56.326 LabApp] JupyterLab extension loaded from /anaconda3/lib/python3.7/site-packages/jupyterlab [I 16:50:56.326 LabApp] JupyterLab application directory is /anaconda3/share/jupyter/lab [I 16:50:56.328 LabApp] Serving notebooks from local directory: /your/workspace/ [I 16:50:56.328 LabApp] The Jupyter Notebook is running at: [I 16:50:56.328 LabApp] https://127.0.0.1:8889/ [I 16:50:56.328 LabApp] Use Control-C to stop this server and shut down all kernels (twice to skip confirmation). 复制代码
最后,我们设置一下 nginx 反向代理:
server {
listen 8888;
listen [::]:8888;
ssl on;
ssl_certificate /your/home/.jupyter/mycert.pem;
ssl_certificate_key /your/home/.jupyter/mykey.key;
location / {
proxy_redirect off;
proxy_pass https://127.0.0.1:8889;
}
}
复制代码
之后你就可以在浏览器中使用 https://hostname:8888 来访问 Jupyter Lab 了。当然,最后的最后,记得设置防火墙,例如打开本文中的 8888 端口。
参考:
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
测试驱动的JavaScript开发
Christian Johansen / 赵勇、程德、凌杰、高博 / 机械工业出版社 / 2012-2-9 / 69.00元
本书是一本完整的、基于最佳实践的JavaScript敏捷测试指南,同时又有着测试驱动开发方法(TDD)所带来的质量保证。领先一步的JavaScript敏捷开发者Christian Johansen的讨论涵盖了将最先进的自动化测试用于JavaScript开发环境的方方面面,带领读者走查整个开发的生命周期,从项目启动到应用程序部署。本书的主要内容包括:掌握自动化测试和TDD;构建有效的自动化测试工作流......一起来看看 《测试驱动的JavaScript开发》 这本书的介绍吧!
CSS 压缩/解压工具
在线压缩/解压 CSS 代码
XML 在线格式化
在线 XML 格式化压缩工具