Geen omschrijving

LabKey 99f4e59291 Updating paths and fixing ip range for labkey_network 6 maanden geleden
bin 99f4e59291 Updating paths and fixing ip range for labkey_network 6 maanden geleden
config 90f776a154 Updating for version 23 6 maanden geleden
packages 1262b05fb2 Significant clean-up, modified instructions 6 maanden geleden
tomcat 130b2d04fc Renaming misleading tomcat8 director to tomcat (version 9 used since LabKey19) 6 maanden geleden
README.md 130b2d04fc Renaming misleading tomcat8 director to tomcat (version 9 used since LabKey19) 6 maanden geleden

README.md

Labkey as a docker container

This git project contains everything required to start labkey as a docker container.

Installation

Prepare

sudo adduser labkey
sudo usermod -G docker labkey
  • clone the software
sudo su labkey
cd
git clone https://git0.fmf.uni-lj.si/studen/labkeyDocker.git

Database

Create directory or copy appropriate database cluster to labkeyDocker/postgresql/data:

mkdir -p labkeyDocker/postgresql/data

Check if database runs:

labkeyDocker/bin/startPGonly.sh
docker logs config-labkey-db-1
labkeyDocker/bin/stopLabkey.sh

Files and external modules for LabKey

If old files and external modules are available, they should be either copied or linked to labkeyDocker/labkeyBase/files and labkeyDocker/labkeyBase/externalModules.

Install LabKey binaries

  • run labkeyDocker/bin/installLabkey.sh 22.3 to unzip the enclosed LabKey binary code and make appropriate links.
  • copy labkeyDocker/bin/env.sh.sample to labkeyDocker/bin/env.sh and set a secret $PGPASS, other settings are probably OK, check $DOCKERCOMPOSE
  • set the same value as password in labkeyDocker/tomcat/conf/Catalina/localhost/labkey.xml

Permissions

To run as non-root user labkey, files should have the proper permissions. I believe that starting from scratch, the neccesary files will be created with appropriate permissions. If using an old implementation or in case of troubles, the following directories should be owned by labkey:labkey on host machine:

~/labkey/externalModules
~/labkey/files

Start containers

Run bin/startLabkey.sh. This will do several things:

  • Download PostgreSQL image and initialize a persistent database at ~/postgresl/data.
  • Build a combined tomcat/R image from a recent version of tomcat
  • Copy and link files from home to the server
  • Start the server

Check the installation

In principle, the service should be running at http://localhost:8443/labkey. Check output of inidividual components by:

  docker logs config-db-1
  docker logs config-web-1
  docker exec -it config-db-1 bash
  

Add ggplot2 to R

Connect to running instance of labkey:

docker exec -it config_labkey-web_1 bash

Start R:

R

In R, installggplot2 with dependencies:

install.packages('ggplot2', repos='http://cran.us.r-project.org', dependencies=TRUE)

Install ggpubr

For ggpubr, install cmake first. When in config_labkey-web_1 do:

apt update
apt install cmake

Then, in R:

install.packages('ggpubr')

Manage postgresql

Create ${POSTGRES_DIR} directory as user that will be running the container. If you have trouble with initial setup, the base can be reset by deleting everything under postgresql/data.

Expected errors

Errors of the type 500: Unexpected server error are common and related