The snap packaging system consists of many components, from system-level Linux kernel security modules, managed by the snap daemon, snapd, to the network connected Snap Store for package retrieval and updates.
These components inter-communicate and operate together to create a secure and confined execution environment for application and service deployment. This component and communication process is outlined below.
Snap system process overview, showing how the snap daemon, snapd, manages snaps within a sandbox and configures the system security modules for access
The snap daemon, snapd, handles snap management to configure and maintain each snap.
The snap damon also maintains the security configuration that creates the sandbox for both snap executables and data. This is implemented using various security modules of the Linux kernel, including Seccomp, AppAmor and Cgroups.
Snaps have the least possible privileges by default. Additional system resources are permitted through the interfaces mechanism which changes the security profile for each snap.
A snap package is a self-contained and immutable SquashFS file carrying application-specific content alongside metadata to tell the system how it should be manipulated.
Package downloads and updates are managed through a connection to the remote Snap Store, which includes package integrity and validation.
The snap daemon uses privilege isolation mechanisms rooted in the Linux kernel through Cgroups and Namespaces, AppArmor and Seccomp.
Cgroups Limit the amount of resources the process confined to a snap can consume (CPU, memory, network bandwidth, and so on). | Namespaces Make sure processes in a snap see their own personal view of the system (files, processes, network interfaces, hostname, and so on). |
AppArmor Allows system administrators to restrict snap capabilities with default security profiles that can be extended. | Seccomp Isolates processes running in a snap by limiting the system calls they are allowed to make. |
The state of snapd, and many of its key functions, can be accessed through its REST API, enabling remote device configuration, updates and orchestration.
For services:
The package ecosystem can be separated at the binary level, including the socket files, and these components include the following:
/run/snapd.socket
: Unix socket used by snap/run/snapd-snap.socket
: Unix socket used by snapctl/run/snapd.socket
: exposes REST API through/run/snapd-snap.socket
: exposes REST API through/run/snapd.socket
: makes user requests/run/snapd-snap.socket
: makes snap requestssnapctl
: runs commandssnap-confine
: prepares confinement/execs into snapLast updated 2 months ago.