diff --git a/.github/workflows/k8s_tests.yml b/.github/workflows/k8s_tests.yml new file mode 100644 index 0000000..ca2cdf8 --- /dev/null +++ b/.github/workflows/k8s_tests.yml @@ -0,0 +1,18 @@ +name: Kubernetes configuration + +on: [push] + +jobs: + check: + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v2 + - run: docker pull nekottyo/kustomize-kubeval + - name: render kustomization + run: | + docker run -i -w /working -v $(pwd):/working nekottyo/kustomize-kubeval \ + kustomize build . >> k8s.yml + - name: check kubernetes configuration + run: | + docker run -i -w /working -v $(pwd):/working nekottyo/kustomize-kubeval \ + kubeval k8s.yml --strict diff --git a/Dockerfile b/Dockerfile index 43208c5..354bb24 100644 --- a/Dockerfile +++ b/Dockerfile @@ -33,9 +33,8 @@ RUN npm run build FROM base as final COPY --from=frontend /app/src/frontend/dist/ /app/static # Setup configs -#ADD docker/uwsgi.ini /etc/uwsgi/lecture2gether.ini +VOLUME /app/config ADD docker/supervisor.conf /etc/supervisor/conf.d/app.conf -RUN mkdir /app/config ADD docker/settings.json /app/config/settings.json RUN ln -sf /app/config/settings.json /app/static/settings.json ADD docker/nginx.conf /etc/nginx/sites-enabled/default diff --git a/README.md b/README.md index 4e80b67..0bf3806 100644 --- a/README.md +++ b/README.md @@ -23,7 +23,7 @@ Lecture2Gether makes it possible to watch online lectures with friends by pasting a link to a [Lecture2Go](https://github.com/lecture2go/portal-6.2-ce-ga6) Video, a YouTube Video or a simple mp4 link. The video streams are synchronized to partially restore the social aspect of campus life. -data:image/s3,"s3://crabby-images/8d271/8d271e24cedfae255bd61459319804a25d23c87c" alt="Flask CI" data:image/s3,"s3://crabby-images/59570/59570236c6005558067e1fa509eceffef31baf18" alt="Node.js CI" +data:image/s3,"s3://crabby-images/8d271/8d271e24cedfae255bd61459319804a25d23c87c" alt="Flask CI" data:image/s3,"s3://crabby-images/59570/59570236c6005558067e1fa509eceffef31baf18" alt="Node.js CI" data:image/s3,"s3://crabby-images/150cb/150cb6205b845d9f683d7e713718b075ff47e2f7" alt="Kubernetes configuration" ### Built With diff --git a/docker/nginx.conf b/docker/nginx.conf index a85e687..0eaeabb 100644 --- a/docker/nginx.conf +++ b/docker/nginx.conf @@ -1,13 +1,24 @@ server { listen 8000; server_name default_server; + gzip on; - try_files $uri /index.html; root /app/static/; + location / { + try_files $uri /index.html?$args; + location ~* \.html$ { + add_header "Cache-Control" "no-cache"; + } + location ~* \.(css|js|woff2) { + add_header "Cache-Control" "max-age=31536000"; + } + } + location /api { proxy_pass http://127.0.0.1:5000; } + location = /socket.io/ { proxy_pass http://127.0.0.1:5000/socket.io/; proxy_http_version 1.1; diff --git a/k8s/deployment.yml b/k8s/deployment.yml index 776b9d4..401fb29 100644 --- a/k8s/deployment.yml +++ b/k8s/deployment.yml @@ -7,12 +7,17 @@ spec: replicas: 1 selector: matchLabels: - app: "NOT_SET" + app: "lecture2gether" template: metadata: labels: - app: "NOT_SET" + app: "lecture2gether" spec: + volumes: + - name: "frontend-config" + configMap: + name: "frontend" + containers: - image: "docker.io/thenerdful8/lecture2gether" name: "main" @@ -21,4 +26,11 @@ spec: containerPort: 8000 - name: "metrics" containerPort: 5000 + envFrom: + - configMapRef: + name: "backend" + volumeMounts: + - name: "frontend-config" + mountPath: "/app/config" + readOnly: true diff --git a/k8s/kustomization.yml b/k8s/kustomization.yml deleted file mode 100644 index cef2f39..0000000 --- a/k8s/kustomization.yml +++ /dev/null @@ -1,9 +0,0 @@ ---- -apiVersion: "kustomize.config.k8s.io/v1beta1" -kind: "Kustomization" -namePrefix: "lecture2gether-" -commonLabels: - app: "lecture2gether" -resources: - - "./deployment.yml" - - "./service.yml" diff --git a/kustomization.yml b/kustomization.yml new file mode 100644 index 0000000..4cec3c6 --- /dev/null +++ b/kustomization.yml @@ -0,0 +1,14 @@ +--- +apiVersion: "kustomize.config.k8s.io/v1beta1" +kind: "Kustomization" +namePrefix: "lecture2gether-" +commonLabels: + app: "lecture2gether" +resources: + - "./k8s/deployment.yml" + - "./k8s/service.yml" +configMapGenerator: + - name: "backend" + - name: "frontend" + files: + - "settings.json=./docker/settings.json" diff --git a/lecture2gether-vue/public/index.html b/lecture2gether-vue/public/index.html index e7cea48..d945ec9 100644 --- a/lecture2gether-vue/public/index.html +++ b/lecture2gether-vue/public/index.html @@ -4,6 +4,9 @@ +