-
Notifications
You must be signed in to change notification settings - Fork 219
/
Copy pathDockerfile
159 lines (146 loc) · 9.69 KB
/
Dockerfile
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
FROM adoptopenjdk/openjdk11-openj9:x86_64-alpine-jre-11.0.15_10_openj9-0.32.0
# this image already contains glibc
ENV JIRA_USER=jira \
JIRA_GROUP=jira \
CONTAINER_UID=1000 \
CONTAINER_GID=1000 \
JIRA_CONTEXT_PATH=ROOT \
JIRA_HOME=/var/atlassian/jira \
JIRA_INSTALL=/opt/jira \
JIRA_SCRIPTS=/usr/local/share/atlassian \
JRE_HOME=$JAVA_HOME \
# Fix for this issue - https://jira.atlassian.com/browse/JRASERVER-46152 \
_RUNJAVA=java
COPY bin $JIRA_SCRIPTS
WORKDIR /tmp
# glibc and pub key already installed by parent image; we need to install latest bin and i18n
RUN export GLIBC_VERSION=2.29-r0 \
&& export GLIBC_DOWNLOAD_URL=https://github.com/sgerrand/alpine-pkg-glibc/releases/download/$GLIBC_VERSION \
&& export GLIBC_BIN=glibc-bin-$GLIBC_VERSION.apk \
&& export GLIBC_I18N=glibc-i18n-$GLIBC_VERSION.apk \
&& apk add --update --no-cache --upgrade \
ssl_client \
ca-certificates \
&& wget -O $GLIBC_BIN $GLIBC_DOWNLOAD_URL/$GLIBC_BIN \
&& wget -O $GLIBC_I18N $GLIBC_DOWNLOAD_URL/$GLIBC_I18N \
&& apk add \
--update \
--no-cache \
bash \
su-exec \
gzip \
nano \
tini \
wget \
xmlstarlet \
$GLIBC_BIN \
$GLIBC_I18N \
fontconfig \
msttcorefonts-installer \
ttf-dejavu \
ghostscript \
graphviz \
motif \
&& update-ms-fonts \
&& fc-cache -f \
&& export JIRA_LIB=$JIRA_INSTALL/lib \
&& mkdir -p $JIRA_HOME $JIRA_INSTALL $JIRA_LIB \
&& addgroup -g $CONTAINER_GID $JIRA_GROUP \
# Install database drivers \
&& export MYSQL_DRIVER_VERSION=5.1.47 \
&& export MYSQL_FILE_BASE=mysql-connector-java-$MYSQL_DRIVER_VERSION \
&& export MYSQL_FILE_TAR=$MYSQL_FILE_BASE.tar.gz \
&& export MYSQL_FILE_BIN=$MYSQL_FILE_BASE-bin.jar \
&& export MYSQL_DOWNLOAD_URL=https://dev.mysql.com/get/Downloads/Connector-J/$MYSQL_FILE_TAR \
&& export POSTGRESQL_DRIVER_VERSION=42.2.5 \
&& export POSTGRESQL_FILE=postgresql-$POSTGRESQL_DRIVER_VERSION.jar \
&& export POSTGRESQL_DOWNLOAD_URL=https://jdbc.postgresql.org/download/$POSTGRESQL_FILE \
&& rm -f $JIRA_LIB/mysql-connector-java*.jar \
&& wget -O $MYSQL_FILE_TAR $MYSQL_DOWNLOAD_URL \
&& tar xzf $MYSQL_FILE_TAR --strip=1 \
&& cp $MYSQL_FILE_BIN $JIRA_LIB/$MYSQL_FILE_BIN \
&& rm -f $JIRA_LIB/postgresql-*.jar \
&& wget -O $JIRA_LIB/$POSTGRESQL_FILE $POSTGRESQL_DOWNLOAD_URL \
# Dockerize \
&& export DOCKERIZE_VERSION=v0.6.1 \
&& export DOCKERIZE_DOWNLOAD_URL=https://github.com/jwilder/dockerize/releases/download/$DOCKERIZE_VERSION/dockerize-alpine-linux-amd64-$DOCKERIZE_VERSION.tar.gz \
# Install Dockerize \
&& wget -O dockerize.tar.gz $DOCKERIZE_DOWNLOAD_URL \
&& tar -C /usr/local/bin -xzvf dockerize.tar.gz \
&& rm dockerize.tar.gz \
# Let's Encrypt \
&& export LE_DOWNLOAD_URL=https://letsencrypt.org/certs/ \
&& export LE_AUTH_1=letsencryptauthorityx1.der \
&& export LE_AUTH_2=letsencryptauthorityx2.der \
&& export LE_CROSS_1=lets-encrypt-x1-cross-signed.der \
&& export LE_CROSS_2=lets-encrypt-x2-cross-signed.der \
&& export LE_CROSS_3=lets-encrypt-x3-cross-signed.der \
&& export LE_CROSS_4=lets-encrypt-x4-cross-signed.der \
# Adding Let's Encrypt CA to truststore \
&& export KEYSTORE=$JRE_HOME/lib/security/cacerts \
&& wget $LE_DOWNLOAD_URL/$LE_AUTH_1 \
&& wget $LE_DOWNLOAD_URL/$LE_AUTH_2 \
&& wget $LE_DOWNLOAD_URL/$LE_CROSS_1 \
&& wget $LE_DOWNLOAD_URL/$LE_CROSS_2 \
&& wget $LE_DOWNLOAD_URL/$LE_CROSS_3 \
&& wget $LE_DOWNLOAD_URL/$LE_CROSS_4 \
&& keytool -trustcacerts -keystore $KEYSTORE -storepass changeit -noprompt -importcert -alias isrgrootx1 -file $LE_AUTH_1 \
&& keytool -trustcacerts -keystore $KEYSTORE -storepass changeit -noprompt -importcert -alias isrgrootx2 -file $LE_AUTH_2 \
&& keytool -trustcacerts -keystore $KEYSTORE -storepass changeit -noprompt -importcert -alias letsencryptauthorityx1 -file $LE_CROSS_1 \
&& keytool -trustcacerts -keystore $KEYSTORE -storepass changeit -noprompt -importcert -alias letsencryptauthorityx2 -file $LE_CROSS_2 \
&& keytool -trustcacerts -keystore $KEYSTORE -storepass changeit -noprompt -importcert -alias letsencryptauthorityx3 -file $LE_CROSS_3 \
&& keytool -trustcacerts -keystore $KEYSTORE -storepass changeit -noprompt -importcert -alias letsencryptauthorityx4 -file $LE_CROSS_4 \
# Remove build packages \
&& apk del \
--no-cache \
msttcorefonts-installer \
# Clean caches and tmps \
&& rm -rf /var/cache/apk/* /tmp/* /var/log/*
# Version
ARG JIRA_VERSION=8.22.4
# Language
ARG LANG_LANGUAGE=en
ARG LANG_COUNTRY=US
RUN /usr/glibc-compat/bin/localedef -i ${LANG_LANGUAGE}_${LANG_COUNTRY} -f UTF-8 ${LANG_LANGUAGE}_${LANG_COUNTRY}.UTF-8
# Product
ARG JIRA_PRODUCT=jira-software
RUN wget -O jira.bin https://www.atlassian.com/software/jira/downloads/binary/atlassian-$JIRA_PRODUCT-$JIRA_VERSION-x64.bin \
&& chmod +x jira.bin \
# JAVA_TOOL_OPTIONS, JAVA_HOME, and PATH already get set by AdoptOpenJDK image \
# Since installer uses Oracle JDK 8, it does not recognize 'IgnoreUnrecognizedVMOptions' or 'UseContainerSupport' in JAVA_TOOL_OPTIONS \
&& export JAVA_TOOL_OPTIONS="" \
# Run installer \
&& ./jira.bin -q -varfile $JIRA_SCRIPTS/response.varfile \
# remove installer JRE and link to AdoptOpenJDK \
&& rm -rf $JIRA_INSTALL/jre \
&& ln -s $JAVA_HOME $JIRA_INSTALL/jre \
# Add user must come after installer to avoid this: \
# https://confluence.atlassian.com/jirakb/how-to-set-the-user-jira-to-run-in-linux-433390559.html \
&& adduser -u $CONTAINER_UID \
-G $JIRA_GROUP \
-h /home/$JIRA_USER \
-s /bin/bash \
-S $JIRA_USER \
# Install Atlassian SSL tool - mainly to be able to create application links with other Atlassian tools, which run LE SSL certificates \
&& wget -O /home/$JIRA_USER/SSLPoke.class https://confluence.atlassian.com/kb/files/779355358/779355357/1/1441897666313/SSLPoke.class \
# Set permissions \
&& chown -R $JIRA_USER:$JIRA_GROUP $JIRA_HOME $JIRA_INSTALL $JIRA_SCRIPTS /home/$JIRA_USER \
# Clean caches and tmps \
&& rm -rf /var/cache/apk/* /tmp/* /var/log/*
USER $JIRA_USER
WORKDIR $JIRA_HOME
VOLUME ["$JIRA_HOME"]
EXPOSE 8080
ENTRYPOINT ["/sbin/tini","--","/usr/local/share/atlassian/docker-entrypoint.sh"]
CMD ["jira"]
# This is set by the build script. Keep this at the end of the Dockerfile to preserve the build cache
ARG BUILD_DATE
# Image Metadata
LABEL maintainer="Jonathan Hult <[email protected]>" \
org.opencontainers.image.authors="Jonathan Hult <[email protected]>" \
org.opencontainers.image.url="https://hub.docker.com/r/teamatldocker/jira/" \
org.opencontainers.image.title=$JIRA_PRODUCT \
org.opencontainers.image.description="$JIRA_PRODUCT $JIRA_VERSION running on Alpine Linux" \
org.opencontainers.image.source="https://github.com/teamatldocker/jira/" \
org.opencontainers.image.created=$BUILD_DATE \
org.opencontainers.image.version=$JIRA_VERSION