The path to Ubuntu Core

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.”

Contemplating 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.

Maintenance and relax

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

Internet of Things

From home control to drones, robots and industrial systems, Ubuntu Core and Snaps provide robust security, app stores and reliable updates for all your IoT devices.

Newsletter signup

Select topics you’re
interested in

In submitting this form, I confirm that I have read and agree to Canonical’s Privacy Notice and Privacy Policy.

Related posts

How to integrate Ubuntu with Active Directory

Ubiquitous use of Microsoft tools coupled with increasing popularity of open source Linux software for enterprise presents new challenges for non-Microsoft operating systems that require seamless integration with Active Directory for authentication and identity management. This …

8 Ways Snaps are Different

Depending on the audience, the discussion of software packaging elicits very different responses. Users generally don’t care how software is packaged, so long as it works. Developers typically want software packaging as a task to not …

Julia and Jeff discover the ease of snaps at the Snapcraft Summit

Julia is an open source, high-level, general-purpose, dynamic programming language designed for numerical analysis and computational science, launched in 2012. It solves the “two language” problem: developers can use Julia for both computational and interactive work, …