Mender is an open source over-the-air (OTA) software updater for embedded Linux devices. Mender comprises a client running at the embedded device, as well as a server that manages deployments across many devices.
This repository contains mender-convert, which is used to convert pre-built disk images (Debian, Ubuntu, Raspbian, etc) to a Mender compatible image by restructuring partition table and injecting the necessary files.
For a full list of tested devices and images please visit Mender Hub. If your device and image combination is not listed as supported, this does not necessarily mean that it will not work, it probably just means that no one has tested and reported it back and usually only small tweaks are necessary to get this running on your device.
To start using Mender, we recommend that you begin with the Getting started section in the Mender documentation.
For more detailed information about mender-convert
please visit the
Debian family section in
the Mender documentation.
Download the raw Raspberry Pi disk image into a subdirectory input:
mkdir -p input
cd input
wget https://downloads.raspberrypi.org/raspbian_lite/images/raspbian_lite-2019-06-24/2019-06-20-raspbian-buster-lite.zip
Extract the raw Raspberry Pi disk image:
unzip 2019-06-20-raspbian-buster-lite.zip
INPUT_DISK_IMAGE=$(ls *raspbian-buster*.img)
cd ..
Bootstrap the demo rootfs overlay that is configured to connect to a Mender server with polling intervals set appropriately for demonstration purposes. There are three scripts here to support the Mender demo server, the Mender production server, and Mender Professional.
NOTE! Only run one of these three steps depending on the server type you are implementing.
Using the Mender demo server
./scripts/bootstrap-rootfs-overlay-demo-server.sh \
--output-dir ${PWD}/rootfs_overlay_demo \
--server-ip 192.168.1.1
Using the Mender production server
./scripts/bootstrap-rootfs-overlay-production-server.sh \
--output-dir ${PWD}/rootfs_overlay_demo \
--server-url https://foobar.mender.io \
[ --server-cert ~/server.crt ]
Using Mender Professional
./scripts/bootstrap-rootfs-overlay-hosted-server.sh \
--output-dir ${PWD}/rootfs_overlay_demo \
--tenant-token "Paste token from Mender Professional"
To make using mender-convert easier, a reference setup using a Docker container is provided.
You need to install Docker Engine to use this environment.
Build a container with all required dependencies for mender-convert
:
./docker-build
This will create a container image with the name mender-convert
which you can
use to run mender-convert
without polluting your host environment with the
necessary dependencies.
Run mender-convert from inside the container with your desired options, e.g.
MENDER_ARTIFACT_NAME=release-1 ./docker-mender-convert \
--disk-image input/$INPUT_DISK_IMAGE \
--config configs/raspberrypi3_config \
--overlay rootfs_overlay_demo/
Conversion will take 10-30 minutes, depending on image size and resources
available. You can watch WORKDIR/convert.log
for progress and diagnostics
information.
After it finishes, you can find your images in the deploy
directory on your
host machine!
In order to be able to manipulate and create filesystem and disk images, mender-convert has a few dependencies, and their version and name vary between Linux distributions. Here is an example of how to install the dependencies on a Debian based distribution:
sudo apt install $(cat requirements-deb.txt)
Start the conversion process with:
MENDER_ARTIFACT_NAME=release-1 ./mender-convert \
--disk-image input/$INPUT_DISK_IMAGE \
--config configs/raspberrypi3_config \
--overlay rootfs_overlay_demo/
NOTE! You will be prompted to enter sudo
password during the conversion
process. This is required to be able to loopback mount images and for modifying
them. Our recommendation is to use the provided Docker container, to run the
tool in a isolated environment.
We welcome and ask for your contribution. If you would like to contribute to Mender, please read our guide on how to best get started contributing code or documentation.
Mender is licensed under the Apache License, Version 2.0. See LICENSE for the full license text.
We take security very seriously. If you come across any issue regarding security, please disclose the information by sending an email to [email protected]. Please do not create a new public issue. We thank you in advance for your cooperation.
- Join the Mender Hub discussion forum
- Follow us on Twitter. Please feel free to tweet us questions.
- Fork us on Github
- Create an issue in the bugtracker
- Email us at [email protected]
- Connect to the #mender IRC channel on Freenode
Mender was created by the team at Northern.tech AS, with many contributions from the community. Thanks everyone!
Mender is sponsored by Northern.tech AS.