ci: Build container image
This image will be used to deploy the application on the Kubernetes cluster.
parent
337406e0a0
commit
333907913d
|
@ -51,5 +51,21 @@ pipeline {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
stage('Build Container') {
|
||||||
|
steps {
|
||||||
|
container('podman') {
|
||||||
|
sh '. ci/build-container.sh'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
stage('Publish Container') {
|
||||||
|
steps {
|
||||||
|
container('podman') {
|
||||||
|
sh '. ci/publish-container.sh'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,7 @@
|
||||||
|
#!/bin/sh -ex
|
||||||
|
|
||||||
|
. ci/container-common.sh
|
||||||
|
|
||||||
|
cp -r svc/dist container/wheels
|
||||||
|
cp -r ui/dist container/ui
|
||||||
|
podman build -t hudctrl:$(tag_name ${BUILD_TAG}) container
|
|
@ -0,0 +1,5 @@
|
||||||
|
# shellcheck: shell=sh
|
||||||
|
|
||||||
|
tag_name() {
|
||||||
|
echo "$1" | sed -e 's/[^a-zA-Z0-9._-]/-/g' -e 's/^[.-]/_/'
|
||||||
|
}
|
|
@ -27,3 +27,10 @@ spec:
|
||||||
securityContext:
|
securityContext:
|
||||||
readOnlyRootFilesystem: true
|
readOnlyRootFilesystem: true
|
||||||
runAsUser: 1000
|
runAsUser: 1000
|
||||||
|
- name: podman
|
||||||
|
image: quay.io/containers/podman:v3.4
|
||||||
|
command:
|
||||||
|
- sleep
|
||||||
|
- infinity
|
||||||
|
securityContext:
|
||||||
|
privileged: true
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
#!/bin/sh -ex
|
||||||
|
|
||||||
|
. ci/container-common.sh
|
||||||
|
|
||||||
|
push() {
|
||||||
|
tag=$(tag_name $1)
|
||||||
|
podman push hudctrl:$(tag_name ${BUILD_TAG}) registry.pyrocufflink.blue/hudctrl:${tag}
|
||||||
|
}
|
||||||
|
|
||||||
|
push ${BUILD_TAG}
|
||||||
|
push ${BRANCH_NAME}
|
||||||
|
if [ "${BRANCH_NAME}" = master ]; then
|
||||||
|
push latest
|
||||||
|
fi
|
|
@ -0,0 +1,2 @@
|
||||||
|
ui/
|
||||||
|
wheels/
|
|
@ -0,0 +1,19 @@
|
||||||
|
FROM docker.io/python:3.10-slim AS build
|
||||||
|
|
||||||
|
COPY wheels /tmp/wheels
|
||||||
|
COPY requirements.txt /tmp
|
||||||
|
RUN python -m venv /usr/local/hudctrl
|
||||||
|
RUN /usr/local/hudctrl/bin/python -m \
|
||||||
|
pip install -f /tmp/wheels -r /tmp/requirements.txt
|
||||||
|
|
||||||
|
COPY ui /usr/local/hudctrl/ui
|
||||||
|
|
||||||
|
FROM docker.io/python:3.10-slim
|
||||||
|
RUN apt-get update && \
|
||||||
|
apt-get install -y nginx tini && \
|
||||||
|
rm -rf /var/cache/apt /var/lib/apt
|
||||||
|
COPY nginx.conf /etc/nginx/nginx.conf
|
||||||
|
COPY --from=build /usr/local/hudctrl /usr/local/hudctrl
|
||||||
|
COPY run.sh /
|
||||||
|
|
||||||
|
CMD ["tini", "--", "/run.sh"]
|
|
@ -0,0 +1,42 @@
|
||||||
|
# vim: set sw=4 ts=4 sts=4 et :
|
||||||
|
|
||||||
|
user www-data;
|
||||||
|
worker_processes auto;
|
||||||
|
pid /run/nginx.pid;
|
||||||
|
|
||||||
|
events {
|
||||||
|
worker_connections 768;
|
||||||
|
}
|
||||||
|
|
||||||
|
http {
|
||||||
|
sendfile on;
|
||||||
|
tcp_nopush on;
|
||||||
|
types_hash_max_size 2048;
|
||||||
|
|
||||||
|
include /etc/nginx/mime.types;
|
||||||
|
default_type application/octet-stream;
|
||||||
|
|
||||||
|
access_log /dev/stderr;
|
||||||
|
error_log /var/log/nginx/error.log;
|
||||||
|
|
||||||
|
gzip on;
|
||||||
|
|
||||||
|
server {
|
||||||
|
listen 80 default_server;
|
||||||
|
listen [::]:80 default_server;
|
||||||
|
server_name _;
|
||||||
|
|
||||||
|
root /usr/local/hudctrl/ui;
|
||||||
|
index index.html;
|
||||||
|
|
||||||
|
location /api/ {
|
||||||
|
proxy_pass http://127.0.0.1:8000/;
|
||||||
|
|
||||||
|
real_ip_header X-Forwarded-For;
|
||||||
|
set_real_ip_from 0.0.0.0/0;
|
||||||
|
set_real_ip_from ::/0;
|
||||||
|
real_ip_recursive on;
|
||||||
|
proxy_set_header Host $proxy_host;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,3 @@
|
||||||
|
gunicorn
|
||||||
|
hudctrl
|
||||||
|
uvicorn
|
|
@ -0,0 +1,7 @@
|
||||||
|
#!/bin/sh
|
||||||
|
# vim: set sw=4 ts=4 sts=4 et :
|
||||||
|
|
||||||
|
nginx || exit $?
|
||||||
|
exec /usr/local/hudctrl/bin/gunicorn \
|
||||||
|
-k uvicorn.workers.UvicornWorker \
|
||||||
|
hudctrl.api:app
|
Loading…
Reference in New Issue