1
0
Fork 0
archivebox/Dockerfile

111 lines
3.9 KiB
Docker
Raw Normal View History

# This is the Dockerfile for ArchiveBox, it bundles the following dependencies:
# python3, ArchiveBox, curl, wget, git, chromium, youtube-dl, single-file
2019-02-28 14:04:37 -05:00
# Usage:
# docker build . -t archivebox --no-cache
2020-07-22 01:30:58 -04:00
# docker run -v "$PWD/data":/data archivebox init
# docker run -v "$PWD/data":/data archivebox add 'https://example.com'
# docker run -v "$PWD/data":/data -it archivebox manage createsuperuser
# docker run -v "$PWD/data":/data -p 8000:8000 archivebox server
2019-02-28 14:04:37 -05:00
2020-06-25 17:46:11 -04:00
FROM python:3.8-slim-buster
2019-07-09 13:05:51 -04:00
2020-06-25 17:46:11 -04:00
LABEL name="archivebox" \
maintainer="Nick Sweeting <archivebox-docker@sweeting.me>" \
description="All-in-one personal internet archiving container" \
2020-11-23 02:04:39 -05:00
homepage="https://github.com/ArchiveBox/ArchiveBox" \
documentation="https://github.com/ArchiveBox/ArchiveBox/wiki/Docker#docker"
2018-10-13 22:47:30 -04:00
# System-level base config
2020-06-25 21:30:29 -04:00
ENV TZ=UTC \
2020-06-25 17:46:11 -04:00
LANGUAGE=en_US:en \
LC_ALL=C.UTF-8 \
2020-06-25 21:30:29 -04:00
LANG=C.UTF-8 \
2020-06-25 17:46:11 -04:00
PYTHONIOENCODING=UTF-8 \
PYTHONUNBUFFERED=1 \
DEBIAN_FRONTEND=noninteractive \
APT_KEY_DONT_WARN_ON_DANGEROUS_USAGE=1
2018-10-13 22:47:30 -04:00
# Application-level base config
ENV CODE_DIR=/app \
2020-06-25 17:46:11 -04:00
VENV_PATH=/venv \
DATA_DIR=/data \
NODE_DIR=/node \
ARCHIVEBOX_USER="archivebox"
# Create non-privileged user for archivebox and chrome
RUN groupadd --system $ARCHIVEBOX_USER \
&& useradd --system --create-home --gid $ARCHIVEBOX_USER --groups audio,video $ARCHIVEBOX_USER
# Install system dependencies
RUN apt-get update -qq \
2020-06-25 17:46:11 -04:00
&& apt-get install -qq -y --no-install-recommends \
2020-08-14 00:14:18 -04:00
apt-transport-https ca-certificates gnupg2 zlib1g-dev \
2020-08-18 01:59:04 -04:00
dumb-init gosu cron unzip curl \
&& rm -rf /var/lib/apt/lists/*
2020-08-14 00:14:18 -04:00
# Install apt dependencies
RUN apt-get update -qq \
&& apt-get install -qq -y --no-install-recommends \
wget curl chromium git ffmpeg youtube-dl \
fontconfig fonts-ipafont-gothic fonts-wqy-zenhei fonts-thai-tlwg fonts-kacst fonts-symbola fonts-noto fonts-freefont-ttf \
&& rm -rf /var/lib/apt/lists/*
# Install Node environment
RUN curl -s https://deb.nodesource.com/gpgkey/nodesource.gpg.key | apt-key add - \
&& echo 'deb https://deb.nodesource.com/node_14.x buster main' >> /etc/apt/sources.list \
2020-06-25 21:30:29 -04:00
&& apt-get update -qq \
2020-06-25 17:46:11 -04:00
&& apt-get install -qq -y --no-install-recommends \
nodejs \
&& rm -rf /var/lib/apt/lists/*
2020-04-22 21:13:49 -04:00
2020-09-08 18:12:55 -04:00
# Install Node dependencies
WORKDIR "$NODE_DIR"
ENV PATH="${PATH}:$NODE_DIR/node_modules/.bin" \
npm_config_loglevel=error
RUN npm install -g npm
ADD ./package.json ./package.json
ADD ./package-lock.json ./package-lock.json
RUN npm ci
# Install Python dependencies
WORKDIR "$CODE_DIR"
2020-07-28 00:53:50 -04:00
ENV PATH="${PATH}:$VENV_PATH/bin"
2020-06-25 21:30:29 -04:00
RUN python -m venv --clear --symlinks "$VENV_PATH" \
&& pip install --upgrade --quiet pip setuptools
ADD ./archivebox.egg-info/requires.txt "$CODE_DIR/archivebox.egg-info/requires.txt"
RUN apt-get update -qq \
&& apt-get install -qq -y --no-install-recommends \
2020-08-13 23:55:02 -04:00
build-essential python-dev python3-dev \
2020-08-15 01:22:29 -04:00
&& grep -B 1000 -E '^$' "$CODE_DIR/archivebox.egg-info/requires.txt" | pip install --quiet -r /dev/stdin \
2020-08-13 23:55:02 -04:00
&& apt-get purge -y build-essential python-dev python3-dev \
2020-08-13 23:43:02 -04:00
&& apt-get autoremove -y \
&& rm -rf /var/lib/apt/lists/*
2018-10-13 22:47:30 -04:00
# Install ArchiveBox Python package
WORKDIR "$CODE_DIR"
ADD . "$CODE_DIR"
RUN pip install -e .
# Setup ArchiveBox runtime config
WORKDIR "$DATA_DIR"
ENV IN_DOCKER=True \
CHROME_SANDBOX=False \
CHROME_BINARY="chromium" \
USE_SINGLEFILE=True \
SINGLEFILE_BINARY="$NODE_DIR/node_modules/.bin/single-file" \
USE_READABILITY=True \
READABILITY_BINARY="$NODE_DIR/node_modules/.bin/readability-extractor" \
USE_MERCURY=True \
MERCURY_BINARY="$NODE_DIR/node_modules/.bin/mercury-parser"
2018-10-13 22:47:30 -04:00
# Print version for nice docker finish summary
# RUN archivebox version
RUN /app/bin/docker_entrypoint.sh archivebox version
2018-10-13 22:47:30 -04:00
# Open up the interfaces to the outside world
VOLUME "$DATA_DIR"
EXPOSE 8000
2020-07-22 01:30:58 -04:00
ENTRYPOINT ["dumb-init", "--", "/app/bin/docker_entrypoint.sh"]
CMD ["archivebox", "server", "0.0.0.0:8000"]