mirror of
https://codeberg.org/ashley/poke.git
synced 2024-11-10 04:28:34 +01:00
Docker Changes
- Add "release" and "release-aio" configurations based on alma linux - Add nginx example and entrypoint script - Dockerfile changes - "p" was not removed
This commit is contained in:
parent
f1e371ee01
commit
81a5d8514f
4 changed files with 157 additions and 10 deletions
|
@ -1,12 +1,17 @@
|
||||||
version: '3.1'
|
|
||||||
|
|
||||||
# TODO: Dockerize the other services
|
|
||||||
|
|
||||||
services:
|
services:
|
||||||
proxy:
|
proxy:
|
||||||
build:
|
build:
|
||||||
context: .
|
context: .
|
||||||
dockerfile: p/Dockerfile
|
dockerfile: p/Dockerfile
|
||||||
|
target: release-aio
|
||||||
|
# cache_to:
|
||||||
|
# cache_from:
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
ports:
|
ports:
|
||||||
- 3000:3000
|
- 80:80
|
||||||
|
- 443:443
|
||||||
|
# - 3000:3000
|
||||||
|
environment:
|
||||||
|
- HOSTNAME=example.com
|
||||||
|
- EMAIL=user@email.com # required for https
|
||||||
|
- STAGING=true # Set to "true" to use staging
|
||||||
|
|
102
p/Dockerfile
102
p/Dockerfile
|
@ -1,7 +1,99 @@
|
||||||
FROM node:18
|
#################################################################################
|
||||||
WORKDIR /app
|
# INSTALLERS #
|
||||||
COPY package.json /app/
|
# These images provide the dependencies required to build the other images. #
|
||||||
COPY p /app/p
|
#################################################################################
|
||||||
|
|
||||||
|
FROM quay.io/almalinuxorg/9-base AS builder-installer
|
||||||
|
|
||||||
|
# Needed for node 18+
|
||||||
|
# RUN dnf module --assumeyes enable nodejs
|
||||||
|
|
||||||
|
RUN --mount=type=cache,target=/var/cache/dnf \
|
||||||
|
dnf install --assumeyes --nodocs nodejs ca-certificates jq make gcc g++
|
||||||
|
|
||||||
|
RUN npm install -g \
|
||||||
|
npm@$(curl "https://release-monitoring.org/api/v2/versions/?project_id=190206" | jq --raw-output '.stable_versions[0]')
|
||||||
|
|
||||||
|
|
||||||
|
# Runtime dependencies
|
||||||
|
FROM quay.io/almalinuxorg/9-base AS installer
|
||||||
|
|
||||||
|
COPY --from=quay.io/almalinuxorg/9-micro / /rpms
|
||||||
|
RUN --mount=type=cache,target=/var/cache/dnf \
|
||||||
|
dnf install --assumeyes \
|
||||||
|
--installroot /rpms \
|
||||||
|
--releasever=9 \
|
||||||
|
--setopt=install_weak_deps=false \
|
||||||
|
--nodocs \
|
||||||
|
nodejs ca-certificates
|
||||||
|
|
||||||
|
RUN dnf clean all \
|
||||||
|
--installroot /rpms
|
||||||
|
|
||||||
|
|
||||||
|
# Proxy + certbot
|
||||||
|
FROM quay.io/almalinuxorg/9-base AS proxy-installer
|
||||||
|
|
||||||
|
RUN dnf install epel-release --assumeyes
|
||||||
|
|
||||||
|
COPY --from=quay.io/almalinuxorg/9-micro / /rpms
|
||||||
|
RUN --mount=type=cache,target=/var/cache/dnf \
|
||||||
|
dnf install --assumeyes \
|
||||||
|
--installroot /rpms \
|
||||||
|
--releasever=9 \
|
||||||
|
--setopt=install_weak_deps=false \
|
||||||
|
--setopt=reposdir=/etc/yum.repos.d \
|
||||||
|
--nodocs \
|
||||||
|
nginx-core certbot python3-certbot-nginx
|
||||||
|
|
||||||
|
RUN dnf clean all \
|
||||||
|
--installroot /rpms
|
||||||
|
|
||||||
|
#################################################################################
|
||||||
|
# BUILDER #
|
||||||
|
#################################################################################
|
||||||
|
|
||||||
|
FROM builder-installer AS builder
|
||||||
|
|
||||||
|
RUN mkdir -p /usr/src/app
|
||||||
|
WORKDIR /usr/src/app
|
||||||
|
COPY package.json ./
|
||||||
RUN npm install --frozen-lockfile
|
RUN npm install --frozen-lockfile
|
||||||
|
COPY ./ ./
|
||||||
|
COPY p/server.js ./
|
||||||
|
|
||||||
|
#################################################################################
|
||||||
|
# FINAL IMAGE #
|
||||||
|
#################################################################################
|
||||||
|
|
||||||
|
FROM quay.io/almalinuxorg/9-micro AS release-base
|
||||||
|
|
||||||
|
# Grab npm
|
||||||
|
COPY --from=installer /rpms /
|
||||||
|
|
||||||
|
# Grab site
|
||||||
|
COPY --from=builder /usr/src/app /app
|
||||||
|
|
||||||
|
WORKDIR /app
|
||||||
|
|
||||||
ENV NODE_ENV production
|
ENV NODE_ENV production
|
||||||
CMD ["node", "p/server.js"]
|
|
||||||
|
|
||||||
|
# Final image
|
||||||
|
FROM release-base as release
|
||||||
|
# EXPOSE 3000/tcp
|
||||||
|
ENTRYPOINT [ "node", "server.js" ]
|
||||||
|
|
||||||
|
# Final image with extras
|
||||||
|
FROM release-base AS release-aio
|
||||||
|
# Grab nginx and certbot
|
||||||
|
COPY --from=proxy-installer /rpms /
|
||||||
|
|
||||||
|
COPY p/entrypoint.sh entrypoint.sh
|
||||||
|
RUN chmod +x entrypoint.sh
|
||||||
|
COPY p/nginx.conf.example /etc/nginx/conf.d/poketube.conf
|
||||||
|
|
||||||
|
# EXPOSE 80/tcp
|
||||||
|
# EXPOSE 443/tcp
|
||||||
|
ENTRYPOINT [ "/usr/bin/bash", "./entrypoint.sh" ]
|
||||||
|
CMD [ "node", "server.js" ]
|
31
p/entrypoint.sh
Normal file
31
p/entrypoint.sh
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
#!/usr/bin/bash
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
if [[ "$STAGING" == true ]]; then
|
||||||
|
TEST="--test-cert"
|
||||||
|
echo Using staging server!
|
||||||
|
else
|
||||||
|
TEST=""
|
||||||
|
echo Using production server!
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [[ -v "HOSTNAME" && -v "EMAIL" ]]; then
|
||||||
|
echo Creating nginx config...
|
||||||
|
sed -i "s/SERVERNAME/$HOSTNAME/" /etc/nginx/conf.d/poketube.conf
|
||||||
|
echo Starting certbot
|
||||||
|
certbot run --nginx -n \
|
||||||
|
-d $HOSTNAME \
|
||||||
|
-d www.$HOSTNAME\
|
||||||
|
--agree-tos \
|
||||||
|
--email $EMAIL \
|
||||||
|
$TEST
|
||||||
|
echo Starting nginx
|
||||||
|
nginx -s reload
|
||||||
|
|
||||||
|
else
|
||||||
|
echo Please set HOSTNAME and/or EMAIL!
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
exec "$@"
|
19
p/nginx.conf.example
Normal file
19
p/nginx.conf.example
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name www.SERVERNAME;
|
||||||
|
return 301 $scheme://SERVERNAME$request_uri;
|
||||||
|
}
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80;
|
||||||
|
server_name SERVERNAME;
|
||||||
|
|
||||||
|
location / {
|
||||||
|
proxy_set_header X-Real-IP $remote_addr;
|
||||||
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
|
proxy_set_header X-NginX-Proxy true;
|
||||||
|
proxy_pass http://localhost:3000;
|
||||||
|
proxy_ssl_session_reuse off;
|
||||||
|
proxy_set_header Host $http_host;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue