The path to Ubuntu Core

by Eric Jensen on 18 March 2019

At Canonical, helping customers overcome their challenges is what we do every day. In the IoT world, a common challenge we encounter is customers who are interested in transitioning to Ubuntu Core and the snapcraft.io ecosystem, but are unsure how to begin. This post covers the recommended approach.

In most cases, it’s relatively easy for someone to see the advantages of Ubuntu Core when they’re first introduced to it. The transactional updates, immutable system design, simplified development and powerful update controls have most people going “you had me at transactional!”

However, we all know the devil’s in the details. Shortly after the “eureka!” moment, there is often an anticlimax, as the newly minted Ubuntu Core believer starts to consider their current product state. For teams of harried software developers on a fixed budget, both in terms of time and money, making changes to the underlying components can feel impossible. Staring down the barrel of one or more projects with aggressive delivery schedules, the last thing you want to do is start changing things. To borrow from a quote often attributed to Walt Kelly, updating your device OS and packaging platform can feel like an “insurmountable opportunity.”

The easiest way to simplify a transition is to break it down into discreet steps, which is the approach we’ve taken here.

Step 1: Get Ubuntu

Ubuntu Server offers all the flexibility of whatever you’re using today, but adds a dizzying array in packages in multiple repositories, including a wealth of developer environments, frameworks, tools and utilities. If your target hardware has sufficient resources, you can develop on there directly. Then there’s regular maintenance, support, and a plethora of publicly available images, with new ones coming like clockwork twice a year. For custom hardware, our certification teams are ready to deliver the Ubuntu experience out of the box.

In addition, there’s a decent chance your developers are already running Ubuntu on their laptops or workstations. Moving to Ubuntu for your target device hardware will begin to simplify things immediately.

Step 2: Snap your apps

The next step is to begin snapping the apps that run on your device(s). You can easily prototype them on your Ubuntu or other Linux system, and then move to your target hardware when you’re ready. Using this method, you can learn all the ins and outs of snaps, such as confinement, service & interface management, and publishing. Once snaps are comfortable and familiar, like a favourite pair of jeans, you’re ready for the next step.

Step 3: Ubuntu Core

At its essence, Ubuntu Core can be described as an Ubuntu operating system built on snaps. You covered Ubuntu and snaps in the previous two steps, so you now have all the tools you’ll need. You’re ready to take advantage of all the benefits; Ubuntu Core’s all-snaps architecture for streamlined maintenance and security updates, minimal footprint, and failsafe update mechanisms for every OS element. If you chose Canonical to enable your board, chances are you’ll already have the Ubuntu Core image at your disposal.

Conclusion

Often a seemingly insurmountable task can be made manageable by breaking it down into smaller, simpler steps. I’ve attempted to do that here for the transition to Ubuntu Core. The benefits vastly outweigh the initial investment; utilising the snapcraft.io ecosystem will result in less effort spent on maintenance while simultaneously strengthening device reliability & security posture, and opening up the door to software-driven monetisation. The ultimate benefit is more profitable, longer-lived products and happier customers.

In future blog posts I intend to explore each step in greater detail. In the meantime, if you’d like to learn more about Ubuntu Core, check out my webinar from the recent Core 18 launch:

https://www.brighttalk.com/webcast/6793/339167

Newsletter Signup

Related posts

Managing software in complex network environments: the Snap Store Proxy

As enterprises grapple with the evolving landscape of security threats, the need to safeguard internal networks from the broader internet is increasingly important. In environments with restricted internet access, it can be difficult to manage software updates in an easy, reliable way. When managing devices in the field, change management […]

We wish you RISC-V holidays!

There are three types of computer users: the end user, the system administrator, and the involuntary system administrator. As it happens, everyone has found themselves in the last group at some point or another; you sit down to perform a task relevant to your needs or duties, but suddenly the machine does not work as […]

Creating Snaps on Ubuntu Touch

This article was written in collaboration with Alfred E. Neumayer of the UBports Project. Tablets, phones and current technology’s capabilities are phenomenal. Who would have thought a thin, light, barely 10 inch device would provide all the power necessary to run Virtual Machines, wherever one desires while powered on battery? That a sma […]