This image enables you to run Atlassian JIRA Software.
It is based on Alpine Linux to provide an as small as possible image.
- Versions prior to 7.12 (or service desk 3.15) use alpine-java to provide an Oracle JDK.
- Starting from 7.13 (or service desk 3.16) adoptopenjdk/openjdk8 is used since Atlassian supports OpenJDK from this version.
In order to set up the autogeneration of images the repositories had to be restructured meaning that if you were using the old (application)-X.Y.Z style tags they are now obsolete, you should switch to the X.Y.Z style tags.
There are tags available for latest, latest major, latest minor and individual versions. If for example you want to run the latest 8.0 version, you can use draca/atlassian-jira-software:8.0
The images are autogenerated as soon as they appear for download on the Atlassian website. This means that sometimes things might break, be aware of this and as always test in staging environments first.
You can find the script that generates these in the atlassian-generator repository. Feel free to create pull requests to that repository if you want to make improvements either to the script or the Dockerfile templates. Please do not make pull requests against this repository as they will be ignored.
A number of environment variables are supported.
By default the application runs as a non-root user. You can influence which user by setting these variables. Note that the names need to be known inside the container so results might not be what you expect.
- RUN_USER
- RUN_GROUP
Note that if you change the username, Java requires that the HOME directory for that user exists, this image automatically assigns the data folder as home directory.
If you are running the application behind a reverse proxy you need to set these variables so that it knows where to redirect requests to.
- JIRA_PROXY_NAME : the hostname (for example jira.mycompany.com)
- JIRA_PROXY_PORT : the port (for example 80 or 443)
- JIRA_PROXY_SCHEME : either http or https
- JIRA_CONTEXT_PATH : if the application isn't running on the root path (for example mycompany.com/jira: set this to jira)
If you want to disable the incoming and outgoing mail on for example a staging server set DISABLE_NOTIFICATIONS to TRUE
Change the default JVM memory size
- JVM_MINIMUM_MEMORY
- JVM_MAXIMUM_MEMORY
If you need to pass additional args you can set the JIRA_ARGS variable.
You can set the CONTAINER_TZ variable to set the default timezone in your container. Jira inherits this if it is configured to use the system default.
This image disables the Tomcat access logs by default as they can grow quite large for popular instances and quickly fill up the container. Should you have need for them you can enable them again by setting KEEP_ACCESS_LOGS to TRUE. You probably also want to mount a volume to /opt/atlassian/jira/install/logs.
The bane of every Atlassian Expert their existence! But fear no longer as this image can automatically import the certificates into the key database. It searches for files ending with .crt in /opt/atlassian/jira/certs so just mount a volume and Bob's your uncle.
If you don't know how to get the certificates here's a simple one-liner fetching the certificate from Google, replace the domain with the one you want to import from.
openssl s_client -connect google.com:443 < /dev/null | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > google-public.crt
If you want to mount a volume or a directory to store your data outside of the container you should mount it over /opt/atlassian/jira/data
Example:
docker run -it --rm -p 8080:8080 draca/atlassian-jira-software
A very quick docker-compose file could be:
version: '3'
services:
jira:
image: draca/atlassian-jira-software
environment:
- DISABLE_NOTIFICATIONS=TRUE
- JIRA_ARGS=-Datlassian.plugins.enable.wait=300
volumes:
- ./data:/opt/atlassian/jira/data
ports:
- 8080:8080
restart: always
jiradb:
image: postgres:9.6
environment:
- POSTGRES_PASSWORD=secret
- POSTGRES_USER=jira
- POSTGRES_DB=jira
volumes:
- ./db:/var/lib/postgresql/data
restart: always
A lot of care was taken in creating these images however running them is at your own risk and no claims can be made should data loss occur. By using these images you confirm that you are complying by any and all of the licenses of the 3rd party software included in this build.