diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..235a58f --- /dev/null +++ b/Dockerfile @@ -0,0 +1,42 @@ +# Base on latest (edge) alpine image +FROM harbor.ervine.dev/library/x86_64/alpine/alpine-3.11 + +MAINTAINER “Jonathan Ervine” + +# Install updates +ENV LANG='en_US.UTF-8' \ + LANGUAGE='en_US.UTF-8' \ + TERM='xterm' \ + VERSION='develop' \ + SONARR_USER='mediaservice' \ + SONARR_GROUP='mediaservice' \ + SONARR_UID='1003' \ + SONARR_GID='1003' + +RUN echo http://dl-4.alpinelinux.org/alpine/edge/testing >> /etc/apk/repositories && \ + apk -U update && \ + apk -U upgrade && \ + apk -U add \ + libmediainfo \ + ca-certificates \ + mono \ + && \ + apk del make gcc g++ && \ + rm -rf /tmp/src && \ + rm -rf /var/cache/apk/* + +ADD start.sh /usr/local/bin/start.sh +RUN chmod 755 /usr/local/bin/start.sh + +RUN wget https://update.sonarr.tv/v2/master/mono/NzbDrone.master.tar.gz -O nzbdrone.tar.gz && \ + tar zxvf nzbdrone.tar.gz && \ + rm -rf nzbdrone.tar.gz && \ + addgroup -g $SONARR_GID $SONARR_GROUP && \ + adduser -D -u $SONARR_UID -G $SONARR_GROUP -H $SONARR_USER && \ + chown -R $SONARR_USER:$SONARR_GROUP /NzbDrone + +EXPOSE 8989 + +USER $SONARR_USER + +CMD [ "/usr/local/bin/start.sh" ] diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 0000000..e135f57 --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,26 @@ +node("docker-node") { + docker.withRegistry('https://harbor.ervine.dev', 'jenkins-to-harbor') { + + git branch: "3.11.6", url: "ssh://git@git.ervine.org/jonny/x86_64-alpine-sonarr", credentialsId: 'jenkins-to-git' + + sh "git rev-parse HEAD > .git/commit-id" + def commit_id = readFile('.git/commit-id').trim() + println commit_id + + try { + stage "build" + def app = docker.build "library/x86_64/alpine/sonarr" + + stage "publish" + app.push("v2.0.0.5344") + app.push("v2") + + stage('Deploy on K8s'){ + sh "/usr/local/bin/kubectl -n media delete po sonarr-0" + } + } + catch (err) { + currentBuild.result = 'FAILURE' + } + } +} diff --git a/start.sh b/start.sh new file mode 100644 index 0000000..d3cad1f --- /dev/null +++ b/start.sh @@ -0,0 +1,6 @@ +#!/bin/sh +## +## Script to start the sonarr server +## +until [ -f "/config/nzbdrone.db" ]; do sleep 1; done +/usr/bin/mono --debug /NzbDrone/NzbDrone.exe --nobrowser --data=/config