Build your first image¶
This tutorial will guide you through the steps required to create your own Ubuntu Core image, with your own selection of snaps, and install it on a Raspberry Pi.
This same process can be used to build Ubuntu Core images for various hardware and devices.
Requirements¶
In addition to having a basic understanding of Linux and running commands from the terminal, this tutorial has hardware requirements.
- Hardware requirements for building an Ubuntu Core image - See the recommended hardware configuration of the host and target systems specific to this tutorial. 
Create an Ubuntu One account¶
Before you can use Ubuntu Core, build or sign an image, or publish a snap, you will need to create an Ubuntu One account, supply it with Snapcraft credentials, and retrieve the developer account ID.
Ubuntu One is a single sign-on service (SSO) for Ubuntu and its affiliated projects, including snapcraft.io, the central resource for all snap-related publishing.
See the details on how to create an account, login, and retrieve your developer account details.
- 
Learn how to create an account and register an SSH key. 
- Export login credentials with Snapcraft - Use Snapcraft to export your login authentication credentials and place them within an environment variable. 
- Retrieve your developer account id - Use the - snapcraft whoamicommand to display your developer identifier.
Create the model assertion¶
A model assertion is a signed recipe that describes the components that comprise a complete image at the heart of a custom Ubuntu Core.
- 
Download the 64-bit reference model for the Raspberry Pi: ubuntu-core-24-pi-arm64.json, save it locally with the wgetcommand.
- 
Edit my-model.jsonusing a text editor.
- 
Replace “canonical” in my-model.jsonwith your developer and brand ID.
- 
Provide the timestamp at the end of the process. 
- 
Add the snaps pi, pi-kernel, core24 and snapd that are required for a functioning Ubuntu Core device. 
- 
Review my-model.jsonafter finishing the edits above.
Sign the model assertion¶
Learn how to sign a model with a GPG key to make it into a model assertion.
- 
Use snapcraftto create a key that will be used across all models or model families.
- 
Upload the key and register it with your Ubuntu One account by using register-keycommand. After creating the key, update the timestamp inmy-model.json.
- 
Use the snap signcommand to update the JSON file with the key name.
Build and write the image¶
Using ubuntu-image, generate a bootable image from the recipe contained in the model assertion.
- 
Install the ubuntu-imagecommand and use the argumentssnap,--allow-snapd-kernel-mismatchand the file name of the previously signed model assertion to build an image.
- 
Install Raspberry Pi Imager and use it to write the image on a microSD card. 
Boot the image¶
Now that you have a custom image for a Raspberry Pi on a microSD card, the device can now be booted and configured.
- 
Insert the microSD card into the powered-off Raspberry Pi and turn it on to boot up your image. 
- Configure a network connection - Choose a wired connection (Ethernet) or Wi-Fi to setup Ubuntu Core. 
- 
Connect to the AdGuard Home snap of the Ubuntu Core via the published IP address and its configured port (3000 for setup). 
