From 8d750d0744070551287553589c0eb78369e1ab2d Mon Sep 17 00:00:00 2001 From: Norman Rzepka Date: Fri, 12 Nov 2021 15:07:53 +0100 Subject: [PATCH 1/6] move /srv/webknossos to /webknossos in the dockerfiles --- Dockerfile | 4 +- MIGRATIONS.unreleased.md | 2 +- docker-compose.yml | 4 +- docs/datasets.md | 2 +- tools/binary_data/download_knossos_data.py | 22 --- tools/binary_data/generate_voronoi_cubes.py | 13 -- tools/binary_data/grabData.sh | 139 ------------------ tools/binary_data/knossos_to_wkw.py | 112 -------------- tools/binary_data/segmentation-deploy.sh | 33 ----- tools/dev_deployment/refresh_schema.sh | 2 +- tools/hosting/docker-compose.yml | 2 +- webknossos-datastore/Dockerfile | 6 +- .../deployment/docker-compose.yml | 6 +- webknossos-tracingstore/Dockerfile | 8 +- .../deployment/docker-compose.yml | 4 +- 15 files changed, 20 insertions(+), 339 deletions(-) delete mode 100755 tools/binary_data/download_knossos_data.py delete mode 100644 tools/binary_data/generate_voronoi_cubes.py delete mode 100755 tools/binary_data/grabData.sh delete mode 100644 tools/binary_data/knossos_to_wkw.py delete mode 100644 tools/binary_data/segmentation-deploy.sh diff --git a/Dockerfile b/Dockerfile index f2ac88524a8..d69aa468be0 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,8 +3,8 @@ RUN apt-get update \ && apt-get -y install postgresql-client \ && rm -rf /var/lib/apt/lists/* -RUN mkdir -p /srv/webknossos -WORKDIR /srv/webknossos +RUN mkdir -p /webknossos +WORKDIR /webknossos COPY target/universal/stage . COPY webknossos-datastore/lib/native target/universal/stage/lib/native diff --git a/MIGRATIONS.unreleased.md b/MIGRATIONS.unreleased.md index b7d958cbf9b..299198282b0 100644 --- a/MIGRATIONS.unreleased.md +++ b/MIGRATIONS.unreleased.md @@ -7,7 +7,7 @@ User-facing changes are documented in the [changelog](CHANGELOG.released.md). ## Unreleased -- +- The docker files now place the webKnossos installation under `/webknossos` instead of `/srv/webknossos`. All mounts, most importantly `/srv/webknossos/binaryData`, need to be changed accordingly. ### Postgres Evolutions: diff --git a/docker-compose.yml b/docker-compose.yml index e53738251c2..4483b8ac647 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -32,7 +32,7 @@ services: # - -Dplay.modules.enabled-="com.scalableminds.webknossos.datastore.DataStoreModule" # - -Dplay.http.router="noDS.Routes" volumes: - - ./binaryData:/srv/webknossos/binaryData + - ./binaryData:/webknossos/binaryData environment: - POSTGRES_URL=jdbc:postgresql://postgres/webknossos user: ${USER_UID:-1000}:${USER_GID:-1000} @@ -44,7 +44,7 @@ services: - "9090:9090" entrypoint: bin/webknossos-datastore volumes: - - ./binaryData:/srv/webknossos-datastore/binaryData + - ./binaryData:/webknossos-datastore/binaryData command: - -J-Xmx20G - -J-Xms1G diff --git a/docs/datasets.md b/docs/datasets.md index 5112785ce70..a8f9cb135af 100644 --- a/docs/datasets.md +++ b/docs/datasets.md @@ -52,7 +52,7 @@ services: webknossos: ... volumes: - - ./data:/srv/webknossos/binaryData + - ./data:/webknossos/binaryData - /cluster:/cluster ... ``` diff --git a/tools/binary_data/download_knossos_data.py b/tools/binary_data/download_knossos_data.py deleted file mode 100755 index f6eaf90e6e5..00000000000 --- a/tools/binary_data/download_knossos_data.py +++ /dev/null @@ -1,22 +0,0 @@ -#!/usr/bin/python - -user = "" -dataset = "2012-09-28_ex145_07x2_segNew" -filename = "2012-09-28_ex145_07x2" -layer = "color" -section = "." -X = [28, 29, 30] -Y = [21, 22, 23] -Z = [12] -R = [1] - -cmd = "mkdir -p ./%s/%s/%d/x%04d/y%04d/z%04d/ && scp %s@oxalis.at:data/%s/%s/%s/%d/x%04d/y%04d/z%04d/%s_mag%d_x%04d_y%04d_z%04d.raw ./%s/%s/%d/x%04d/y%04d/z%04d/%s_mag%d_x%04d_y%04d_z%04d.raw" - -for x in X: - for y in Y: - for z in Z: - for r in R: - x /= r - y /= r - z /= r - print cmd % (layer, section, r, x, y, z, user, dataset, layer, section, r, x, y, z, filename, r, x, y, z, layer, section, r, x, y, z, dataset, r, x, y, z) diff --git a/tools/binary_data/generate_voronoi_cubes.py b/tools/binary_data/generate_voronoi_cubes.py deleted file mode 100644 index b8422922900..00000000000 --- a/tools/binary_data/generate_voronoi_cubes.py +++ /dev/null @@ -1,13 +0,0 @@ -import np - -d = 128 -points = np.random.randint(0, d, (32, 3)) -hull_space=np.zeros([d,d,d], dtype=np.int8) -for x in range(d): - for y in range(d): - for z in range(d): - coord = np.array([x,y,z]) - diff = points - coord - dist = diff[:,0]**2 + diff[:,1]**2 + diff[:,2]**2 - closest = np.argmin(dist) - hull_space[x][y][z] = closest * 8 diff --git a/tools/binary_data/grabData.sh b/tools/binary_data/grabData.sh deleted file mode 100755 index 5f32cc15a87..00000000000 --- a/tools/binary_data/grabData.sh +++ /dev/null @@ -1,139 +0,0 @@ -#!/bin/bash -set -e -if [ $# -lt 1 ]; then - echo "Usage: $0 " - exit 1 -fi - -USER=$1 -SERVER="dev.oxalis.at" -CONTROL_PATH="/tmp/%r@%h:%p" -CONTROL_PATH_LITERAL="/tmp/$USER@$SERVER:22" -BINARY_DATA_DIR="/srv/binaryData/Structure\ of\ Neocortical\ Circuits\ Group" -LOCAL_BINARY_DATA_DIR="../../binaryData" - -echo "Select a dataset to download" -echo "cancel with CTRL+C" - -function download_segmentation_oriented() { - echo "Which section do you want to download?(including color data)" - select Section in `ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/segmentation | grep -P "^section"`; - do - ssh $USER@$SERVER -S $CONTROL_PATH "find $BINARY_DATA_DIR/$DataSet/segmentation/$Section -name '*.raw' -printf '+_%f\\n'" > sectionfiles - #loading json and directory structure - rsync -e "ssh -S $CONTROL_PATH" -rtvuczm --progress --filter=+_*.json --filter=-_*.raw "$USER@$SERVER:$BINARY_DATA_DIR/$DataSet" $LOCAL_BINARY_DATA_DIR - #loading color data - rsync -e "ssh -S $CONTROL_PATH" -rtvuczm --progress --filter=._sectionfiles --filter=-_*.raw "$USER@$SERVER:$BINARY_DATA_DIR/$DataSet/color" $LOCAL_BINARY_DATA_DIR/$DataSet - #loading segmentation - rsync -e "ssh -S $CONTROL_PATH" -rtvuczm --progress --filter=._sectionfiles --filter=-_*.raw "$USER@$SERVER:$BINARY_DATA_DIR/$DataSet/segmentation/$Section" $LOCAL_BINARY_DATA_DIR/$DataSet/segmentation - rm sectionfiles - break - done -} - -function download_block_range() { - X_MIN=`ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/color/1/ | grep -P "x[0-9]{4}" | cut -c2- | head -n 1` #| sed 's/0*//' | sed 's/^$/0/'` - X_MAX=`ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/color/1/ | grep -P "x[0-9]{4}" | cut -c2- | tail -n 1` #| sed 's/0*//' | sed 's/^$/0/'` - echo "Dataset consists of x$X_MIN - x$X_MAX" - echo "Lower bound for x?" - read X_LOWER_B - if [ $X_LOWER_B -lt $X_MIN -o $X_LOWER_B -gt $X_MAX ]; then - echo "Bad lower bound..." - exit 1 - fi - echo "Upper bound for x?" - read X_UPPER_B - if [ $X_UPPER_B -lt $X_LOWER_B -o $X_UPPER_B -gt $X_MAX ]; then - echo "Bad upper bound..." - exit 1 - fi - - Y_MIN=`ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/color/1/x$X_MIN/ | grep -P "y[0-9]{4}" | cut -c2- | head -n 1` - Y_MAX=`ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/color/1/x$X_MIN/ | grep -P "y[0-9]{4}" | cut -c2- | tail -n 1` - echo "Dataset consists of y$Y_MIN - y$Y_MAX" - echo "Lower bound for y?" - read Y_LOWER_B - if [ $Y_LOWER_B -lt $Y_MIN -o $Y_LOWER_B -gt $Y_MAX ]; then - echo "Bad lower bound..." - exit 1 - fi - echo "Upper bound for y?" - read Y_UPPER_B - if [ $Y_UPPER_B -lt $Y_LOWER_B -o $Y_UPPER_B -gt $Y_MAX ]; then - echo "Bad upper bound..." - exit 1 - fi - - Z_MIN=`ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/color/1/x$X_MIN/y$Y_MIN/ | grep -P "z[0-9]{4}" | cut -c2- | head -n 1` - Z_MAX=`ssh $USER@$SERVER -S $CONTROL_PATH ls $BINARY_DATA_DIR/$DataSet/color/1/x$X_MIN/y$Y_MIN/ | grep -P "z[0-9]{4}" | cut -c2- | tail -n 1` - echo "Dataset consists of z$Z_MIN - z$Z_MAX" - echo "Lower bound for z?" - read Z_LOWER_B - if [ $Z_LOWER_B -lt $Z_MIN -o $Z_LOWER_B -gt $Z_MAX ]; then - echo "Bad lower bound..." - exit 1 - fi - echo "Upper bound for z?" - read Z_UPPER_B - if [ $Z_UPPER_B -lt $Z_LOWER_B -o $Z_UPPER_B -gt $Z_MAX ]; then - echo "Bad upper bound..." - exit 1 - fi - if [ -f tempfilter ]; then - rm tempfilter - fi - for x in `seq $X_LOWER_B $X_UPPER_B`; do - for y in `seq $Y_LOWER_B $Y_UPPER_B`; do - for z in `seq $Z_LOWER_B $Z_UPPER_B`; do - printf "+_%s_mag1_x%04d_y%04d_z%04d.raw\n" $DataSet $x $y $z >> tempfilter - done - done - done - rsync -e "ssh -S $CONTROL_PATH" -rtvuczm --progress --filter=._tempfilter --filter=+_*.json --filter=-_*.raw "$USER@$SERVER:$BINARY_DATA_DIR/$DataSet" $LOCAL_BINARY_DATA_DIR - rm tempfilter -} - -cd `dirname $0` -echo "setting up ssh connection" -ssh $USER@$SERVER -fN -M -S $CONTROL_PATH -PS3="Your choice: " -select DataSet in `ssh -S $CONTROL_PATH $USER@$SERVER ls $BINARY_DATA_DIR`; -do - echo "You picked $DataSet ($REPLY)" - echo "Download full or partial dataset?" - select Choice in `echo full; echo partial`; - do - case $Choice in - "full") - rsync -e "ssh -S $CONTROL_PATH" -rtvucz --progress "$USER@$SERVER:$BINARY_DATA_DIR/$DataSet" $LOCAL_BINARY_DATA_DIR - ;; - "partial") - RANGE=4 - RESOLUTION=1 - ssh $USER@$SERVER -S $CONTROL_PATH test -d $BINARY_DATA_DIR/$DataSet/segmentation - - if [[ $? -eq 0 ]]; then - echo "For $DataSet segmentation is available, do you want to download segmentation block oriented or do you want to give ranges for blocks?" - select Choice in `echo "segmentation-oriented"; echo "range-oriented"`; - do - case $Choice in - "segmentation-oriented") - download_segmentation_oriented - ;; - "range-oriented") - download_block_range - ;; - esac - break - done - else - download_block_range - fi - ;; - esac - break - done - break -done - -rm $CONTROL_PATH_LITERAL \ No newline at end of file diff --git a/tools/binary_data/knossos_to_wkw.py b/tools/binary_data/knossos_to_wkw.py deleted file mode 100644 index 39b0b787ffe..00000000000 --- a/tools/binary_data/knossos_to_wkw.py +++ /dev/null @@ -1,112 +0,0 @@ -import itertools -import json -import math -import os -import re - -def mortonEncode(x, y, z): - p = 0 - m = 0 - while x + y + z > 0: - m |= ((x & 1) << p) | ((y & 1) << (p + 1)) | ((z & 1) << (p + 2)) - x = x >> 1 - y = y >> 1 - z = z >> 1 - p += 3 - return m - -def mortonDecode(m): - p = 0 - x = 0 - y = 0 - z = 0 - while m > 0: - x |= (m & 1) << p - m = m >> 1 - y |= (m & 1) << p - m = m >> 1 - z |= (m & 1) << p - m = m >> 1 - p += 1 - return x, y, z - -def reorganizeInputCube(input, settings): - buckets = [bytearray() for _ in range(pow(settings['inputCubeSize'] / settings['bucketSize'], 3))] - bytesPerElement = len(input) / pow(settings['inputCubeSize'], 3) - offset = 0 - c = 0 - for z in range(settings['inputCubeSize']): - for y in range(settings['inputCubeSize']): - for x in range(settings['inputCubeSize'] / settings['bucketSize']): - data = input[offset:offset + settings['bucketSize'] * bytesPerElement] - c += len(data) - bucketIndex = mortonEncode( - x, - int(y / settings['bucketSize']), - int(z / settings['bucketSize']) - ) - buckets[bucketIndex] += data - offset += settings['bucketSize'] * bytesPerElement - return bytearray().join(buckets) - -def convertZoomstep(input, output, settings): - os.makedirs(output) - - # Crawl all raw input files of the zoomStep to - # a) determinte the datasets size and - # b) keep a mapping from each file's voxel offset to its filename. - rawFiles = {} - rawFileNames = itertools.chain(*map(lambda x: map(lambda y: x[0] + '/' + y, x[2]), os.walk(input))) - for rawFileName in rawFileNames: - match = re.search('^.*x(\d+)_y(\d+)_z(\d+)\.raw$', rawFileName) - if match: - # Compute voxel offset from filename. - offset = ( - int(match.group(1)) * settings['inputCubeSize'], - int(match.group(2)) * settings['inputCubeSize'], - int(match.group(3)) * settings['inputCubeSize'] - ) - rawFiles[offset] = rawFileName - - # Determine size of the data in voxels. - inputSize = map(lambda i: (max(map(lambda key: key[i], rawFiles.keys())) + settings['inputCubeSize']), range(3)) - - inputCubesPerOutputCube = pow(settings['outputCubeSize'] / settings['inputCubeSize'], 3) - inputCubeSize = os.stat(rawFiles.values()[0]).st_size - emptyInputCube = bytearray(inputCubeSize) - - for x in range(0, inputSize[0], settings['outputCubeSize']): - for y in range(0, inputSize[1], settings['outputCubeSize']): - for z in range(0, inputSize[2], settings['outputCubeSize']): - - # Create new output cube. - outputCubeFileName = output + '/%d_%d_%d.raw' % (x, y, z) - print('Creating output file: "%s"' % outputCubeFileName) - with open(outputCubeFileName, 'wb') as outputCubeFile: - - # Loop through all input cubes for the current output cube in morton order. - # Each input cube is opened, split into buckets and appended to the output cube. - for inputCubeIndex in range(inputCubesPerOutputCube): - print '%d/%d' % (inputCubeIndex, inputCubesPerOutputCube) - inputCubeCoords = mortonDecode(inputCubeIndex) - inputCubeOffset = ( - x + inputCubeCoords[0] * settings['inputCubeSize'], - y + inputCubeCoords[1] * settings['inputCubeSize'], - z + inputCubeCoords[2] * settings['inputCubeSize'] - ) - - if rawFiles.has_key(inputCubeOffset): - with open(rawFiles[inputCubeOffset], 'rb') as inputCubeFile: - inputCube = inputCubeFile.read() - outputSubcube = reorganizeInputCube(inputCube, settings) - outputCubeFile.write(outputSubcube) - else: - # Input cube does not exist -> write an appropriate number of 0-bytes. - outputCubeFile.write(emptyInputCube) - -settings = {} -settings['bucketSize'] = 32 -settings['inputCubeSize'] = 128 -settings['outputCubeSize'] = 1024 - -convertZoomstep('./dataset/color/1', './output/color/1', settings) diff --git a/tools/binary_data/segmentation-deploy.sh b/tools/binary_data/segmentation-deploy.sh deleted file mode 100644 index 1b803047eeb..00000000000 --- a/tools/binary_data/segmentation-deploy.sh +++ /dev/null @@ -1,33 +0,0 @@ -#!/bin/sh - -ZSTOR_SERVER="newton" -SCM_SERVER="78.47.16.186" -ZSTOR_BINARY_DATA_DIR="/zdata/thomas/binaryData" -SCM_BINARY_DATA_DIR="/srv/binaryData" - -if [ $# -lt 3 ]; then - echo "Usage: $0 " - exit 1 -fi - -SYNCDIR="$1" -USER_LEVELCREATOR="$2" -USER_NEWTON="$3" - -function syncToRemote -{ - dataset_path=$1 - remote=$2 - rsync -rtucz --progress $dataset_path"/segmentation/" $remote/segmentation - rsync -tuc $dataset_path"/settings.json" $remote -} - -read -p "Do you really want to distribute the segmentation data in ${SYNCDIR}? [y/N]" -n 1 -r -if [[ $REPLY == "y" ]] -then - for dataset in `find ${SYNCDIR} -follow -mindepth 2 -maxdepth 2 -type d -name segmentation | cut -d/ -f2` - do - syncToRemote ${SYNCDIR}/${dataset} "${USER_NEWTON}@${ZSTOR_SERVER}:${ZSTOR_BINARY_DATA_DIR}/${dataset}" - syncToRemote ${SYNCDIR}/${dataset} "${USER_LEVELCREATOR}@${SCM_SERVER}:${SCM_BINARY_DATA_DIR}/${dataset}" - done -fi diff --git a/tools/dev_deployment/refresh_schema.sh b/tools/dev_deployment/refresh_schema.sh index 01c00925719..4d52a293436 100755 --- a/tools/dev_deployment/refresh_schema.sh +++ b/tools/dev_deployment/refresh_schema.sh @@ -20,5 +20,5 @@ POD=$( echo "Going to run 'refresh_schema.sh' in pod $POD" ssh -t kube.scm.io " - sudo kubectl exec $POD -n $NAMESPACE -- /srv/webknossos/tools/postgres/refresh_schema.sh + sudo kubectl exec $POD -n $NAMESPACE -- /webknossos/tools/postgres/refresh_schema.sh " diff --git a/tools/hosting/docker-compose.yml b/tools/hosting/docker-compose.yml index 779fad1844f..09a54b4a859 100644 --- a/tools/hosting/docker-compose.yml +++ b/tools/hosting/docker-compose.yml @@ -22,7 +22,7 @@ services: - -Dtracingstore.publicUri=https://${PUBLIC_HOST} - -Ddatastore.publicUri=https://${PUBLIC_HOST} volumes: - - ./binaryData:/srv/webknossos/binaryData + - ./binaryData:/webknossos/binaryData environment: - POSTGRES_URL=jdbc:postgresql://postgres/webknossos - VIRTUAL_HOST=${PUBLIC_HOST} diff --git a/webknossos-datastore/Dockerfile b/webknossos-datastore/Dockerfile index b65e8113c69..1d9fbec1b0a 100644 --- a/webknossos-datastore/Dockerfile +++ b/webknossos-datastore/Dockerfile @@ -1,12 +1,12 @@ FROM openjdk:8-jre -RUN mkdir -p /srv/webknossos-datastore \ +RUN mkdir -p /webknossos-datastore \ && groupadd -g 1000 -r webknossos \ && useradd -u 1000 -r -g webknossos webknossos -WORKDIR /srv/webknossos-datastore +WORKDIR /webknossos-datastore -VOLUME /srv/webknossos-datastore/binaryData /tmp +VOLUME /webknossos-datastore/binaryData /tmp COPY target/universal/stage . COPY lib/native target/universal/stage/lib/native diff --git a/webknossos-datastore/deployment/docker-compose.yml b/webknossos-datastore/deployment/docker-compose.yml index 5d8c5ebd740..7f677f8d0cb 100644 --- a/webknossos-datastore/deployment/docker-compose.yml +++ b/webknossos-datastore/deployment/docker-compose.yml @@ -1,4 +1,4 @@ -version: '2.1' +version: "2.1" services: webknossos-datastore: @@ -21,9 +21,9 @@ services: - $USER_GROUP_1 - $USER_GROUP_2 volumes: - - $BINARY_DATA_PATH:/srv/webknossos-datastore/binaryData + - $BINARY_DATA_PATH:/webknossos-datastore/binaryData - ./tmp:/tmp - - ./config/datastore-docker.conf:/srv/webknossos-datastore/conf/docker.conf + - ./config/datastore-docker.conf:/webknossos-datastore/conf/docker.conf environment: - NEW_RELIC_LICENSE_KEY - NEW_RELIC_APP_NAME diff --git a/webknossos-tracingstore/Dockerfile b/webknossos-tracingstore/Dockerfile index a79beb055ee..1f582f8ebf6 100644 --- a/webknossos-tracingstore/Dockerfile +++ b/webknossos-tracingstore/Dockerfile @@ -1,13 +1,13 @@ FROM openjdk:8-jre -RUN mkdir -p /srv/webknossos-tracingstore \ +RUN mkdir -p /webknossos-tracingstore \ && groupadd -g 1000 -r webknossos \ && useradd -u 1000 -r -g webknossos webknossos \ - && mkdir /srv/webknossos-tracingstore/tracingData + && mkdir /webknossos-tracingstore/tracingData -WORKDIR /srv/webknossos-tracingstore +WORKDIR /webknossos-tracingstore -VOLUME /srv/webknossos-tracingstore/tracingData /tmp +VOLUME /webknossos-tracingstore/tracingData /tmp COPY target/universal/stage . diff --git a/webknossos-tracingstore/deployment/docker-compose.yml b/webknossos-tracingstore/deployment/docker-compose.yml index 6fcea9bc592..281f68a3a71 100644 --- a/webknossos-tracingstore/deployment/docker-compose.yml +++ b/webknossos-tracingstore/deployment/docker-compose.yml @@ -1,4 +1,4 @@ -version: '2.1' +version: "2.1" services: webknossos-tracingstore: @@ -25,7 +25,7 @@ services: - $USER_GROUP_2 volumes: - ./tmp:/tmp - - ./config/tracingstore-docker.conf:/srv/webknossos-tracingstore/conf/docker.conf + - ./config/tracingstore-docker.conf:/webknossos-tracingstore/conf/docker.conf environment: - NEW_RELIC_LICENSE_KEY - NEW_RELIC_APP_NAME From d317e1cf243cce63f5893101885dbd5149c3fefd Mon Sep 17 00:00:00 2001 From: Norman Rzepka Date: Tue, 16 Nov 2021 10:51:21 +0100 Subject: [PATCH 2/6] add umask to dockerfiles --- Dockerfile | 10 +++++++--- docker-compose.yml | 5 +++-- tools/hosting/docker-compose.yml | 1 + webknossos-datastore/Dockerfile | 7 +++++-- webknossos-datastore/deployment/docker-compose.yml | 2 +- webknossos-tracingstore/Dockerfile | 7 +++++-- webknossos-tracingstore/deployment/docker-compose.yml | 2 +- 7 files changed, 23 insertions(+), 11 deletions(-) diff --git a/Dockerfile b/Dockerfile index d69aa468be0..c0d0ce15e8a 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,7 +1,7 @@ FROM openjdk:8-jdk RUN apt-get update \ - && apt-get -y install postgresql-client \ - && rm -rf /var/lib/apt/lists/* + && apt-get -y install postgresql-client \ + && rm -rf /var/lib/apt/lists/* RUN mkdir -p /webknossos WORKDIR /webknossos @@ -17,6 +17,9 @@ RUN addgroup --system --gid 999 webknossos \ && chmod go+x bin/webknossos \ && chmod go+w . +RUN echo '#!/bin/bash\numask 002\n/bin/bash\n' > /docker-entrypoint.sh \ + && chmod +x /docker-entrypoint.sh + HEALTHCHECK \ --interval=1m --timeout=5s --retries=10 \ CMD curl --fail http://localhost:9000/api/buildinfo || exit 1 @@ -25,4 +28,5 @@ USER webknossos EXPOSE 9000 -ENTRYPOINT [ "bin/webknossos" ] +ENTRYPOINT [ "/docker-entrypoint.sh" ] +CMD [ "bin/webknossos" ] diff --git a/docker-compose.yml b/docker-compose.yml index 4483b8ac647..a87af1a5dbd 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -18,6 +18,7 @@ services: redis: condition: service_healthy command: + - bin/webknossos - -Dconfig.file=conf/application.conf - -Djava.net.preferIPv4Stack=true - -Dtracingstore.fossildb.address=fossildb @@ -42,10 +43,10 @@ services: image: scalableminds/webknossos-datastore:${DOCKER_TAG:-master} ports: - "9090:9090" - entrypoint: bin/webknossos-datastore volumes: - ./binaryData:/webknossos-datastore/binaryData command: + - bin/webknossos-datastore - -J-Xmx20G - -J-Xms1G - -Dconfig.file=conf/standalone-datastore.conf @@ -58,8 +59,8 @@ services: image: scalableminds/webknossos-tracingstore:${DOCKER_TAG:-master} ports: - "9050:9050" - entrypoint: bin/webknossos-tracingstore command: + - bin/webknossos-tracingstore - -J-Xmx20G - -J-Xms1G - -Dconfig.file=conf/standalone-tracingstore.conf diff --git a/tools/hosting/docker-compose.yml b/tools/hosting/docker-compose.yml index 09a54b4a859..0508bd062a6 100644 --- a/tools/hosting/docker-compose.yml +++ b/tools/hosting/docker-compose.yml @@ -13,6 +13,7 @@ services: redis: condition: service_healthy command: + - bin/webknossos - -Dconfig.file=conf/application.conf - -Djava.net.preferIPv4Stack=true - -Dtracingstore.fossildb.address=fossildb diff --git a/webknossos-datastore/Dockerfile b/webknossos-datastore/Dockerfile index 1d9fbec1b0a..862cd459ce7 100644 --- a/webknossos-datastore/Dockerfile +++ b/webknossos-datastore/Dockerfile @@ -15,6 +15,9 @@ RUN chown -R webknossos . \ && chmod go+x bin/webknossos-datastore \ && chmod go+w . +RUN echo '#!/bin/bash\numask 002\n/bin/bash\n' > /docker-entrypoint.sh \ + && chmod +x /docker-entrypoint.sh + USER webknossos HEALTHCHECK \ @@ -23,5 +26,5 @@ HEALTHCHECK \ EXPOSE 9090 -ENTRYPOINT ["bin/webknossos-datastore"] -CMD ["-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-datastore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] +ENTRYPOINT ["/docker-entrypoint.sh"] +CMD ["bin/webknossos-datastore", "-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-datastore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] diff --git a/webknossos-datastore/deployment/docker-compose.yml b/webknossos-datastore/deployment/docker-compose.yml index 7f677f8d0cb..560b309c5dd 100644 --- a/webknossos-datastore/deployment/docker-compose.yml +++ b/webknossos-datastore/deployment/docker-compose.yml @@ -3,8 +3,8 @@ version: "2.1" services: webknossos-datastore: image: scalableminds/webknossos-datastore:${DATASTORE_TAG} - entrypoint: bin/webknossos-datastore command: + - bin/webknossos-datastore - -J-Xmx20G - -J-Xms1G - -J-XX:+UseG1GC diff --git a/webknossos-tracingstore/Dockerfile b/webknossos-tracingstore/Dockerfile index 1f582f8ebf6..c0e9a612bea 100644 --- a/webknossos-tracingstore/Dockerfile +++ b/webknossos-tracingstore/Dockerfile @@ -15,6 +15,9 @@ RUN chown -R webknossos . \ && chmod go+x bin/webknossos-tracingstore \ && chmod go+w . +RUN echo '#!/bin/bash\numask 002\n/bin/bash\n' > /docker-entrypoint.sh \ + && chmod +x /docker-entrypoint.sh + USER webknossos HEALTHCHECK \ @@ -23,5 +26,5 @@ HEALTHCHECK \ EXPOSE 9050 -ENTRYPOINT ["bin/webknossos-tracingstore"] -CMD ["-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-tracingstore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] +ENTRYPOINT ["/docker-entrypoint.sh"] +CMD ["bin/webknossos-tracingstore", "-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-tracingstore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] diff --git a/webknossos-tracingstore/deployment/docker-compose.yml b/webknossos-tracingstore/deployment/docker-compose.yml index 281f68a3a71..80e3510ff90 100644 --- a/webknossos-tracingstore/deployment/docker-compose.yml +++ b/webknossos-tracingstore/deployment/docker-compose.yml @@ -3,8 +3,8 @@ version: "2.1" services: webknossos-tracingstore: image: scalableminds/webknossos-tracingstore:${DATASTORE_TAG} - entrypoint: bin/webknossos-tracingstore command: + - bin/webknossos-tracingstore - -J-Xmx20G - -J-Xms1G - -J-XX:+UseG1GC From b5d999bb62b4619ed56a2380708859c6a2b36c45 Mon Sep 17 00:00:00 2001 From: Norman Rzepka Date: Tue, 16 Nov 2021 13:41:29 +0100 Subject: [PATCH 3/6] fix entrypoint --- Dockerfile | 2 +- webknossos-datastore/Dockerfile | 2 +- webknossos-tracingstore/Dockerfile | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Dockerfile b/Dockerfile index c0d0ce15e8a..cfc6f1c9ba6 100644 --- a/Dockerfile +++ b/Dockerfile @@ -17,7 +17,7 @@ RUN addgroup --system --gid 999 webknossos \ && chmod go+x bin/webknossos \ && chmod go+w . -RUN echo '#!/bin/bash\numask 002\n/bin/bash\n' > /docker-entrypoint.sh \ +RUN echo '#!/bin/bash\numask 002\n/bin/bash "$@"\n' > /docker-entrypoint.sh \ && chmod +x /docker-entrypoint.sh HEALTHCHECK \ diff --git a/webknossos-datastore/Dockerfile b/webknossos-datastore/Dockerfile index 862cd459ce7..5ef1c2341a3 100644 --- a/webknossos-datastore/Dockerfile +++ b/webknossos-datastore/Dockerfile @@ -15,7 +15,7 @@ RUN chown -R webknossos . \ && chmod go+x bin/webknossos-datastore \ && chmod go+w . -RUN echo '#!/bin/bash\numask 002\n/bin/bash\n' > /docker-entrypoint.sh \ +RUN echo '#!/bin/bash\numask 002\n/bin/bash "$@"\n' > /docker-entrypoint.sh \ && chmod +x /docker-entrypoint.sh USER webknossos diff --git a/webknossos-tracingstore/Dockerfile b/webknossos-tracingstore/Dockerfile index c0e9a612bea..37d9cb2506a 100644 --- a/webknossos-tracingstore/Dockerfile +++ b/webknossos-tracingstore/Dockerfile @@ -15,7 +15,7 @@ RUN chown -R webknossos . \ && chmod go+x bin/webknossos-tracingstore \ && chmod go+w . -RUN echo '#!/bin/bash\numask 002\n/bin/bash\n' > /docker-entrypoint.sh \ +RUN echo '#!/bin/bash\numask 002\n/bin/bash "$@"\n' > /docker-entrypoint.sh \ && chmod +x /docker-entrypoint.sh USER webknossos From 5c34c6dd7650b03ec0ddc2e214e3b831396f59ee Mon Sep 17 00:00:00 2001 From: Norman Rzepka Date: Tue, 16 Nov 2021 13:55:37 +0100 Subject: [PATCH 4/6] docs --- CHANGELOG.unreleased.md | 2 +- MIGRATIONS.unreleased.md | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/CHANGELOG.unreleased.md b/CHANGELOG.unreleased.md index 1739b9ee12f..e4e2aaa0791 100644 --- a/CHANGELOG.unreleased.md +++ b/CHANGELOG.unreleased.md @@ -14,7 +14,7 @@ For upgrade instructions, please check the [migration guide](MIGRATIONS.released - Added a new bounding box tool that allows resizing and creating bounding boxes more easily. Additionally, the context menu now contains options to modify the bounding box close to the clicked position. [#5767](https://github.com/scalableminds/webknossos/pull/5767) ### Changed -- +- The docker setup has been restructured, which requires changes to existing docker-compose setups. See the migration guide for details. [#5843](https://github.com/scalableminds/webknossos/pull/5843) ### Fixed - diff --git a/MIGRATIONS.unreleased.md b/MIGRATIONS.unreleased.md index 299198282b0..f86de262460 100644 --- a/MIGRATIONS.unreleased.md +++ b/MIGRATIONS.unreleased.md @@ -8,6 +8,7 @@ User-facing changes are documented in the [changelog](CHANGELOG.released.md). ## Unreleased - The docker files now place the webKnossos installation under `/webknossos` instead of `/srv/webknossos`. All mounts, most importantly `/srv/webknossos/binaryData`, need to be changed accordingly. +- The entrypoint of the docker files have changed. Therefore, any existing `docker-compose.yml` setups need to be adapted. In most cases, the `entrypoint: bin/webknossos` lines need to be removed (if existant) and `bin/webknossos` needs to be pre-pended to the `command` specification. ### Postgres Evolutions: From 835a09da950f9107891d0d93e33025691f68b661 Mon Sep 17 00:00:00 2001 From: Norman Rzepka Date: Wed, 17 Nov 2021 16:37:12 +0100 Subject: [PATCH 5/6] pr feedback --- Dockerfile | 3 +-- MIGRATIONS.unreleased.md | 2 +- docker-compose.yml | 3 --- tools/hosting/docker-compose.yml | 1 - webknossos-datastore/Dockerfile | 4 ++-- webknossos-datastore/deployment/docker-compose.yml | 1 - webknossos-tracingstore/Dockerfile | 4 ++-- webknossos-tracingstore/deployment/docker-compose.yml | 1 - 8 files changed, 6 insertions(+), 13 deletions(-) diff --git a/Dockerfile b/Dockerfile index cfc6f1c9ba6..ac2ce014a2c 100644 --- a/Dockerfile +++ b/Dockerfile @@ -17,7 +17,7 @@ RUN addgroup --system --gid 999 webknossos \ && chmod go+x bin/webknossos \ && chmod go+w . -RUN echo '#!/bin/bash\numask 002\n/bin/bash "$@"\n' > /docker-entrypoint.sh \ +RUN echo '#!/bin/bash\numask 002\nbin/webknossos "$@"\n' > /docker-entrypoint.sh \ && chmod +x /docker-entrypoint.sh HEALTHCHECK \ @@ -29,4 +29,3 @@ USER webknossos EXPOSE 9000 ENTRYPOINT [ "/docker-entrypoint.sh" ] -CMD [ "bin/webknossos" ] diff --git a/MIGRATIONS.unreleased.md b/MIGRATIONS.unreleased.md index f86de262460..96cf842afec 100644 --- a/MIGRATIONS.unreleased.md +++ b/MIGRATIONS.unreleased.md @@ -8,7 +8,7 @@ User-facing changes are documented in the [changelog](CHANGELOG.released.md). ## Unreleased - The docker files now place the webKnossos installation under `/webknossos` instead of `/srv/webknossos`. All mounts, most importantly `/srv/webknossos/binaryData`, need to be changed accordingly. -- The entrypoint of the docker files have changed. Therefore, any existing `docker-compose.yml` setups need to be adapted. In most cases, the `entrypoint: bin/webknossos` lines need to be removed (if existant) and `bin/webknossos` needs to be pre-pended to the `command` specification. +- The entrypoint of the docker files have changed. Therefore, any existing `docker-compose.yml` setups need to be adapted. In most cases, only the `entrypoint: bin/webknossos` lines need to be removed (if existant). ### Postgres Evolutions: diff --git a/docker-compose.yml b/docker-compose.yml index a87af1a5dbd..f6c12516c2a 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -18,7 +18,6 @@ services: redis: condition: service_healthy command: - - bin/webknossos - -Dconfig.file=conf/application.conf - -Djava.net.preferIPv4Stack=true - -Dtracingstore.fossildb.address=fossildb @@ -46,7 +45,6 @@ services: volumes: - ./binaryData:/webknossos-datastore/binaryData command: - - bin/webknossos-datastore - -J-Xmx20G - -J-Xms1G - -Dconfig.file=conf/standalone-datastore.conf @@ -60,7 +58,6 @@ services: ports: - "9050:9050" command: - - bin/webknossos-tracingstore - -J-Xmx20G - -J-Xms1G - -Dconfig.file=conf/standalone-tracingstore.conf diff --git a/tools/hosting/docker-compose.yml b/tools/hosting/docker-compose.yml index 0508bd062a6..09a54b4a859 100644 --- a/tools/hosting/docker-compose.yml +++ b/tools/hosting/docker-compose.yml @@ -13,7 +13,6 @@ services: redis: condition: service_healthy command: - - bin/webknossos - -Dconfig.file=conf/application.conf - -Djava.net.preferIPv4Stack=true - -Dtracingstore.fossildb.address=fossildb diff --git a/webknossos-datastore/Dockerfile b/webknossos-datastore/Dockerfile index 5ef1c2341a3..bfc0c4aed78 100644 --- a/webknossos-datastore/Dockerfile +++ b/webknossos-datastore/Dockerfile @@ -15,7 +15,7 @@ RUN chown -R webknossos . \ && chmod go+x bin/webknossos-datastore \ && chmod go+w . -RUN echo '#!/bin/bash\numask 002\n/bin/bash "$@"\n' > /docker-entrypoint.sh \ +RUN echo '#!/bin/bash\numask 002\nbin/webknossos-datastore "$@"\n' > /docker-entrypoint.sh \ && chmod +x /docker-entrypoint.sh USER webknossos @@ -27,4 +27,4 @@ HEALTHCHECK \ EXPOSE 9090 ENTRYPOINT ["/docker-entrypoint.sh"] -CMD ["bin/webknossos-datastore", "-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-datastore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] +CMD ["-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-datastore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] diff --git a/webknossos-datastore/deployment/docker-compose.yml b/webknossos-datastore/deployment/docker-compose.yml index 560b309c5dd..321afc9e5e2 100644 --- a/webknossos-datastore/deployment/docker-compose.yml +++ b/webknossos-datastore/deployment/docker-compose.yml @@ -4,7 +4,6 @@ services: webknossos-datastore: image: scalableminds/webknossos-datastore:${DATASTORE_TAG} command: - - bin/webknossos-datastore - -J-Xmx20G - -J-Xms1G - -J-XX:+UseG1GC diff --git a/webknossos-tracingstore/Dockerfile b/webknossos-tracingstore/Dockerfile index 37d9cb2506a..53a498c8f48 100644 --- a/webknossos-tracingstore/Dockerfile +++ b/webknossos-tracingstore/Dockerfile @@ -15,7 +15,7 @@ RUN chown -R webknossos . \ && chmod go+x bin/webknossos-tracingstore \ && chmod go+w . -RUN echo '#!/bin/bash\numask 002\n/bin/bash "$@"\n' > /docker-entrypoint.sh \ +RUN echo '#!/bin/bash\numask 002\nbin/webknossos-tracingstore "$@"\n' > /docker-entrypoint.sh \ && chmod +x /docker-entrypoint.sh USER webknossos @@ -27,4 +27,4 @@ HEALTHCHECK \ EXPOSE 9050 ENTRYPOINT ["/docker-entrypoint.sh"] -CMD ["bin/webknossos-tracingstore", "-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-tracingstore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] +CMD ["-J-Xmx20G", "-J-Xms1G", "-Dconfig.file=conf/standalone-tracingstore.conf", "-Dlogger.file=conf/logback-docker.xml", "-Dlogback.configurationFile=conf/logback-docker.xml", "-Dhttp.port=9090", "-Dhttp.address=0.0.0.0"] diff --git a/webknossos-tracingstore/deployment/docker-compose.yml b/webknossos-tracingstore/deployment/docker-compose.yml index 80e3510ff90..dde7d6044d0 100644 --- a/webknossos-tracingstore/deployment/docker-compose.yml +++ b/webknossos-tracingstore/deployment/docker-compose.yml @@ -4,7 +4,6 @@ services: webknossos-tracingstore: image: scalableminds/webknossos-tracingstore:${DATASTORE_TAG} command: - - bin/webknossos-tracingstore - -J-Xmx20G - -J-Xms1G - -J-XX:+UseG1GC From 1986283c221767d2df9a7a8da7094a235c81f838 Mon Sep 17 00:00:00 2001 From: Norman Rzepka Date: Wed, 17 Nov 2021 17:21:32 +0100 Subject: [PATCH 6/6] remove newrelic env vars --- webknossos-datastore/deployment/docker-compose.yml | 3 --- webknossos-tracingstore/deployment/docker-compose.yml | 3 --- 2 files changed, 6 deletions(-) diff --git a/webknossos-datastore/deployment/docker-compose.yml b/webknossos-datastore/deployment/docker-compose.yml index 321afc9e5e2..108c6f955c7 100644 --- a/webknossos-datastore/deployment/docker-compose.yml +++ b/webknossos-datastore/deployment/docker-compose.yml @@ -23,6 +23,3 @@ services: - $BINARY_DATA_PATH:/webknossos-datastore/binaryData - ./tmp:/tmp - ./config/datastore-docker.conf:/webknossos-datastore/conf/docker.conf - environment: - - NEW_RELIC_LICENSE_KEY - - NEW_RELIC_APP_NAME diff --git a/webknossos-tracingstore/deployment/docker-compose.yml b/webknossos-tracingstore/deployment/docker-compose.yml index dde7d6044d0..9133df3c974 100644 --- a/webknossos-tracingstore/deployment/docker-compose.yml +++ b/webknossos-tracingstore/deployment/docker-compose.yml @@ -25,9 +25,6 @@ services: volumes: - ./tmp:/tmp - ./config/tracingstore-docker.conf:/webknossos-tracingstore/conf/docker.conf - environment: - - NEW_RELIC_LICENSE_KEY - - NEW_RELIC_APP_NAME fossildb: image: scalableminds/fossildb:${FOSSILDB_TAG}