Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sorrir/yocto-pipeline
A description for an example process on how to create a custom Yocto image with kubernetes and mender
https://github.com/sorrir/yocto-pipeline
example iot k3s mender yocto
Last synced: about 5 hours ago
JSON representation
A description for an example process on how to create a custom Yocto image with kubernetes and mender
- Host: GitHub
- URL: https://github.com/sorrir/yocto-pipeline
- Owner: sorrir
- Created: 2021-10-18T14:07:08.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2021-10-18T14:10:03.000Z (about 3 years ago)
- Last Synced: 2024-05-12T06:41:37.459Z (6 months ago)
- Topics: example, iot, k3s, mender, yocto
- Language: Dockerfile
- Homepage:
- Size: 5.86 KB
- Stars: 4
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Yocto Pipline
This repository briefly describes to process of building platform specific Yocto based images for the [sorrir](https://sorrir.io/) IoT testbed. All images are based on Yocto Warrior
## Overview
* Yocto builds take place in a CI/CD system (GitLab Pipelines)
* Custom layers are imported for use-case specific needs
* Mender is used to deploy and update them
* k3s is used as a kubernetes container orchestrator### Yocto
This folder contains a Dockerfile used to build a Yocto build environment. Later on, this is used by a build runner in GitLab, but could be easily applied to GitHub Actions or any other CI/CD build tool.
Within the Dockerfile, the following steps are executed:
1. Install the Yocto Build environment and dependencies based on [the official documentation](https://www.yoctoproject.org/docs/1.8/yocto-project-qs/yocto-project-qs.html#ubuntu)
2. Google [Repo](https://gerrit.googlesource.com/git-repo/) is installed since Mender makes heavy use of it
3. A unprivileged user is created and configured that later runs the actual build### Image example
This folder contains an example on how to build a Raspberry Pi image for our testbed.
Hereby the following process is executed:
1. Prepare the working directory
2. Download the appropriate mender base configuration
3. Download our custom layers
4. Source the build environment
5. Configure the layers with some debug output
6. Build the image
7. Pass the built images to the next stage to upload it to a running mender instance### Mender
This folder contains a Mender deployment based on their [initial release](https://mender.io/blog/official-helm-chart-for-mender-2-5). This deployment makes use of [kustomize](https://github.com/kubernetes-sigs/kustomize)
The following process is executed:
* Manually run `helm repo add mender https://charts.mender.io`
* Manually run `kustomize build ./mender/mender --enable-helm . | kubectl apply -f -`
* Minio is installed
* MongoDB is installed
* Mender is installedAfter a first login to the mender webinterface you can generate the necessarry credentials used in the second pipeline step of our "Image example" above.
## Deployment
Based on this example, you can now create your initial deployment by duming the CI artifact `sdcard` image to your device. Any subsequent update can be automatically deployed using mender.