使用 boot2docker 设置 IPython 开发环境#
注意
这是从旧 IPython wiki 中逐字复制的,目前正在开发中。开发指南的这一部分中的许多信息已过时。
以下是如何启动并运行 IPython 开发环境的说明,而无需在主机上安装任何内容,除了 `boot2docker
<boot2docker/boot2docker>`__ 和 `docker
<https://docker.net.cn/>`__。
安装 boot2docker
#
安装 boot2docker。有多种安装方法,具体取决于你的环境。请参阅 boot2docker 文档。
Mac OS X#
在安装了 Homebrew 的 Mac OS X 主机上
$ brew install boot2docker docker
初始化 boot2docker
VM#
$ boot2docker init
启动 VM#
$ boot2docker up
boot2docker
CLI 与 boot2docker
VM 上的 docker 守护进程通信。为此,我们必须设置一些环境变量,例如 DOCKER_HOST
,
$ $(boot2docker shellinit)
要查看 VM 的 IP 地址
$ boot2docker ip
192.168.59.103
从开发分支安装 ipython
#
$ git clone --recursive https://github.com/ipython/ipython.git
构建 Docker 镜像#
使用克隆的 ipython
目录中的 Dockerfile 来构建 Docker 镜像。
$ cd ipython
$ docker build --rm -t ipython .
运行 Docker 容器#
使用新镜像运行容器。我们将主机上的整个 ipython
源代码树挂载到容器中的 /srv/ipython
中,以使我们在主机上对源代码所做的更改立即反映到容器中。
# change to the root of the git clone
$ cd ipython
$ docker run -it --rm -p 8888:8888 --workdir /srv/ipython --name ipython-dev -v `pwd`:/srv/ipython ipython /bin/bash
要在主机上的另一个 shell 中列出正在运行的容器
$ $(boot2docker shellinit)
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
f6065f206519 ipython "/bin/bash" 1 minutes ago Up 1 minutes 0.0.0.0:8888->8888/tcp ipython-dev
以可编辑模式安装 IPython#
进入容器后,你需要卸载 ipython
包,并以可编辑模式重新安装,以使你的开发更改反映到你的环境中。
container $ pip uninstall ipython
# pip install ipython in editable mode
container $ cd /srv
container $ ls
ipython
container $ pip install -e ipython
运行 Notebook 服务器#
container $ ipython notebook --no-browser --ip=*
访问 Notebook 服务器#
如果你忘记了,在你的主机上运行以下命令以获取 boot2docker VM 的 IP
# on host
$ boot2docker ip
192.168.59.103
然后在你的浏览器中访问它
# browser
http://192.168.59.103:8888
作为 Mac 上的快捷方式,你可以在终端窗口中运行以下命令(或将其设为 bash 别名)
$ open http://$(boot2docker ip 2>/dev/null):8888