--- layout : post title : "Jupyter——Code, note and data presentation platform" subtitle : "代码,笔记以及数据展示平台" date : 2022-09-09 08:48:32 author : "Manford Fan" catalog : false header-img : "img/post-bg-universe.jpg" tags : - Python - Jupyter - Ipython --- 距离上次记录已经有两个月的时间了,这是艰难的两个月,中间发生了很多很多事情,搞得整个人身心俱疲。好在时间是最好的医生,可以抚平所有的不快乐,也能让人看清楚现实,拍拍屁股,继续向前走。很早之前就听说过Jupyter,之前LY上课的时候说老师推荐他们用这个,前段时间支援ECX的时候,LYB也在自己的黑群晖上建了一个给我用,当时我还是用不习惯,说还是PyCharm好用,直到现在也觉得PyCharm好用,只不过在不同应用场景下,Jupyter优势还是很明显的。 ## 一、Jupyter Notebook/Lab 简介 Jupyter Notebook: 经典的笔记交互界面。Jupyter Notebook是最原始的网页应用,它被用来创建和分享计算标注文档,并提供简洁,易于理解的以为当为中心的代码体验。其可被应用于全过程计算:开发、文档编写、运行代码和展示结果。 Jupyter Lab: 下一代的笔记交互界面。Jupyter Lab是最新的基于网页的用于交互计算的应用程序,它可以是笔记,代码和数据融合的交互式开发环境。这种灵活的交互界面允许用户按照自己的习惯来进行大数据分析,科学计算,机器学习的流程按安排和配置。符合潮流的模块化设计,使得Jupyter Lab具有丰富的功能和高度的可扩展性。 由此可见,Jupiter Lab是Jupiter Notebook的升级版,前者是后者的超集,而且官方也明确说后续会使用前者替代后者,所以一步到位,这次我们使用Jupyter Lab作为工作环境。 ## 二、安装在线服务 安装Jupyter Lab在线服务分为环境准备,服务安装以及多用户配置是三个部分,其中服务安装配置完成之后,可以直接使用IP:Port的形式直接访问,也可以使用Nginx做一个反向代理,让该服务以域名的形式出现,显得更加简洁。 #### 1. 环境准备 这里主要准备了Python3的运行环境,升级更新了*pip*和*setuptools*这两个系统工具(不更新有可能会报错);另外安装过程中可能会提示如下不建议使用root账号来使用*pip*的建议,这里也选择了忽略,个人环境无所谓,企业环境中还是最好使用非root账号;在一个就是需要安装*ipython*,因为无论是notebook还是lab环境用的都是*ipython*。 > WARNING: Running pip as the 'root' user can result in broken permissions and conflicting behaviour with the system package manager. It is recommended to usea virtual environment instead: https://pip.pypa.io/warnings/venv ```bash apt install python3-pip python3-dev pip3 install --upgrade setuptools pip3 install --upgrade pip pip3 install ipython ``` #### 2. 服务安装与配置 以*jupyterlab*为例,安装的过程是很简单的,但是可能会需要点时间,安装完成之后需要设定密码,生成配置文件,然后将默认的配置文件根据下面的提示修改一下,就可以直接运行了。 ```bash pip3 install jupyterlab jupyter lab password jupyter lab --generate-config # c.ServerApp.ip = '0.0.0.0' # c.ServerApp.port = 8000 # c.ServerApp.open_browser = False # c.ServerApp.root_dir = '/xxxx/xxxx/xxx' # c.ServerApp.password_required = True # c.ServerApp.password = 'xxxxxxx' ``` 如果想要了解更多的用法,可以在命令行运行`jupyter lab --help`命令,在安装配置的过程中,需要注意如下几点: 1. 如果以root用户运行的话,需要加上 `--allow-root`选项 2. 如果是多用户使用的话,需要使用`--config + 配置文件`选项指定配置文件路径 3. 有些系统Python3的模块管理工具是`pip`,有些是`pip3`,以实际为准 4. 如果需要其他模块,可以在服务端直接用`pip`安装,然后在Jupiter Lab中就可以直接使用了 5. 配置Nginx反向代理的话需要区分不同路径,比如*terminal/api*,具体可参考如下 ```nginx server { server_name jupyter.rustle.cc; listen [::]:443 ssl http2; listen 443 ssl http2; listen [::]:80; listen 80; charset utf-8; access_log logs/jupyter.access.log main; location / { proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $http_host; proxy_redirect off; proxy_set_header Cache-Control no-cache; proxy_pass http://localhost:8922; } location ~ /api/kernels/ { proxy_pass http://localhost:8922; proxy_set_header Host $http_host; proxy_http_version 1.1; # websocket support proxy_set_header Upgrade "websocket"; proxy_set_header Connection "Upgrade"; proxy_read_timeout 86400; } location ~ /terminals/ { proxy_pass http://localhost:8922; proxy_set_header Host $http_host; proxy_http_version 1.1; # websocket support proxy_set_header Upgrade "websocket"; proxy_set_header Connection "Upgrade"; proxy_read_timeout 86400; } } ``` #### 3. 多用户配置 很多时候搭建了一个服务是给很多人使用的,有些具有私密性或者安全性敏感的,就按需开放,这个时候就需要设置不同的账号密码,而Jupyter没有账号,或者说在哪个账户下运行的服务,账号默认就是这个账户的名字,所以只需将原来的配置文件**jupyter_lab_config.py**复制一个副本,修改设定不同的登录密码以及端口即可,密码的生成有如下两种方式: > **方式1:使用命令行** 在命令行中直接运行`jupyter lab password`,会有输入密码的提示,连续输入两次相同的密码,Jupyter就会再次提示你,密码的hash值已经被写入如下文件。然后打开制定的文件,发现是键值对的形式,将其中的值的部分,复制到**/home/manford/.jupyter/jupyter_lab_config.py**配置文件中*c.ServerApp.password*字段。 ```bash [ 0 root@ECX ~]$ jupyter lab password Enter password: Verify password: [JupyterPasswordApp] Wrote hashed password to /home/manford/.jupyter/jupyter_server_config.json ``` > **方式2:使用Python模块** 在命令行中输入`python3`之后进入python的控制台环境,然后使用**notebook.auth**模块生成密码,最后和第一种方法一样,将生成hash值形式的密码,填到**jupyter_lab_config.py**配置文件中的*c.ServerApp.password*字段即可。 ```python [ 0 root@ECX ~]# python3 Python 3.7.3 (default, Jan 22 2021, 20:04:44) [GCC 8.3.0] on linux Type "help", "copyright", "credits" or "license" for more information. >>> from notebook.auth import passwd >>> passwd() Enter password: Verify password: 'argon2:$argon2id$v=19$m=10240,t=10,p=8$Y+LaIGe/37+rQSFoWgwPUA$7K/vd8b01i7NpZXdQDXK5y1WLysUaNZg/ypz1OBFxX0' >>> exit() ``` 密码准备好了之后,还有一个地方需要修改,配置文件**jupyter_lab_config.py**中的字段*c.ServerApp.port*值需要修改成和之前端口不一样的值,然后运行`jupyter lab --allow-root --config $PATH-TO-YOUR-CONF`。 ## 三、使用示例 Jupyter Lab作为Jupyter Notebook的升级改造版,除了更加人性化的交互界面以及更多的用户自主定制功能之外,最吸引人的就是其丰富多样的拓展插件,使得每个使用Jupyter Lab的人都可以按照自己所需挑选安装插件,组合出自己心中的完美工作台。如下是安装好打开之后的界面,可以在最左边的侧边栏最后一个按钮处启用并安装扩展程序。 #### 1. 界面要素简介 如下图所示,Jupyter Lab分为三大块——菜单栏,左侧工作区,右侧启动区。布局比较清晰简洁,多操作几次就可以很熟练地使用了。