From ee7c25c767c357bd12570889f8ccd79ba9ea4eb9 Mon Sep 17 00:00:00 2001 From: am97 Date: Tue, 9 Oct 2018 17:35:02 +0200 Subject: [PATCH] Create new Docker dev image (#1173) * Move the old dev docker files to support/docker/janitor * Create new Docker dev image --- support/docker/dev/Dockerfile | 48 ++++++++++++------- support/docker/dev/setup_postgres.sql | 6 +++ support/docker/dev/usage.md | 20 ++++++++ support/docker/janitor/Dockerfile | 32 +++++++++++++ .../docker/{dev => janitor}/create_user.sql | 0 support/docker/{dev => janitor}/janitor.json | 0 .../docker/{dev => janitor}/supervisord.conf | 0 7 files changed, 90 insertions(+), 16 deletions(-) create mode 100644 support/docker/dev/setup_postgres.sql create mode 100644 support/docker/dev/usage.md create mode 100644 support/docker/janitor/Dockerfile rename support/docker/{dev => janitor}/create_user.sql (100%) rename support/docker/{dev => janitor}/janitor.json (100%) rename support/docker/{dev => janitor}/supervisord.conf (100%) diff --git a/support/docker/dev/Dockerfile b/support/docker/dev/Dockerfile index 2b4f2b215..aa4a8a3d6 100644 --- a/support/docker/dev/Dockerfile +++ b/support/docker/dev/Dockerfile @@ -1,32 +1,48 @@ -FROM janitortechnology/ubuntu-dev +FROM ubuntu:bionic + +# Avoid tzdata interactive dialog +ENV DEBIAN_FRONTEND=noninteractive # Install PeerTube's dependencies. # Packages are from https://github.com/Chocobozzz/PeerTube#dependencies -RUN sudo apt-get update -q && sudo apt-get install -qy \ +RUN apt-get update -q && apt-get install -qy \ + curl \ + nano \ ffmpeg \ postgresql \ - openssl + postgresql-contrib \ + openssl \ + g++ \ + make \ + redis-server \ + git \ + gnupg + +# Install NodeJS 8.x +RUN curl -sL https://deb.nodesource.com/setup_8.x | bash - && \ + apt-get install -y nodejs + +# Install Yarn +RUN curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - && \ + echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list && \ + apt-get update && apt-get install yarn # Download PeerTube's source code. RUN git clone -b develop https://github.com/Chocobozzz/PeerTube /home/user/PeerTube WORKDIR /home/user/PeerTube -# Configure the IDEs to use Janitor's source directory as workspace. -ENV WORKSPACE /home/user/PeerTube/ - # Install dependencies. RUN yarn install --pure-lockfile -# Configure Janitor for PeerTube. -COPY --chown=user:user janitor.json /home/user/ +# Configure and run PeerTube. +COPY setup_postgres.sql /tmp/ +RUN service postgresql start \ + && su postgres -c "psql --file=/tmp/setup_postgres.sql" -# Configure and build PeerTube. -COPY create_user.sql /tmp/ -RUN sudo service postgresql start \ - && sudo -u postgres psql --file=/tmp/create_user.sql \ - && npm run build - -COPY --chown=user:user supervisord.conf /tmp/supervisord-extra.conf -RUN cat /tmp/supervisord-extra.conf | sudo tee -a /etc/supervisord.conf +# Expose PeerTube sources as a volume +VOLUME /home/user/PeerTube EXPOSE 3000 9000 + +# Start PostgreSQL and Redis +CMD service postgresql start && redis-server diff --git a/support/docker/dev/setup_postgres.sql b/support/docker/dev/setup_postgres.sql new file mode 100644 index 000000000..0937f9d19 --- /dev/null +++ b/support/docker/dev/setup_postgres.sql @@ -0,0 +1,6 @@ +create database peertube_dev; +create user peertube password 'peertube'; +grant all privileges on database peertube_dev to peertube; +\c peertube_dev +CREATE EXTENSION pg_trgm; +CREATE EXTENSION unaccent; diff --git a/support/docker/dev/usage.md b/support/docker/dev/usage.md new file mode 100644 index 000000000..319d7db30 --- /dev/null +++ b/support/docker/dev/usage.md @@ -0,0 +1,20 @@ +### Usage +1. Build the image: + ``` + docker build -t my_peertube_dev . + ``` +1. Start the container: + ``` + docker run -d -i -p 3000:3000 -p 9000:9000 --name peertube my_peertube_dev + ``` + This will create a new Docker volume containing PeerTube sources. + +1. Start PeerTube inside the container: + ``` + docker exec -it peertube npm run dev + ``` +1. In another window, find the path to the Docker volume + ``` + docker inspect peertube | less +/Mounts + ``` + You can now make changes to the files. They should be automatically recompiled. diff --git a/support/docker/janitor/Dockerfile b/support/docker/janitor/Dockerfile new file mode 100644 index 000000000..2b4f2b215 --- /dev/null +++ b/support/docker/janitor/Dockerfile @@ -0,0 +1,32 @@ +FROM janitortechnology/ubuntu-dev + +# Install PeerTube's dependencies. +# Packages are from https://github.com/Chocobozzz/PeerTube#dependencies +RUN sudo apt-get update -q && sudo apt-get install -qy \ + ffmpeg \ + postgresql \ + openssl + +# Download PeerTube's source code. +RUN git clone -b develop https://github.com/Chocobozzz/PeerTube /home/user/PeerTube +WORKDIR /home/user/PeerTube + +# Configure the IDEs to use Janitor's source directory as workspace. +ENV WORKSPACE /home/user/PeerTube/ + +# Install dependencies. +RUN yarn install --pure-lockfile + +# Configure Janitor for PeerTube. +COPY --chown=user:user janitor.json /home/user/ + +# Configure and build PeerTube. +COPY create_user.sql /tmp/ +RUN sudo service postgresql start \ + && sudo -u postgres psql --file=/tmp/create_user.sql \ + && npm run build + +COPY --chown=user:user supervisord.conf /tmp/supervisord-extra.conf +RUN cat /tmp/supervisord-extra.conf | sudo tee -a /etc/supervisord.conf + +EXPOSE 3000 9000 diff --git a/support/docker/dev/create_user.sql b/support/docker/janitor/create_user.sql similarity index 100% rename from support/docker/dev/create_user.sql rename to support/docker/janitor/create_user.sql diff --git a/support/docker/dev/janitor.json b/support/docker/janitor/janitor.json similarity index 100% rename from support/docker/dev/janitor.json rename to support/docker/janitor/janitor.json diff --git a/support/docker/dev/supervisord.conf b/support/docker/janitor/supervisord.conf similarity index 100% rename from support/docker/dev/supervisord.conf rename to support/docker/janitor/supervisord.conf