-
Notifications
You must be signed in to change notification settings - Fork 29
SIRF SuperBuild on Docker
This will be moved to [SuperBuild-docker]. [SuperBuild-docker]: https://github.com/CCPPETMR/SIRF-SuperBuild/tree/master/docker
Docker wrapper for CCP PET-MR SIRF.
- Install docker CE and
docker-compose
, - Run
./sirf-compose-server up -d sirf
(in this folder) - Open a browser at http://localhost:9999. It may take a few seconds.
(Run
docker logs -f sirf
to see the container's progress - eventually there should be a message stating the notebook has started.) The password isvirtual
. The directory is mounted at/devel
in the docker container from./devel
(in this folder) on the host. The container will copy SIRF-Exercises into this folder if not present.
Note: If on Windows, localhost
probably won't work.
Find out the service IP address using:
docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' sirf
and use the resultant IP instead of localhost
(e.g.: 172.18.0.2:9999
).
The repository is hosted at hub.docker.com. To pull directly, use:
docker pull ccppetmr/sirf:<DOCKER_TAG>
<DOCKER_TAG> |
Service <DOCKER_TAG>
|
SuperBuild branch/tag |
---|---|---|
release |
release-service |
<latest_tag> |
<tag> |
<tag>-service |
<tag> |
latest |
service |
master |
devel |
devel-service |
master with cmake -DDEVEL_BUILD=ON
|
Service images are intended to be run in the background, and expose:
Port(s) | Notes |
---|---|
9999 |
Jupyter (in folder /devel ) |
8890-9 |
Jupyter (in folder /devel/SIRF-Exercises-<0-9> ) |
9002 | Gadgetron |
Docker is a low-overhead, container-based replacement for virtual machines (VMs).
This works best on a linux system due to:
- Possibility to get CUDA support within the container
-
X11
windows displayed natively without needing e.g. avnc
server or desktop in the container
This is probably the easiest way to use SIRF
due to really short installation instructions essentially consisting of:
docker-compose up --no-start sirf
docker start -ai sirf
After installing docker CE and docker-compose
,
git clone https://github.com/CCPPETMR/SIRF-SuperBuild
cd SIRF-SuperBuild/docker
# if your host is linux:
./sirf-compose up --no-start sirf
# alternative if your host is windows:
docker-compose up --no-start sirf
Then it's just
docker start -ai sirf
every time you want to play with SIRF
.
docker start -ai sirf
(pyvenv) sirf:~$ python /opt/SIRF-SuperBuild/sources/SIRF/examples/Python/PET/osem_reconstruction.py
Alternatively, if you want a jupyter notebook server,
git clone https://github.com/CCPPETMR/SIRF-SuperBuild
cd SIRF-SuperBuild/docker
./sirf-compose-server up -d sirf # remove `./` if on windows
Then it's just
./sirf-compose-server up -d sirf # start sirf
firefox localhost:9999 # open a browser pointing to the server
./sirf-compose-server down # stop sirf server
every time you want to play with SIRF
.
- Docker
- The free Community Edition (CE) is sufficient
docker-compose
- The
SIRF-SuperBuild
repository- download and unzip or
git clone
this locally
- download and unzip or
A wonderfully tiny list of everything important to know for a basic working knowledge of docker.
-
Base image: the starting point for building a Docker image
- analogous to a clean OS (in this case
ubuntu:16.04
)
- analogous to a clean OS (in this case
-
Layer: a single build step
- usually represented by a single line in a
Dockerfile
(e.g.apt-get install cmake
)
- usually represented by a single line in a
-
Image: a sequence of layers (applied on top of a base image)
- analogous to a clean OS with
SIRF
installed (in this case taggedccppetmr/sirf
)
- analogous to a clean OS with
-
Container: a sandboxed workspace derived from an image
- analogous to a running virtual machine (in this case named
sirf
) - easily stoppable, restartable, disposable
- can be thought of as end-user-created layers which would never be formally part of a redistributable image
- can share files, network connections, and devices with the host computer
- analogous to a running virtual machine (in this case named
Images are built or pulled. Containers are created from them:
-
Build: typically refers to pulling a base image, then building all the layers necessary to form an image
- usually once-off
-
Pull: typically refers to downloading an image from the internet (which someone else built)
- usually only required when there is no source code available to allow for building locally
-
Create: typically refers to making a container from an image
- often recreated for a semi-clean slate - especially if data is shared with the host computer so that no data is lost on disposal
The docker image can be built from source using CCPPETMR/SIRF-SuperBuild
by following the steps below. Alternatively, simply run docker pull ccppetmr/sirf
to download a pre-built image.
docker-compose
is used to help with creating containers (and even building images). It should be added to your PATH
or at least have the executable copied to SIRF-SuperBuild/docker
.
# Either:
SIRF-SuperBuild/docker$ docker pull ccppetmr/sirf
# Or:
SIRF-SuperBuild/docker$ docker-compose build core sirf
After this a container called sirf
is created:
For easier file and window sharing, the sirf
container should be started using the host user's ID and some environment variables:
SIRF-SuperBuild/docker$ ./sirf-compose up --no-start sirf
Either:
SIRF-SuperBuild/docker> docker pull ccppetmr/sirf
Or:
SIRF-SuperBuild/docker> docker-compose build core sirf
Instead of passing user IDs, Windows requires that file sharing is enabled. Then:
SIRF-SuperBuild/docker> docker-compose up --no-start sirf
You may want to consult SIRF on Windows Subsystem for Linux regarding setting up Xserver/VNCserver and other UNIX-for-Windows-users tips.
Note that Docker for Windows uses the newer Hyper-V backend which can't be enabled if you have VirtualBox. You can use the older VirtualBox backend instead by using Docker Machine.
Alternatively, if you want a jupyter notebook server,
# Linux:
SIRF-SuperBuild/docker$ ./sirf-compose-server up -d sirf
# Windows:
SIRF-SuperBuild/docker> sirf-compose-server up -d sirf
Open your favourite web browser on your host OS, and go to
http://localhost:9999.
If the browser is giving you a connection error,
docker logs -f sirf
will give you the current status of the server
(there should be an eventual message about Jupyter being started).
To stop the server, run sirf-compose-server down
.
ccache
is used in the container to speed up rebuilding images from scratch.
The cache is pulled from the host machine via the devel/.ccache
folder.
To replace the host's cache with the updated one from the container, run:
SIRF-SuperBuild/docker$ sudo rm -rf devel/.ccache/*
SIRF-SuperBuild/docker$ ./sirf-compose run --rm sirf \
/bin/bash -c 'sudo cp -a /opt/ccache/* /devel/.ccache/'
Note that ./sirf-compose*
are simple wrappers around docker-compose
.
- For a service (Jupyter) container:
./sirf-compose-server
- For a container hosting 10 Jupyter servers:
./sirf-compose-server-multi
- For a basic interactive container:
- on Linux:
./sirf-compose
- on Windows:
docker-compose
- on Linux:
Run any of the above commands without arguments for help.
For example, to host multiple Jupyter servers in one container, simply:
./sirf-compose-server-multi up -d sirf # start 10 jupyter servers
./sirf-compose-server-multi ps # print out exposed ports
./sirf-compose-server-multi stop # stop and remove the container
Note that the devel/SIRF-Exercises*
shared folders created in the above steps
will persist across container (and indeed host) restarts.
Well, that was easy. The container can be run interactively for daily use.
SIRF-SuperBuild/docker$ docker start -ai sirf
(py2) sirf:~$ gadgetron >> /dev/null &
(py2) sirf:~$ python SIRF-SuperBuild/SIRF/examples/Python/MR/fully_sampled_recon.py
The first line starts the sirf
docker container.
The second line starts gadgetron
within the container as a background process.
Finally, we can then run an example.
Note that the devel
folder in the host's SIRF-SuperBuild/docker
directory
is mounted to /devel
in the container.
- Tests can be run as follows:
(py2) sirf:~$ /devel/test.sh
- "Cannot connect to display" errors are usually fixed by running
xhost +local:""
on the host linux system - Non-linux users (e.g. Windows) will need to set up a desktop and vnc server in order to have a GUI (docker files coming soon)
- On host systems with less than 16GB RAM, before
docker-compose up ...
you may want to editSIRF-SuperBuild/docker/user_sirf-ubuntu.sh
, changing the linemake -j...
to simplymake
. This increases build time and reduces build memory requirements.