Update docker image for 2nd edition

main
Aurélien Geron 2019-06-04 16:43:14 +08:00
parent f680e49ea2
commit fb47fab0c8
7 changed files with 45 additions and 75 deletions

View File

@ -1 +1 @@
COMPOSE_PROJECT_NAME=handson-ml COMPOSE_PROJECT_NAME=handson-ml2

View File

@ -1,4 +1,4 @@
FROM continuumio/anaconda3:5.2.0 FROM continuumio/anaconda3:2019.03
RUN apt-get update && apt-get upgrade -y \ RUN apt-get update && apt-get upgrade -y \
&& apt-get install -y \ && apt-get install -y \
@ -7,20 +7,37 @@ RUN apt-get update && apt-get upgrade -y \
git \ git \
sudo \ sudo \
cmake zlib1g-dev libjpeg-dev xvfb libav-tools xorg-dev libboost-all-dev libsdl2-dev swig \ cmake zlib1g-dev libjpeg-dev xvfb libav-tools xorg-dev libboost-all-dev libsdl2-dev swig \
unzip zip \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
RUN conda update -n base conda RUN conda update -n base conda
RUN conda install -y \
joblib \
PyYAML==3.13
RUN conda install -y -c conda-forge \ RUN conda install -y -c conda-forge \
tensorflow \ pyopengl \
jupyter_contrib_nbextensions \ xgboost \
pyopengl nbdime
RUN pip install "urlextract"
RUN pip install "gym[atari,box2d,classic_control]" RUN pip install "gym[atari,box2d,classic_control]"
RUN pip install "tensorflow-hub"
RUN pip install "tensorflow-serving-api"
RUN pip install "tfx"
#RUN pip install "tensorflow-addons"
RUN pip install "tf-agents-nightly"
RUN pip install "tfds-nightly"
RUN pip install "tfp-nightly"
RUN pip uninstall -y tensorflow
RUN pip uninstall -y tensorboard
RUN pip install "tf-nightly-2.0-preview"
RUN pip install "tb-nightly"
ARG username ARG username
ARG userid ARG userid
ARG home=/home/${username} ARG home=/home/${username}
ARG workdir=${home}/handson-ml ARG workdir=${home}/handson-ml2
RUN adduser ${username} --uid ${userid} --gecos '' --disabled-password \ RUN adduser ${username} --uid ${userid} --gecos '' --disabled-password \
&& echo "${username} ALL=(root) NOPASSWD:ALL" > /etc/sudoers.d/${username} \ && echo "${username} ALL=(root) NOPASSWD:ALL" > /etc/sudoers.d/${username} \
@ -29,25 +46,17 @@ RUN adduser ${username} --uid ${userid} --gecos '' --disabled-password \
WORKDIR ${workdir} WORKDIR ${workdir}
RUN chown ${username}:${username} ${workdir} RUN chown ${username}:${username} ${workdir}
USER ${username}
RUN jupyter contrib nbextension install --user
RUN jupyter nbextension enable toc2/main
# INFO: Jupyter and nbdime extension are not totally integrated (anaconda image is py36,
# nbdime checks for py35 at the moment, still the config below enables diffing
# notebooks with nbdiff (and nbdiff support in git diff command) after connecting
# to the container by "make exec" (or "docker-compose exec handson-ml bash")
# You may also try running:
# nbd NOTEBOOK_NAME.ipynb
# to get nbdiff between checkpointed version and current version of the given notebook
USER root
WORKDIR /
RUN conda install -y -c conda-forge nbdime
USER ${username} USER ${username}
WORKDIR ${workdir} WORKDIR ${workdir}
# The config below enables diffing notebooks with nbdiff (and nbdiff support
# in git diff command) after connecting to the container by "make exec" (or
# "docker-compose exec handson-ml2 bash")
# You may also try running:
# nbdiff NOTEBOOK_NAME.ipynb
# to get nbdiff between checkpointed version and current version of the
# given notebook.
RUN git-nbdiffdriver config --enable --global RUN git-nbdiffdriver config --enable --global
# INFO: Optionally uncomment any (one) of the following RUN commands below to ignore either # INFO: Optionally uncomment any (one) of the following RUN commands below to ignore either
@ -56,19 +65,6 @@ RUN git-nbdiffdriver config --enable --global
RUN git config --global diff.jupyternotebook.command 'git-nbdiffdriver diff --ignore-details' RUN git config --global diff.jupyternotebook.command 'git-nbdiffdriver diff --ignore-details'
# INFO: Dirty nbdime patching (ignored if not matching)
COPY docker/nbdime-*.patch /tmp/
USER root
WORKDIR /
RUN patch -d /opt/conda/lib/python3.6/site-packages -p1 --forward --reject-file=- < \
/tmp/nbdime-1-details.patch || true \
&& patch -d /opt/conda/lib/python3.6/site-packages -p1 --forward --reject-file=- < \
/tmp/nbdime-2-toc.patch || true
RUN rm /tmp/nbdime-*.patch
USER ${username}
WORKDIR ${workdir}
COPY docker/bashrc.bash /tmp/ COPY docker/bashrc.bash /tmp/
RUN cat /tmp/bashrc.bash >> ${home}/.bashrc RUN cat /tmp/bashrc.bash >> ${home}/.bashrc
RUN echo "export PATH=\"${workdir}/docker/bin:$PATH\"" >> ${home}/.bashrc RUN echo "export PATH=\"${workdir}/docker/bin:$PATH\"" >> ${home}/.bashrc
@ -81,11 +77,13 @@ RUN sudo rm /tmp/bashrc.bash
#RUN cat /tmp/jupyter_notebook_config.py >> ${home}/.jupyter/jupyter_notebook_config.py #RUN cat /tmp/jupyter_notebook_config.py >> ${home}/.jupyter/jupyter_notebook_config.py
#RUN sudo rm /tmp/jupyter_notebook_config.py #RUN sudo rm /tmp/jupyter_notebook_config.py
# INFO: Uncomment the RUN command below to disable git diff paging # INFO: Uncomment the RUN command below to disable git diff paging
#RUN git config --global core.pager '' #RUN git config --global core.pager ''
# INFO: Uncomment the RUN command below for easy and constant notebook URL (just localhost:8888) # INFO: Uncomment the RUN command below for easy and constant notebook URL (just localhost:8888)
# That will switch jupyter to using empty password instead of a token. # That will switch Jupyter to using empty password instead of a token.
# To avoid making a security hole you SHOULD in fact not only uncomment but # To avoid making a security hole you SHOULD in fact not only uncomment but
# regenerate the hash for your own non-empty password and replace the hash below. # regenerate the hash for your own non-empty password and replace the hash below.
# You can compute a password hash in any notebook, just run the code: # You can compute a password hash in any notebook, just run the code:

View File

@ -4,11 +4,11 @@ help:
run: run:
docker-compose up docker-compose up
exec: exec:
docker-compose exec handson-ml bash docker-compose exec handson-ml2 bash
build: stop .FORCE build: stop .FORCE
docker-compose build docker-compose build
rebuild: stop .FORCE rebuild: stop .FORCE
docker-compose build --force-rm docker-compose build --force-rm
stop: stop:
docker stop handson-ml || true; docker rm handson-ml || true; docker stop handson-ml2 || true; docker rm handson-ml2 || true;
.FORCE: .FORCE:

View File

@ -18,11 +18,11 @@ Some general knowledge about `docker` infrastructure might be useful (that's an
Switch to `docker` directory here and run `make build` (or `docker-compose build`) to build your docker image. That may take some time but is only required once. Or perhaps a few times after you tweak something in a `Dockerfile`. Switch to `docker` directory here and run `make build` (or `docker-compose build`) to build your docker image. That may take some time but is only required once. Or perhaps a few times after you tweak something in a `Dockerfile`.
After the process is finished you have a `handson-ml` image, that will be the base for your experiments. You can confirm that looking on results of `docker images` command. After the process is finished you have a `handson-ml2` image, that will be the base for your experiments. You can confirm that looking on results of `docker images` command.
### Run the notebooks ### Run the notebooks
Run `make run` (or just `docker-compose up`) to start the jupyter server inside the container (also named `handson-ml`, same as image). Just point your browser to the URL printed on the screen (or just <http://localhost:8888> if you enabled password authentication) and you're ready to play with the book's code! Run `make run` (or just `docker-compose up`) to start the jupyter server inside the container (also named `handson-ml2`, same as image). Just point your browser to the URL printed on the screen (or just <http://localhost:8888> if you enabled password authentication) and you're ready to play with the book's code!
The server runs in the directory containing the notebooks, and the changes you make from the browser will be persisted there. The server runs in the directory containing the notebooks, and the changes you make from the browser will be persisted there.
@ -30,9 +30,9 @@ You can close the server just by pressing `Ctrl-C` in terminal window.
### Run additional commands in container ### Run additional commands in container
Run `make exec` (or `docker-compose exec handson-ml bash`) while the server is running to run an additional `bash` shell inside the `handson-ml` container. Now you're inside the environment prepared within the image. Run `make exec` (or `docker-compose exec handson-ml2 bash`) while the server is running to run an additional `bash` shell inside the `handson-ml2` container. Now you're inside the environment prepared within the image.
One of the usefull things that can be done there would be starting TensorBoard (for example with simple `tb` command, see bashrc file). One of the useful things that can be done there would be starting TensorBoard (for example with simple `tb` command, see bashrc file).
Another one may be comparing versions of the notebooks using the `nbdiff` command if you haven't got `nbdime` installed locally (it is **way** better than plain `diff` for notebooks). See [Tools for diffing and merging of Jupyter notebooks](https://github.com/jupyter/nbdime) for more details. Another one may be comparing versions of the notebooks using the `nbdiff` command if you haven't got `nbdime` installed locally (it is **way** better than plain `diff` for notebooks). See [Tools for diffing and merging of Jupyter notebooks](https://github.com/jupyter/nbdime) for more details.

View File

@ -1,14 +1,14 @@
version: "3" version: "3"
services: services:
handson-ml: handson-ml2:
build: build:
context: ../ context: ../
dockerfile: ./docker/Dockerfile dockerfile: ./docker/Dockerfile
args: args:
- username=devel - username=devel
- userid=1000 - userid=1000
container_name: handson-ml container_name: handson-ml2
image: handson-ml image: handson-ml2
restart: unless-stopped restart: unless-stopped
logging: logging:
driver: json-file driver: json-file
@ -18,5 +18,5 @@ services:
- "8888:8888" - "8888:8888"
- "6006:6006" - "6006:6006"
volumes: volumes:
- ../:/home/devel/handson-ml - ../:/home/devel/handson-ml2
command: /opt/conda/bin/jupyter notebook --ip='0.0.0.0' --port=8888 --no-browser command: /opt/conda/bin/jupyter notebook --ip='0.0.0.0' --port=8888 --no-browser

View File

@ -1,17 +0,0 @@
--- a/nbdime/diffing/notebooks.py
+++ b/nbdime/diffing/notebooks.py
@@ -548,8 +548,12 @@ def set_notebook_diff_targets(sources=True, outputs=True, attachments=True, meta
metadata_keys = ("/cells/*/metadata", "/metadata", "/cells/*/outputs/*/metadata")
if metadata:
for key in metadata_keys:
- if key in notebook_differs:
- del notebook_differs[key]
+ if details:
+ if key in notebook_differs:
+ del notebook_differs[key]
+ else:
+ notebook_differs[key] = diff_ignore_keys(
+ inner_differ=diff, ignore_keys=['collapsed', 'autoscroll', 'deletable', 'editable'])
else:
for key in metadata_keys:
notebook_differs[key] = diff_ignore

View File

@ -1,11 +0,0 @@
--- a/nbdime/diffing/notebooks.py
+++ b/nbdime/diffing/notebooks.py
@@ -553,7 +553,7 @@
del notebook_differs[key]
else:
notebook_differs[key] = diff_ignore_keys(
- inner_differ=diff, ignore_keys=['collapsed', 'autoscroll', 'deletable', 'editable'])
+ inner_differ=diff, ignore_keys=['toc', 'collapsed', 'autoscroll', 'deletable', 'editable'])
else:
for key in metadata_keys:
notebook_differs[key] = diff_ignore