forked from StaPH-B/docker-builds
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile_builder
129 lines (101 loc) · 5.94 KB
/
Dockerfile_builder
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### Thank you for using this Dockerfile template! #####
##### This is an outline for the flow of building a docker image. #####
##### The docker image is built to the 'app' stage on dockerhub/quay. #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### Sometimes tools required to build a tool are not needed to run #####
##### it. This means that images are larger than they need to be. A way #####
##### to reduce the size of an image, is to have a stage prior to 'app' #####
##### where these temporarily-required tools are installed. Then, only #####
##### relevant executables and files are copied in to the 'app' stage. #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### Step 1. Set up the builder stage as the first stage. #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
# Please note, all 'LABEL', 'ENV', and 'CMD' instructions will be lost
# Also, files and executables are not carried over unless they are explicitly copied.
# 'FROM' defines where the Dockerfile is starting to build from. This command has to come first in the file
FROM ubuntu:jammy as builder
# 'RUN' executes code during the build
# Install dependencies via apt-get or yum if using a centos or fedora base
RUN apt-get update && apt-get install -y --no-install-recommends \
dependency_a \
dependency_b \
dependency_c && \
apt-get autoclean && rm -rf /var/lib/apt/lists/*
# Install and/or setup more things. Make /data for use as a working dir
# For readability, limit one install per 'RUN' statement.
# Example: install ncbi-blast+ 2.9.0 pre-compiled linux binaries
ARG BLAST_VER=2.9.0
RUN wget ftp://ftp.ncbi.nlm.nih.gov/blast/executables/blast+/${BLAST_VER}/ncbi-blast-${BLAST_VER}+-x64-linux.tar.gz && \
tar -xzf ncbi-blast-${BLAST_VER}+-x64-linux.tar.gz && \
rm ncbi-blast-${BLAST_VER}+-x64-linux.tar.gz
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### Step 2. Set up the base image in the 'app' stage. #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
# 'FROM' defines where the Dockerfile is starting to build from. This command has to come first in the file
# The 'as' keyword lets you name the folowing stage. The production image uses everything to the 'app' stage.
FROM ubuntu:jammy as app
# List all software versions are ARGs near the top of the dockerfile
# 'ARG' sets environment variables during the build stage
# ARG variables are ONLY available during image build, they do not persist in the final image
ARG SOFTWARENAME_VER="1.0.0"
# 'LABEL' instructions tag the image with metadata that might be important to the user
LABEL base.image="ubuntu:jammy"
LABEL dockerfile.version="1"
LABEL software="SoftwareName"
LABEL software.version="${SOFTWARENAME_VER}"
LABEL description="This software does X, Y, AND Z!"
LABEL website="https://github.com/StaPH-B/docker-builds"
LABEL license="https://github.com/StaPH-B/docker-builds/blob/master/LICENSE"
LABEL maintainer="FirstName LastName"
LABEL maintainer.email="[email protected]"
# copy in files and executables into app stage
COPY --from=builder <source> <destination>
# example copy in blast executable
ARG BLAST_VER=2.9.0
COPY --from=builder /bwa/bwa-${BWA_VER}/bwa /usr/local/bin
# 'RUN' executes code during the build
# Install dependencies via apt-get or yum if using a centos or fedora base
# Please ensure ALL dependencies for running the tool make it into this stage
RUN apt-get update && apt-get install -y --no-install-recommends \
dependency_a \
dependency_b \
dependency_c && \
apt-get autoclean && rm -rf /var/lib/apt/lists/*
# Install and/or setup more things. Make /data for use as a working dir
# For readability, limit one install per 'RUN' statement.
# 'ENV' instructions set environment variables that persist from the build into the resulting image
# Use for e.g. $PATH and locale settings for compatibility with Singularity
ENV PATH="/software-${SOFTWARENAME_VER}/bin:$PATH" \
LC_ALL=C
# 'CMD' instructions set a default command when the container is run. This is typically 'tool --help.'
CMD [ "tool", "--help" ]
# 'WORKDIR' sets working directory
WORKDIR /data
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
##### Step 3. Set up the testing stage. #####
##### The docker image is built to the 'test' stage before merging, but #####
##### the test stage (or any stage after 'app') will be lost. #####
##### ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- ----- #####
# A second FROM insruction creates a new stage
# The test stage must be downstream from 'app'
FROM app as test
# set working directory so that all test inputs & outputs are kept in /test
WORKDIR /test
# print help and version info; check dependencies (not all software has these options available)
# Mostly this ensures the tool of choice is in path and is executable
RUN softwarename --help && \
softwarename --check && \
softwarename --version
# Demonstrate that the program is successfully installed - which is highly dependant on what the tool is.
# Run the program's internal tests if available, for example with SPAdes:
RUN spades.py --test
# Option 1: write your own tests in a bash script in the same directory as your Dockerfile and copy them:
COPY my_tests.sh .
RUN bash my_tests.sh
# Option 2: write below common usage cases, for example with tb-profiler:
RUN wget ftp://ftp.sra.ebi.ac.uk/vol1/fastq/ERR166/009/ERR1664619/ERR1664619_1.fastq.gz && \
wget ftp://ftp.sra.ebi.ac.uk/vol1/fastq/ERR166/009/ERR1664619/ERR1664619_2.fastq.gz && \
tb-profiler profile -1 ERR1664619_1.fastq.gz -2 ERR1664619_2.fastq.gz -t 4 -p ERR1664619 --txt