2022-01-23 20:57:28 +01:00
|
|
|
# syntax=docker/dockerfile:1
|
2022-01-24 20:08:55 +01:00
|
|
|
FROM ubuntu:18.04 AS os-dependencies
|
2022-01-23 20:57:28 +01:00
|
|
|
|
2022-01-24 20:08:55 +01:00
|
|
|
# Install system dependencies.
|
2022-01-23 20:57:28 +01:00
|
|
|
RUN apt-get update -y && \
|
|
|
|
apt-get -y install libimage-exiftool-perl
|
|
|
|
|
2022-01-24 05:44:38 +01:00
|
|
|
FROM continuumio/miniconda3:4.10.3p0-alpine
|
2022-01-23 20:57:28 +01:00
|
|
|
|
2022-01-24 20:08:55 +01:00
|
|
|
# From the previous image, copy exiftool into this image.
|
|
|
|
COPY --from=os-dependencies /usr/bin/exiftool /usr/bin/exiftool
|
2022-01-23 20:57:28 +01:00
|
|
|
|
2022-01-24 20:08:55 +01:00
|
|
|
# Add the local code to the /app directory and set it to be the working directory.
|
|
|
|
# Since we mount the /app directory as a volume in docker-compose.yml, this
|
|
|
|
# allows us to automatically update the code in the Docker image when it's changed.
|
|
|
|
ADD . /app
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
# Get the arguments from the docker-compose environment.
|
2022-01-24 05:44:38 +01:00
|
|
|
ARG PORT
|
|
|
|
EXPOSE ${PORT}
|
2022-01-23 20:57:28 +01:00
|
|
|
|
2022-01-24 20:08:55 +01:00
|
|
|
# Create the conda environment.
|
2022-01-23 20:57:28 +01:00
|
|
|
RUN conda env create -f environment.yml
|
|
|
|
|
2022-01-24 05:44:38 +01:00
|
|
|
# Use the conda environment we created to run the application.
|
2022-01-24 20:08:55 +01:00
|
|
|
# To enable the conda env, we cannot simply RUN `conda activate semantic-search`,
|
|
|
|
# since each RUN command in a Dockerfile is a separate bash shell.
|
|
|
|
# The environment would not carry forward.
|
|
|
|
# Instead, we'll use `conda run` to run the application.
|
|
|
|
# There are more arguments required for the script to run,
|
|
|
|
# but these should be passed in through the docker-compose.yml file.
|
2022-01-24 05:44:38 +01:00
|
|
|
ENTRYPOINT ["conda", "run", "--no-capture-output", "--name", "semantic-search", \
|
|
|
|
"python3", "-m", "src.main"]
|