Skip to content

Latest commit

 

History

History
280 lines (191 loc) · 7.49 KB

ReadMe.md

File metadata and controls

280 lines (191 loc) · 7.49 KB

Introduction

In this example, we run an OpenVisus server inside a Docker container. (NOTE it will work just fine with PodMan too)

The OpenVisus server is a C++ Apache module called mod_visus.

In this tutorial we assume that the datasets are stored in a shared directory (i.e. an host directory mounted inside the Docker instance); but there are other more advanced options, such as using Object Storage (e.g. Amazon S3, Wasabi, Google Cloud Storage, Azure Blob Storage etc.) and let the OpenVisus server to create a local cache.

Apache server is the httpd:2.4 version and runs in event mode under daemon account. HTTP (port 80) and HTTPS (port 443) will be mapped to port 8080 and port 8443. If you need to change this setup, you may need to customize the Dockerfile.

Figure 1. Diagram of a dockerized OpenVisus server

For more complex case with a load balancer (e.g. nginx or HAProxy) in front of OpenVisus instances, please refer to Kubernetes or Docker Swarm tutorials.

Run OpenVisus server

Example (NOTE: better to specify a version than latest, since latest is ambiguous):

IMAGE=visus/mod_visus_x86_64:latest
sudo docker run --rm --publish 8080:80 --publish 8443:443 --name my-modvisus $IMAGE

From another shell check if it is working:

# should return an HTML document (BODY it works)
curl http://localhost:8080

# internal messages
curl http://localhost:8080/server-status

# it should return an XML list with 2kbit1 inside
curl http://localhost:8080/mod_visus?action=list

# it should return an XML list with 2kbit1 inside
# NOTE --insecure since by default OpenVisus is using self-signed certificates
curl --insecure https://localhost:8443/mod_visus?action=list

# it should return a text file with (version) as first line
curl http://localhost:8080/mod_visus?dataset=2kbit1 

Run OpenVisus server with you datasets

Example:

export DATASETS=/mnt/data/datasets
mkdir -p $DATASETS

pushd $DATASETS
wget https://github.com/sci-visus/OpenVisus/releases/download/files/2kbit1.zip
unzip 2kbit1.zip -d ./2kbit1
rm -f 2kbit1.zip
popd

Create a datasets.config file i.e. the master configuration file which tells to OpenVisus where the data is located:

cat <<EOF > $DATASETS/datasets.config
<visus>
  <datasets>
    <dataset name="2kbit1" url="/datasets/2kbit1/visus.idx" />
  </datasets>
</visus>
EOF

Important note: Docker instance will see the $DATASET directory as /datasets, so the <dataset ...> items should be filled accordingly.

then type:

IMAGE=visus/mod_visus_x86_64:latest
sudo docker run --rm --publish 8080:80 --publish 8443:443 --name my-modvisus -v $DATASETS:/datasets $IMAGE

From another shell check if it is working:


curl http://localhost:8080/mod_visus?dataset=2kbit1 
curl --insecure https://localhost:8443/mod_visus?dataset=2kbit1 

(OPTIONAL) Debug the Container

To debug the container from the inside:

sudo docker run --rm -it --publish 8080:80 --publish 8443:443 -v $DATASETS:/datasets $IMAGE /bin/bash
/usr/local/bin/httpd-foreground

(OPTIONAL)Generate CA certificates

ee https://certbot.eff.org/docs/install.html#running-with-docker for full instructions:

`` DOMAIN=$atlantis.sci.utah.edu

sudo docker run -it --rm --name certbot
-v "$HOME/.certbot/etc/letsencrypt:/etc/letsencrypt"
-v "$HOME/.certbot/var/lib/letsencrypt:/var/lib/letsencrypt"
-p 80:80
-p 443:443
certbot/certbot certonly --standalone -m [email protected] -n --agree-tos -d $DOMAIN

fix file permissions

sudo docker run
-v "$HOME/.certbot/etc/letsencrypt:/etc/letsencrypt"
-v "$HOME/.certbot/var/lib/letsencrypt:/var/lib/letsencrypt"
ubuntu:latest chmod a+rX -R /etc/letsencrypt

``

and then during docker run mount the certificate:

sudo docker run \
   ... \
   --mount type=bind,source=$HOME/.certbot/etc/letsencrypt/live/$DOMAIN/fullchain.pem,target=/usr/local/apache2/conf/server.crt \
   --mount type=bind,source=$HOME/.certbot/etc/letsencrypt/live/$DOMAIN/privkey.pem,target=/usr/local/apache2/conf/server.key \
   ...

(OPTIONAL)Build the image

cd Docker/mod_visus
TAG=YOUR_TAG_HERE
sudo docker build --tag visus/mod_visus_x86_64:$TAG  --build-arg TAG=$TAG .
sudo docker push visus/mod_visus_x86_64:$TAG

(OPTIONAL) Inspect the logs

Type:

sudo docker ps  | grep mod_visus
sudo docker logs my-modvisus

(OPTIONAL) Start containers automatically

Add some options to the run command (see https://docs.docker.com/config/containers/start-containers-automatically):

sudo docker run --rm \
   --publish 8080:80 \
   --publish 8443:443 \
   -v $DATASETS:/datasets \
   --name my-modvisus \
   --restart=always \
   -d --restart=unless-stopped \
   $IMAGE

and start the docker daemon (see https://docs.docker.com/config/daemon/systemd):

sudo systemctl start docker

(OPTIONAL) Enable password security

To enable password security:

export MODVISUS_USERNAME=visus
export MODVISUS_PASSWORD=`openssl rand -base64 48`

# save in a file for later use
cat <<EOF > .mod_visus.identity.sh
#!/bin/bash
export MODVISUS_USERNAME=$MODVISUS_USERNAME
export MODVISUS_PASSWORD=$MODVISUS_PASSWORD
EOF
chmod 600 .mod_visus.identity.sh
source .mod_visus.identity.sh

htpasswd -nb  $MODVISUS_USERNAME $MODVISUS_PASSWORD > $DATASETS/.htpasswd

# TOFIX: is this secure?
chmod 644 $DATASETS/.htpasswd

To test the password-protected server with curl:

curl -u$MODVISUS_USERNAME:$MODVISUS_PASSWORD ...

(OPTIONAL)Enable dynamic datasets

If your need to change the datasets.config at runtime, for example because you want to dynamically add/remove datasets at runtime, add a ModVisus/Dynamic section to your datasets.config:

<visus>
  <Configuration>
    <ModVisus>
      <Dynamic enabled='true' filename='/datasets/datasets.config' msec='5000' />
    </ModVisus>
  </Configuration>
  ...
</visus>

This way mod_visus will check for file changes every 5000 milliseconds, and will fire a reload dataset event if needed.

(OPTIONAL) File permission problems

The quick-and-dirty way of fixing file permissions is to set read-write permissions for all datasets:

chmod -R a+rwX $DATASETS

Another more polite way is to map the users and groups of the host to the docker instance.

Find all the groups

find $DATASETS -printf "%g %G\n" | sort | uniq 

this command will print a list with the group name (%g) and group ID (%G):

user1 1000
user2 1001
...

Then create Dockerfile adding the groups and adding the daemon user to those groups:

FROM $IMAGE
RUN addgroup --gid <group-id-1> <group-name-1>
RUN addgroup --gid <group-id-2> <group-name-2>
RUN usermod -a -G <group-name-1>,<group-name-2> daemon 

Build the image:

sudo docker build --tag visus/my_mod_visus:$TAG .

Another way (not tested) is to directly add the groups to daemon user by command line:

docker run ... --group-add <group-id-1> --group-add <group-id-2> ...