Rebase, port fix and changelog

This commit is contained in:
Henning Bocklage 2020-06-11 20:45:28 +02:00
parent 9c0ad0e7f0
commit a92efee3a8
9 changed files with 115 additions and 83 deletions

View File

@ -7,26 +7,31 @@ stages:
variables: variables:
IMAGE: registry.gitlab.com/bockiii/deemix-docker IMAGE: registry.gitlab.com/bockiii/deemix-docker
IMAGE_TAG: latest
DOCKER_CLI_EXPERIMENTAL: enabled DOCKER_CLI_EXPERIMENTAL: enabled
before_script: before_script:
- docker login -u gitlab-ci-token -p $CI_JOB_TOKEN $CI_REGISTRY - docker login -u gitlab-ci-token -p $CI_JOB_TOKEN $CI_REGISTRY
- apk add --update curl && rm -rf /var/cache/apk/* - apk add --update curl && rm -rf /var/cache/apk/*
- export CI_JOB_TIMESTAMP=$(date --utc -Iseconds)
build: build:
stage: build stage: build
script: script:
- docker run --rm --privileged multiarch/qemu-user-static:register --reset - docker run --rm --privileged multiarch/qemu-user-static:register --reset
- docker build --pull -f Dockerfile.arm64v8 -t $IMAGE:arm64v8 . - docker build --pull -f Dockerfile.arm64v8 --build-arg BUILDDATE=$CI_JOB_TIMESTAMP -t $IMAGE:arm64v8-${IMAGE_TAG} .
- docker push $IMAGE:arm64v8 - docker build --pull -f Dockerfile.arm32v7 --build-arg BUILDDATE=$CI_JOB_TIMESTAMP -t $IMAGE:arm32v7-${IMAGE_TAG} .
- docker build --pull -f Dockerfile.arm32v7 -t $IMAGE:arm32v7 . - docker build --pull --build-arg BUILDDATE=$CI_JOB_TIMESTAMP -t $IMAGE:amd64-${IMAGE_TAG} .
- docker push $IMAGE:arm32v7 - docker push $IMAGE:arm64v8-${IMAGE_TAG}
- docker build --pull -t $IMAGE:amd64 . - docker push $IMAGE:arm32v7-${IMAGE_TAG}
- docker push $IMAGE:amd64 - docker push $IMAGE:amd64-${IMAGE_TAG}
- set -e - docker manifest create "$IMAGE:${IMAGE_TAG}"
- HOST_ARCH=$(uname -m) "$IMAGE:amd64-${IMAGE_TAG}"
- HOST_ARCH_ALIAS=$([[ "${HOST_ARCH}" == "x86_64" ]] && echo "amd64" || echo "${HOST_ARCH}") "$IMAGE:arm32v7-${IMAGE_TAG}"
- MANIFEST_TOOL_VERSION=$(curl -s https://api.github.com/repos/estesp/manifest-tool/releases/latest | grep 'tag_name' | cut -d\" -f4) "$IMAGE:arm64v8-${IMAGE_TAG}"
- curl -L https://github.com/estesp/manifest-tool/releases/download/$MANIFEST_TOOL_VERSION/manifest-tool-linux-$HOST_ARCH_ALIAS -o manifest-tool - docker manifest annotate "$IMAGE:${IMAGE_TAG}" "$IMAGE:arm32v7-${IMAGE_TAG}" --os=linux --arch=arm --variant=v7
- chmod +x manifest-tool - docker manifest annotate "$IMAGE:${IMAGE_TAG}" "$IMAGE:arm64v8-${IMAGE_TAG}" --os=linux --arch=arm64 --variant=v8
- ./manifest-tool push from-spec manifest.yaml # Push manifest to official registry
- docker manifest push "$IMAGE:${IMAGE_TAG}"
# Validate multi-arch manifest
- docker run --rm mplatform/mquery:v0.2 $IMAGE:${IMAGE_TAG}

6
CHANGELOG.md Normal file
View File

@ -0,0 +1,6 @@
# Changelog
## 2020-06-11
- First entry in the changelog. This is for the container only, not for deemix or any of it's components.
- Switched port to 6595 from 9666 (due to pyweb update). THIS SHOULD BE FIX NOW. I have hard-coded the port into the run parameter, so even if deemix itself will switch the port, you should always just have to map to 6595
- Switched the base from a pre-build alpine-python3 build (that was pretty old) to the current alpine base with my own python installation.

View File

@ -1,27 +1,39 @@
FROM lsiobase/alpine.python3:3.9 FROM lsiobase/alpine:3.12
ENV PUID=1000 ARG BUILDDATE
ENV PGID=1000
EXPOSE 9666 LABEL \
app.deemix.image.created="${BUILDDATE}" \
app.deemix.image.url="https://gitlab.com/Bockiii/deemix-docker" \
app.deemix.image.title="Docker image for Deemix" \
app.deemix.image.description="Docker image for Deemix and the pyweb frontend" \
maintainer="Bocki"
RUN \ RUN \
apk update && \ echo "**** install build packages ****" && \
apk add --no-cache \ apk add --no-cache --virtual=build-dependencies \
gcc \ gcc \
g++ \ g++ \
libffi-dev \ libffi-dev \
python3-dev \ python3-dev \
make git \
make && \
echo "**** install packages ****" && \
RUN \ apk add --no-cache \
mkdir /deem && \ py3-pip \
chown abc:abc /deem && \ python3 && \
rm -R /config && \ echo "**** setup directories ****" && \
ln -sf /deem/.config/deemix /config && \ mkdir /deem && \
ln -sf /downloads /deem/deemix\ Music chown abc:abc /deem && \
rm -R /config && \
ln -sf /deem/.config/deemix /config && \
ln -sf /downloads /deem/deemix\ Music && \
echo "**** clean up ****" && \
rm -rf \
/root/.cache \
/tmp/*
COPY root/ / COPY root/ /
VOLUME /downloads /config EXPOSE 6595
VOLUME /downloads /config

View File

@ -1,36 +1,49 @@
FROM alpine AS builder FROM alpine AS builder
# Download QEMU, see https://github.com/docker/hub-feedback/issues/1261 # Download QEMU, see https://github.com/docker/hub-feedback/issues/1261
#ENV QEMU_URL https://github.com/balena-io/qemu/releases/download/v3.0.0%2Bresin/qemu-3.0.0+resin-arm.tar.gz
ENV QEMU_URL https://github.com/balena-io/qemu/releases/download/v4.0.0-balena/qemu-4.0.0-balena-arm.tar.gz ENV QEMU_URL https://github.com/balena-io/qemu/releases/download/v4.0.0-balena/qemu-4.0.0-balena-arm.tar.gz
RUN apk add curl && curl -L ${QEMU_URL} | tar zxvf - -C . --strip-components 1 RUN apk add curl && curl -L ${QEMU_URL} | tar zxvf - -C . --strip-components 1
FROM lsiobase/alpine.python3.armhf:3.9
FROM lsiobase/alpine:arm32v7-3.12
# Add QEMU # Add QEMU
COPY --from=builder qemu-arm-static /usr/bin COPY --from=builder qemu-arm-static /usr/bin
ENV PUID=1000 ARG BUILDDATE
ENV PGID=1000
EXPOSE 9666 LABEL \
app.deemix.image.created="${BUILDDATE}" \
app.deemix.image.url="https://gitlab.com/Bockiii/deemix-docker" \
app.deemix.image.title="Docker image for Deemix" \
app.deemix.image.description="Docker image for Deemix and the pyweb frontend" \
maintainer="Bocki"
RUN \ RUN \
apk update && \ echo "**** install build packages ****" && \
apk add --no-cache \ apk add --no-cache --virtual=build-dependencies \
gcc \ gcc \
g++ \ g++ \
libffi-dev \ libffi-dev \
python3-dev \ python3-dev \
make git \
make && \
RUN \ echo "**** install packages ****" && \
mkdir /deem && \ apk add --no-cache \
chown abc:abc /deem && \ py3-pip \
rm -R /config && \ python3 && \
ln -sf /deem/.config/deemix /config && \ echo "**** setup directories ****" && \
ln -sf /downloads /deem/deemix\ Music mkdir /deem && \
chown abc:abc /deem && \
rm -R /config && \
ln -sf /deem/.config/deemix /config && \
ln -sf /downloads /deem/deemix\ Music && \
echo "**** clean up ****" && \
rm -rf \
/root/.cache \
/tmp/*
COPY root/ / COPY root/ /
EXPOSE 6595
VOLUME /downloads /config VOLUME /downloads /config

View File

@ -1,36 +1,50 @@
FROM alpine AS builder FROM alpine AS builder
# Download QEMU, see https://github.com/docker/hub-feedback/issues/1261 # Download QEMU, see https://github.com/docker/hub-feedback/issues/1261
#ENV QEMU_URL https://github.com/balena-io/qemu/releases/download/v3.0.0%2Bresin/qemu-3.0.0+resin-aarch64.tar.gz
ENV QEMU_URL https://github.com/balena-io/qemu/releases/download/v4.0.0-balena/qemu-4.0.0-balena-aarch64.tar.gz ENV QEMU_URL https://github.com/balena-io/qemu/releases/download/v4.0.0-balena/qemu-4.0.0-balena-aarch64.tar.gz
RUN apk add curl && curl -L ${QEMU_URL} | tar zxvf - -C . --strip-components 1 RUN apk add curl && curl -L ${QEMU_URL} | tar zxvf - -C . --strip-components 1
FROM lsiobase/alpine.python3.arm64:3.8 FROM lsiobase/alpine:arm64v8-3.12
# Add QEMU # Add QEMU
COPY --from=builder qemu-aarch64-static /usr/bin COPY --from=builder qemu-aarch64-static /usr/bin
ENV PUID=1000 ARG BUILDDATE
ENV PGID=1000
LABEL \
app.deemix.image.created="${BUILDDATE}" \
app.deemix.image.url="https://gitlab.com/Bockiii/deemix-docker" \
app.deemix.image.title="Docker image for Deemix" \
app.deemix.image.description="Docker image for Deemix and the pyweb frontend" \
maintainer="Bocki"
EXPOSE 9666 EXPOSE 9666
RUN \ RUN \
apk update && \ echo "**** install build packages ****" && \
apk add --no-cache \ apk add --no-cache --virtual=build-dependencies \
gcc \ gcc \
g++ \ g++ \
libffi-dev \ libffi-dev \
python3-dev \ python3-dev \
make git \
make && \
RUN \ echo "**** install packages ****" && \
mkdir /deem && \ apk add --no-cache \
chown abc:abc /deem && \ py3-pip \
rm -R /config && \ python3 && \
ln -sf /deem/.config/deemix /config && \ echo "**** setup directories ****" && \
ln -sf /downloads /deem/deemix\ Music mkdir /deem && \
chown abc:abc /deem && \
rm -R /config && \
ln -sf /deem/.config/deemix /config && \
ln -sf /downloads /deem/deemix\ Music && \
echo "**** clean up ****" && \
rm -rf \
/root/.cache \
/tmp/*
COPY root/ / COPY root/ /
EXPOSE 6595
VOLUME /downloads /config VOLUME /downloads /config

View File

@ -6,8 +6,6 @@ In order to run this container, you will have to exchange your previous image ta
That should be it, everything else stays the same. You will only get updates if you switch to the new source! That should be it, everything else stays the same. You will only get updates if you switch to the new source!
ARM Builds are not working yet as I have to get used to the gitlab CI first.
# deemix-docker # deemix-docker
@ -27,7 +25,7 @@ $ docker run -d --name Deemix \
-e PUID=1000 \ -e PUID=1000 \
-e PGID=1000 \ -e PGID=1000 \
-e ARL=1234567 \ -e ARL=1234567 \
-p 9666:9666 \ -p 6595:6595 \
registry.gitlab.com/bockiii/deemix-docker registry.gitlab.com/bockiii/deemix-docker
``` ```
@ -46,7 +44,7 @@ services:
- PGID=1000 - PGID=1000
- ARL=1234567 - ARL=1234567
ports: ports:
- 9666:9666 - 6595:6595
``` ```
### Updating Deemix ### Updating Deemix
@ -65,11 +63,11 @@ The container will look for a new update in the Deemix repo on every start and w
`-e ARL=1234567` - OPTIONAL: If you want Deemix to automatically log in for everyone who opens the website, provide your ARL token via this Environment variable. `-e ARL=1234567` - OPTIONAL: If you want Deemix to automatically log in for everyone who opens the website, provide your ARL token via this Environment variable.
`-p 9666:9666` - Port opened for the web interface. `-p 6595:6595` - Port opened for the web interface.
`registry.gitlab.com/bockiii/deemix-docker` - This container. `registry.gitlab.com/bockiii/deemix-docker` - This container.
To access the web interface, go to http://YOURSERVERIP:9666 To access the web interface, go to http://YOURSERVERIP:6595
## Tags ## Tags

View File

@ -11,4 +11,4 @@ services:
- PGID=1000 - PGID=1000
- ARL=1234567 - ARL=1234567
ports: ports:
- 9666:9666 - 6595:6595

View File

@ -1,16 +0,0 @@
image: registry.gitlab.com/bockiii/deemix-docker:latest
manifests:
- image: registry.gitlab.com/bockiii/deemix-docker:amd64
platform:
architecture: amd64
os: linux
- image: registry.gitlab.com/bockiii/deemix-docker:arm32v7
platform:
architecture: arm
os: linux
variant: v7
- image: registry.gitlab.com/bockiii/deemix-docker:arm64v8
platform:
architecture: arm64
os: linux
variant: v8

View File

@ -7,9 +7,9 @@ HOME=/deem
if [ -f "/config/.arl" ]; then if [ -f "/config/.arl" ]; then
echo "[services.d] Starting with ARL" echo "[services.d] Starting with ARL"
exec \ exec \
s6-setuidgid abc python3 /deemix/server.py --serverwide-arl --host 0.0.0.0 s6-setuidgid abc python3 /deemix/server.py 6595 --serverwide-arl --host 0.0.0.0
else else
echo "[services.d] Starting without ARL" echo "[services.d] Starting without ARL"
exec \ exec \
s6-setuidgid abc python3 /deemix/server.py --host 0.0.0.0 s6-setuidgid abc python3 /deemix/server.py 6595 --host 0.0.0.0
fi fi