GNU Guix System
GNU Guix System (previously GuixSD[6]) is a rolling release GNU/Linux distribution built around the GNU Guix package manager.[7][8] It enables a declarative operating system configuration[9] and allows reliable system upgrades that can easily be rolled back.[10] It uses GNU Shepherd init system[11][12] and the Linux-libre kernel, with support for the GNU Hurd kernel under development.[13] On February 3, 2015, the distribution was added to the Free Software Foundation's list of free Linux distributions.[14]
Developer | GNU Project[1][2] |
---|---|
OS family | Unix-like |
Working state | Current[3] |
Source model | Free software, FSDG |
Latest release | 1.2.0[4] / 23 November 2020 |
Marketing target | Desktop |
Package manager | GNU Guix |
Platforms | x86_64, i686, arm[5] |
Kernel type | Monolithic: Linux-libre (operational) Microkernel: GNU Hurd (under development) |
Userland | GNU |
License | GPL |
Official website | gnu |
Architecture support
The following CPU architectures are supported: IA-32, x64, AArch32, AArch64[15] and in April 2019 work was in progress for POWER9 support.[16]
Features
System services
System services are a core feature in Guix System that enable the user to declaratively compose the configuration of daemons and background services and easily specify the relevant configurations.
This enables the user to within a single configuration file declare the whole OS (e.g., to have a tor proxy, an sshd server, and a webserver serving guix-web via nginx on a specific port at bootup).
System services can:[17]
- generate files in the filesystem (needed by some applications e.g. files in /etc)
- run any code for setting up daemons
- create specific user and group accounts (e.g. a database user for postgresql)
Ricardo Wurmus, one of the maintainers, explains the extendability like this:[17]
Services can extend one another, which allows us to define ways to set up complex applications, for example, that require a web server, user accounts, application-specific daemons, a database, udev rules, etc — all with just one service type.
All the services are defined using Guile Scheme.[18] The list of services continue to grow and as of 1.0.0 the list of services includes the following:[19]
- Base Services: Essential system services.
- Scheduled Job Execution: The mcron service.
- Log Rotation: The rottlog service.
- Networking Services: Network setup, SSH daemon, etc.
- X Window: Graphical display.
- Printing Services: Local and remote printer support.
- Desktop Services: D-Bus and desktop services.
- Sound Services: ALSA and Pulseaudio services.
- Database Services: SQL databases, key-value stores, etc.
- Mail Services: IMAP, POP3, SMTP, and all that.
- Messaging Services: Messaging services.
- Telephony Services: Telephony services.
- Monitoring Services: Monitoring services.
- Kerberos Services: Kerberos services.
- LDAP Services: LDAP services.
- Web Services: Web servers.
- Certificate Services: TLS certificates via Let's Encrypt.
- DNS Services: DNS daemons.
- VPN Services: VPN daemons.
- Network File System: NFS related services.
- Continuous Integration: The Cuirass service.
- Power Management Services: Extending battery life.
- Audio Services: The MPD.
- Virtualization Services: Virtualization services.
- Version Control Services: Providing remote access to Git repositories.
- Game Services: Game servers.
- Miscellaneous Services: Other services.
GNU Shepherd init system
Guix System uses the GNU Daemon Shepherd as its init system, which is developed in tandem with Guix and is written in Guile as well. It was previously known as "dmd", which stood for "Daemon managing Daemons" or "Daemons-managing Daemon", but changed names to avoid collision with the Digital Mars D compiler.[20]
Shepherd supplies user-space functionality asynchronously as services, which under Shepherd are generic functions and object data types that are exported for use by the Shepherd to extend the base operating system in some defined way. In contrast to systemd, a userspace shepherd process runs as that user. Core to the Shepherd model of user space initialisation is the concept of the extension, a form of composability where services are designed to be layered onto other services, augmenting them with more elaborate or specialised behaviours as desired.[21] This expresses the instantiation-based dependency relationships found in many modern init systems,[22] making the system modular, but also allows services to interact variadically with other services in arbitrary ways.
Shepherd also provides so-called virtual services which allow dynamic dispatch over a class of related service objects, such as all those which instantiate a mail transfer agent (MTA) for the system.[23] A system governed via the Shepherd daemon can represent its user space as a directed acyclic graph, with the "system-service" − responsible for early phases of boot and init − as its root, and all subsequently initialised services as extensions to system-service's functionality, either directly or transitively over other services.[21][24]
Being both written and configured in Guile Scheme, GNU Shepherd is intended to be highly programmable by the system administrator, but it can also be used to manage per-user profiles of unprivileged daemons and services.[25] Its services and configuration are stored uniformly as object-oriented Scheme code, and while a core set of services are provided with the basic Guix System,[26] arbitrary new services can be flexibly declared, and through Guile's object system, GOOPS, existing services can be redefined at the user's discretion by asking the Shepherd to dynamically rewrite services in specified ways on instantiation.[27][28]
GNU Shepherd was originally designed to work with GNU Hurd, and was later adopted by Guix System.[29]
Release and stability
Guix System to date has only an unstable development git repository[30] shared with Guix but enables users or organizations to set up stable release channels themselves via the channel-feature.[31]
Updates
Packages in Guix are generally very up-to-date thanks to the lack of a package maintainer bottleneck: anyone can contribute an update subject to community approval and the process is assisted by tools such as guix refresh.[32]
Changes to the git repository are peer-reviewed by community members and committed by one of the 45 people with commit access.[33] In practice sometimes these builds cause system breakages for users because of a typo or similar error, but these are often solved within minutes. The way Guix pull operates means users retain a working system in the meantime.
Roll-back
If a system update should leave users with a broken system, users can easily roll back individual packages as well as the whole system state.[34] This means that a stable channel which is very common in other Linux distributions is no longer needed for users who are willing to report a bug and wait a few minutes, when trying to update via guix pull.
Reception
Jesse Smith from DistroWatch Weekly reviewed GNU Guix System 0.15.0 (at the time named GuixSD), and said, "GuixSD has a package manager that I like", but criticized the limited hardware support and its limited documentation.[35] The documentation has since then been expanded and improved with videos[36] and a cookbook[37] in six languages with tutorials, how-to guides and examples.
See also
- GNU Guix
- Debian GNU/Hurd
- Comparison of Linux distributions
- NixOS – A similar operating system, which inspired GNU Guix[38]
References
- GuixSD Contributors. "About — GuixSD". gnu.org. Archived from the original on April 12, 2017. Retrieved March 16, 2017.
- "GNU/Linux FAQ - GNU Project - Free Software Foundation". Free Software Foundation. Archived from the original on September 7, 2013. Retrieved May 14, 2017.
- "Download — GNU Guix". Archived from the original on August 1, 2020. Retrieved November 3, 2019.
- Ludovic Courtès (November 23, 2020). "GNU Guix 1.2.0 released — 2020 — Blog — GNU Guix". Retrieved November 24, 2020.
- Mathieu Othacehe. "Porting GuixSD to ARMv7". Archived from the original on December 25, 2017. Retrieved February 17, 2018.
- "What to call Guix?" (Mailing list). gnu-system-discuss. January 15, 2015. Archived from the original on August 7, 2020. Retrieved August 3, 2020.
- "List of Free GNU/Linux Distributions". Archived from the original on July 6, 2020. Retrieved February 3, 2015.
- "Guix: A New Package Manager & GNU Distribution". Phoronix. Archived from the original on February 2, 2015. Retrieved February 3, 2015.
- "Using the Configuration System". gnu.org. Archived from the original on April 29, 2019. Retrieved April 27, 2019.
- "Package Management". gnu.org. Archived from the original on May 21, 2019. Retrieved April 27, 2019.
- "Programming Interface (GNU Guix Reference Manual)". guix.gnu.org. Archived from the original on August 7, 2020. Retrieved August 3, 2020.
- "Guix: A New Package Manager & GNU Distribution - Phoronix". www.phoronix.com. Archived from the original on July 6, 2018. Retrieved August 3, 2020.
- "GNU Guix & GuixSD 0.12.0 released" (Mailing list). guix-devel. December 21, 2016. Archived from the original on August 1, 2020. Retrieved August 3, 2020.
- "FSF adds Guix System Distribution to list of endorsed distributions". Free Software Foundation. February 3, 2015. Archived from the original on February 3, 2015. Retrieved February 3, 2015.
- "Download". gnu.org. Archived from the original on July 13, 2019. Retrieved April 27, 2019.
- "Patch adding POWER9 cross compile support" (Mailing list). Archived from the original on August 1, 2020. Retrieved April 27, 2019.
- Wurmus, Ricardo. "Re: Help with preparing to move from Arch Linux to Guix" (Mailing list). Archived from the original on August 1, 2020. Retrieved May 11, 2019.
- "guix.git". git.savannah.gnu.org. Archived from the original on May 11, 2019. Retrieved May 11, 2019.
- "Services". gnu.org. Archived from the original on August 1, 2020. Retrieved May 11, 2019.
- "guix-devel mailing lists". Archived from the original on September 19, 2019. Retrieved November 5, 2016.
- "GNU Guix Reference Manual: Service Composition". GNU Project. Archived from the original on January 1, 2019. Retrieved November 5, 2016.
- "systemd: Unit Dependencies and Order". Fedora Magazine. Archived from the original on August 1, 2020. Retrieved November 5, 2016.
- "The GNU Shepherd Manual: Jump Start". GNU Project. Archived from the original on August 1, 2020. Retrieved November 5, 2016.
- "GNU Guix Reference Manual: Shepherd Services". GNU Project. Archived from the original on January 1, 2019. Retrieved November 5, 2016.
- "The GNU Shepherd Manual". GNU Project. Archived from the original on August 1, 2020. Retrieved November 5, 2016.
- "GNU Guix Reference Manual: Services". GNU Project. Archived from the original on December 25, 2018. Retrieved November 5, 2016.
- "GNU Guix Reference Manual: Service Types and Services". GNU Project. Archived from the original on January 5, 2019. Retrieved November 5, 2016.
- "GNU Guix Reference Manual: Using the Configuration System". GNU Project. Archived from the original on April 29, 2019. Retrieved November 5, 2016.
- "GNU Shepherd". GNU project. Archived from the original on February 12, 2016. Retrieved February 12, 2016.
- "Re: We need an RFC procedure" (Mailing list). Archived from the original on August 1, 2020. Retrieved April 27, 2019.
- "Channels". gnu.org. Archived from the original on May 7, 2019. Retrieved April 27, 2019.
- "Invoking guix refresh". gnu.org. Archived from the original on December 26, 2018. Retrieved May 16, 2019.
- "GNU Guix - Summary: Project Memberlist". gnu.org. Archived from the original on August 1, 2020. Retrieved April 27, 2019.
- "Invoking guix system". gnu.org. Archived from the original on May 26, 2019. Retrieved April 27, 2019.
- Smith, Jesse. "Guix System Distribution 0.15.0 and ReactOS 0.4.9". distrowatch.com (778). Archived from the original on July 30, 2019. Retrieved August 30, 2018.
- "Videos". Archived from the original on August 1, 2020. Retrieved March 3, 2020.
- "Cookbook". Archived from the original on August 1, 2020. Retrieved March 3, 2020.
- "About — GuixSD". www.gnu.org. Archived from the original on December 27, 2015. Retrieved May 3, 2018.