chat over e-mail |
meissa@social.meissa-gmbh.de | Blog | Website
GitOps for static generated Websites.
c4k-website generates k8s-manifest for a webserver serving static html.
c4k-website is an example how to create k8s manifests for OneShotDeployments with https://repo.prod.meissa.de/meissa/c4k-common.
You can serve many websites, each of can listen to a list of domain names. E.g.
# Config example
websites:
- unique-name: "test.io"
fqdns: ["test.de", "test.org", "www.test.de", "www.test.org"]
- unique-name: "example.io"
fqdns: ["example.org", "www.example.com"]The domain names listed will get their certificates from letsencrypt out of the box.
There is a Ratelimit included for each website. This makes it harder to DOS one or all websites served.
Monitoring on GrafanaCloud (or any other grafana) is included out of the box.
If your repository is on a frogejo or gitea repo, we included GitOps. We ask every ten minutes the repo api for new pushed content.
If there is new content we generate the new static html & serve it.
For static html generation we support cryogen & hugo.
Prerequisites:
- DNS routes pointing to your k8s cluster.
- frogejo or gitea instance for your website repo. In doubt use https://codeberg.org
- A git repository with your hugo / cryogene website
- the project provides a
generate.sh(maybe your generatoin needs some preprocessing) generate.shdeliver its static generated html totarget/html
- the project provides a
Development happens at: https://repo.prod.meissa.de/meissa/c4k-website
Mirrors are:
- https://codeberg.org/meissa/c4k-website.git
- https://gitlab.com/domaindrivenarchitecture/c4k-website (issues and PR, CI)
- https://github.com/DomainDrivenArchitecture/c4k-website
For more details about our repository model see: https://repo.prod.meissa.de/meissa/federate-your-repos
Go to folder infrastructure/build/ and create an image with pyb image.
After you have tagged the image and pushed it to "docker.io" it can be used by c4k-website. (TODO: document how to tag and push.)
To use the new image, update the image's version in line
- image: domaindrivenarchitecture/c4k-website-build:2.0.6
in file: build-cron.yaml
Then (re-)deploy the c4k-website to the server or - alternatively - update the version of the image manually on the server
in the corresponding cronJob-Deployment to automatically pull and use the new image on the server.
Copyright © 2022 - 2025 meissa GmbH Licensed under the Apache License, Version 2.0 (the "License") Pls. find licenses of our subcomponents here