Buiding a deps image - stjude/proteinpaint GitHub Wiki

The deps image is placed in: proteinpaint/container/deps

The purpose of the deps image is to speed up the build process by already having prebuilt binaries, R and R libraries, Rust dependency, etc, so when ppserver and ppfull images are built, the built is faster, because the ppfull and ppserver image are built from the deps image.

In case a new binary, R library, Rust dependency, etc is added to the project, it should be added to the deps image: proteinpaint/container/deps

It's recommended to prune all the images before building the deps image:

docker system prune -a

To test the updated deps image locally, perform the following steps: cd /container/deps ./version.sh deps ./build.sh"

The new deps image version named "ppfull:latest" and "ppserver:latest" should be added to

proteinpaint/container/ppfull/Dockerfile

ARG VERSION=latest

#########################

# Full app update

#########################

FROM ppfull:$VERSION

and:

proteinpaint/container/server/Dockerfile

ARG VERSION=latest

#########################

# Server-only app update

#########################

FROM ppserver:$VERSION

Simulate the Docker build:

Remove all previous builds/images in docker manually before the following steps.

For the full build (recommended), do the following:

cd container
./pack.sh
./build2.sh -z full
./run.sh ppfull:NEW_VERSION # requires a serverconfig.json, read the NEW_VERSION from the list of docker images. 

It requires minimal serverconfig.json in the container dir.

For the server only build which doesn't include client code, do the following:

cd container
./pack.sh
./build2.sh -z server #in case server only build is tested, execute this and the following step, otherwise skip both.
./run.sh ppserver:NEW_VERSION # requires a serverconfig.json, read the NEW_VERSION from the list of docker images. 

It requires minimal serverconfig.json in the container dir.

Example minimal serverconfig.json in the container dir

{
   "tpmasterdir": "...",
   "port": 3000,
   "genomes": [
      {
         "name": "hg19",
         "species": "human",
         "file": "./genome/hg19.js",
         "datasets": [
            {
               "name": "ClinVar",
               "jsfile": "./dataset/clinvar.hg19.js"
            }
         ]
      },
      {
         "name": "hg38",
         "species": "human",
         "file": "./genome/hg38.js",
         "datasets": [
            {
               "name": "ClinVar",
               "jsfile": "./dataset/clinvar.hg38.js"
            }
         ]
      }
   ],
   "backend_only": false,
   "URL": "http://localhost:3456"
}

In case everything works as expected locally, release a new deps image using CI action. :

https://github.com/stjude/proteinpaint/actions/workflows/CD-publish-deps-image.yml

In case the build is successful, the deps image versions are updated inside of:

proteinpaint/container/ppfull/Dockerfile

ARG VERSION=NEW_VERSION

and:

proteinpaint/container/server/Dockerfile

ARG VERSION=NEW_VERSION

It's possible to read the new version here: github repo.

Start a new release using the github action.

to check logs of the pp server side code run:

docker logs pp

to check logs of the same ppfull container on the production servers run:

podman logs {pp-cont_name}