mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 13:49:23 -05:00
doc: Move sections under "GNU Distribution" one level higher.
* doc/guix.texi (Introduction): Add note about Guix System. [Managing Software the Guix Way]: New section heading. [GNU Distribution]: New subsection of "Introduction". Mention "Guix System" rather than "GuixSD" and update the list of supported systems. (GNU Distribution): Remove as a chapter. (System Installation, System Configuration, Documentation) (Installing Debugging Files, Security Updates, Package Modules) (Packaging Guidelines, Bootstrapping, Porting): Turn these sections into chapters.
This commit is contained in:
parent
5f2daffe09
commit
b40de030d1
1 changed files with 187 additions and 208 deletions
395
doc/guix.texi
395
doc/guix.texi
|
@ -120,7 +120,15 @@ Project}.
|
|||
* Package Management:: Package installation, upgrade, etc.
|
||||
* Programming Interface:: Using Guix in Scheme.
|
||||
* Utilities:: Package management commands.
|
||||
* GNU Distribution:: Software for your friendly GNU system.
|
||||
* System Installation:: Installing the whole operating system.
|
||||
* System Configuration:: Configuring the operating system.
|
||||
* Documentation:: Browsing software user manuals.
|
||||
* Installing Debugging Files:: Feeding the debugger.
|
||||
* Security Updates:: Deploying security fixes quickly.
|
||||
* Package Modules:: Packages from the programmer's viewpoint.
|
||||
* Packaging Guidelines:: Growing the distribution.
|
||||
* Bootstrapping:: GNU/Linux built from scratch.
|
||||
* Porting:: Targeting another platform or kernel.
|
||||
* Contributing:: Your help needed!
|
||||
|
||||
* Acknowledgments:: Thanks!
|
||||
|
@ -210,18 +218,6 @@ Invoking @command{guix build}
|
|||
* Additional Build Options:: Options specific to 'guix build'.
|
||||
* Debugging Build Failures:: Real life packaging experience.
|
||||
|
||||
GNU Distribution
|
||||
|
||||
* System Installation:: Installing the whole operating system.
|
||||
* System Configuration:: Configuring the operating system.
|
||||
* Documentation:: Browsing software user manuals.
|
||||
* Installing Debugging Files:: Feeding the debugger.
|
||||
* Security Updates:: Deploying security fixes quickly.
|
||||
* Package Modules:: Packages from the programmer's viewpoint.
|
||||
* Packaging Guidelines:: Growing the distribution.
|
||||
* Bootstrapping:: GNU/Linux built from scratch.
|
||||
* Porting:: Targeting another platform or kernel.
|
||||
|
||||
System Installation
|
||||
|
||||
* Limitations:: What you can expect.
|
||||
|
@ -297,21 +293,6 @@ Packaging Guidelines
|
|||
* Java Packages:: Coffee break.
|
||||
* Fonts:: Fond of fonts.
|
||||
|
||||
Contributing
|
||||
|
||||
* Building from Git:: The latest and greatest.
|
||||
* Running Guix Before It Is Installed:: Hacker tricks.
|
||||
* The Perfect Setup:: The right tools.
|
||||
* Coding Style:: Hygiene of the contributor.
|
||||
* Submitting Patches:: Share your work.
|
||||
|
||||
Coding Style
|
||||
|
||||
* Programming Paradigm:: How to compose your elements.
|
||||
* Modules:: Where to store your code?
|
||||
* Data Types and Pattern Matching:: Implementing data structures.
|
||||
* Formatting Code:: Writing conventions.
|
||||
|
||||
@end detailmenu
|
||||
@end menu
|
||||
|
||||
|
@ -322,11 +303,22 @@ Coding Style
|
|||
@cindex purpose
|
||||
GNU Guix@footnote{``Guix'' is pronounced like ``geeks'', or ``ɡiːks''
|
||||
using the international phonetic alphabet (IPA).} is a package
|
||||
management tool for the GNU system. Guix makes it easy for unprivileged
|
||||
users to install, upgrade, or remove packages, to roll back to a
|
||||
management tool for and distribution of the GNU system.
|
||||
Guix makes it easy for unprivileged
|
||||
users to install, upgrade, or remove software packages, to roll back to a
|
||||
previous package set, to build packages from source, and generally
|
||||
assists with the creation and maintenance of software environments.
|
||||
|
||||
@cindex Guix System
|
||||
@cindex GuixSD
|
||||
You can install GNU@tie{}Guix on top of an existing GNU/Linux system where it
|
||||
complements the available tools without interference (@pxref{Installation}),
|
||||
or you can use it as a standalone operating system distribution,
|
||||
@dfn{Guix@tie{}System} (@pxref{GNU Distribution}).
|
||||
|
||||
@node Managing Software the Guix Way
|
||||
@section Managing Software the Guix Way
|
||||
|
||||
@cindex user interfaces
|
||||
Guix provides a command-line package management interface
|
||||
(@pxref{Invoking guix package}), a set of command-line utilities
|
||||
|
@ -348,17 +340,6 @@ is also @emph{customizable}: users can @emph{derive} specialized package
|
|||
definitions from existing ones, including from the command line
|
||||
(@pxref{Package Transformation Options}).
|
||||
|
||||
@cindex Guix System Distribution
|
||||
@cindex GuixSD
|
||||
You can install GNU@tie{}Guix on top of an existing GNU/Linux system
|
||||
where it complements the available tools without interference
|
||||
(@pxref{Installation}), or you can use it as part of the standalone
|
||||
@dfn{Guix System Distribution} or GuixSD (@pxref{GNU Distribution}).
|
||||
With GNU@tie{}GuixSD, you @emph{declare} all aspects of the operating
|
||||
system configuration and Guix takes care of instantiating the
|
||||
configuration in a transactional, reproducible, and stateless fashion
|
||||
(@pxref{System Configuration}).
|
||||
|
||||
@cindex functional package management
|
||||
@cindex isolation
|
||||
Under the hood, Guix implements the @dfn{functional package management}
|
||||
|
@ -389,6 +370,81 @@ for transactional package upgrade and rollback, per-user installation, and
|
|||
garbage collection of packages (@pxref{Features}).
|
||||
|
||||
|
||||
@node GNU Distribution
|
||||
@section GNU Distribution
|
||||
|
||||
@cindex Guix System
|
||||
@cindex GuixSD
|
||||
Guix comes with a distribution of the GNU system consisting entirely of
|
||||
free software@footnote{The term ``free'' here refers to the
|
||||
@url{http://www.gnu.org/philosophy/free-sw.html,freedom provided to
|
||||
users of that software}.}. The
|
||||
distribution can be installed on its own (@pxref{System Installation}),
|
||||
but it is also possible to install Guix as a package manager on top of
|
||||
an installed GNU/Linux system (@pxref{Installation}). When we need to
|
||||
distinguish between the two, we refer to the standalone distribution as
|
||||
Guix@tie{}System.
|
||||
|
||||
The distribution provides core GNU packages such as GNU libc, GCC, and
|
||||
Binutils, as well as many GNU and non-GNU applications. The complete
|
||||
list of available packages can be browsed
|
||||
@url{http://www.gnu.org/software/guix/packages,on-line} or by
|
||||
running @command{guix package} (@pxref{Invoking guix package}):
|
||||
|
||||
@example
|
||||
guix package --list-available
|
||||
@end example
|
||||
|
||||
Our goal is to provide a practical 100% free software distribution of
|
||||
Linux-based and other variants of GNU, with a focus on the promotion and
|
||||
tight integration of GNU components, and an emphasis on programs and
|
||||
tools that help users exert that freedom.
|
||||
|
||||
Packages are currently available on the following platforms:
|
||||
|
||||
@table @code
|
||||
|
||||
@item x86_64-linux
|
||||
Intel/AMD @code{x86_64} architecture, Linux-Libre kernel;
|
||||
|
||||
@item i686-linux
|
||||
Intel 32-bit architecture (IA32), Linux-Libre kernel;
|
||||
|
||||
@item armhf-linux
|
||||
ARMv7-A architecture with hard float, Thumb-2 and NEON,
|
||||
using the EABI hard-float application binary interface (ABI),
|
||||
and Linux-Libre kernel.
|
||||
|
||||
@item aarch64-linux
|
||||
little-endian 64-bit ARMv8-A processors, Linux-Libre kernel. This is
|
||||
currently in an experimental stage, with limited support.
|
||||
@xref{Contributing}, for how to help!
|
||||
|
||||
@item mips64el-linux
|
||||
little-endian 64-bit MIPS processors, specifically the Loongson series,
|
||||
n32 ABI, and Linux-Libre kernel.
|
||||
|
||||
@end table
|
||||
|
||||
With Guix@tie{}System, you @emph{declare} all aspects of the operating system
|
||||
configuration and Guix takes care of instantiating the configuration in a
|
||||
transactional, reproducible, and stateless fashion (@pxref{System
|
||||
Configuration}). Guix System uses the Linux-libre kernel, the Shepherd
|
||||
initialization system (@pxref{Introduction,,, shepherd, The GNU Shepherd
|
||||
Manual}), the well-known GNU utilities and tool chain, as well as the
|
||||
graphical environment or system services of your choice.
|
||||
|
||||
Guix System is available on all the above platforms except
|
||||
@code{mips64el-linux}.
|
||||
|
||||
@noindent
|
||||
For information on porting to other architectures or kernels,
|
||||
@pxref{Porting}.
|
||||
|
||||
Building this distribution is a cooperative effort, and you are invited
|
||||
to join! @xref{Contributing}, for information about how you can help.
|
||||
|
||||
|
||||
@c *********************************************************************
|
||||
@node Installation
|
||||
@chapter Installation
|
||||
|
@ -9034,86 +9090,9 @@ ClientPID: 19419
|
|||
ClientCommand: cuirass --cache-directory /var/cache/cuirass @dots{}
|
||||
@end example
|
||||
|
||||
@c *********************************************************************
|
||||
@node GNU Distribution
|
||||
@chapter GNU Distribution
|
||||
|
||||
@cindex Guix System Distribution
|
||||
@cindex GuixSD
|
||||
Guix comes with a distribution of the GNU system consisting entirely of
|
||||
free software@footnote{The term ``free'' here refers to the
|
||||
@url{http://www.gnu.org/philosophy/free-sw.html,freedom provided to
|
||||
users of that software}.}. The
|
||||
distribution can be installed on its own (@pxref{System Installation}),
|
||||
but it is also possible to install Guix as a package manager on top of
|
||||
an installed GNU/Linux system (@pxref{Installation}). To distinguish
|
||||
between the two, we refer to the standalone distribution as the Guix
|
||||
System Distribution, or GuixSD.
|
||||
|
||||
The distribution provides core GNU packages such as GNU libc, GCC, and
|
||||
Binutils, as well as many GNU and non-GNU applications. The complete
|
||||
list of available packages can be browsed
|
||||
@url{http://www.gnu.org/software/guix/packages,on-line} or by
|
||||
running @command{guix package} (@pxref{Invoking guix package}):
|
||||
|
||||
@example
|
||||
guix package --list-available
|
||||
@end example
|
||||
|
||||
Our goal is to provide a practical 100% free software distribution of
|
||||
Linux-based and other variants of GNU, with a focus on the promotion and
|
||||
tight integration of GNU components, and an emphasis on programs and
|
||||
tools that help users exert that freedom.
|
||||
|
||||
Packages are currently available on the following platforms:
|
||||
|
||||
@table @code
|
||||
|
||||
@item x86_64-linux
|
||||
Intel/AMD @code{x86_64} architecture, Linux-Libre kernel;
|
||||
|
||||
@item i686-linux
|
||||
Intel 32-bit architecture (IA32), Linux-Libre kernel;
|
||||
|
||||
@item armhf-linux
|
||||
ARMv7-A architecture with hard float, Thumb-2 and NEON,
|
||||
using the EABI hard-float application binary interface (ABI),
|
||||
and Linux-Libre kernel.
|
||||
|
||||
@item aarch64-linux
|
||||
little-endian 64-bit ARMv8-A processors, Linux-Libre kernel. This is
|
||||
currently in an experimental stage, with limited support.
|
||||
@xref{Contributing}, for how to help!
|
||||
|
||||
@item mips64el-linux
|
||||
little-endian 64-bit MIPS processors, specifically the Loongson series,
|
||||
n32 ABI, and Linux-Libre kernel.
|
||||
|
||||
@end table
|
||||
|
||||
GuixSD itself is currently only available on @code{i686} and @code{x86_64}.
|
||||
|
||||
@noindent
|
||||
For information on porting to other architectures or kernels,
|
||||
@pxref{Porting}.
|
||||
|
||||
@menu
|
||||
* System Installation:: Installing the whole operating system.
|
||||
* System Configuration:: Configuring the operating system.
|
||||
* Documentation:: Browsing software user manuals.
|
||||
* Installing Debugging Files:: Feeding the debugger.
|
||||
* Security Updates:: Deploying security fixes quickly.
|
||||
* Package Modules:: Packages from the programmer's viewpoint.
|
||||
* Packaging Guidelines:: Growing the distribution.
|
||||
* Bootstrapping:: GNU/Linux built from scratch.
|
||||
* Porting:: Targeting another platform or kernel.
|
||||
@end menu
|
||||
|
||||
Building this distribution is a cooperative effort, and you are invited
|
||||
to join! @xref{Contributing}, for information about how you can help.
|
||||
|
||||
@node System Installation
|
||||
@section System Installation
|
||||
@chapter System Installation
|
||||
|
||||
@cindex installing GuixSD
|
||||
@cindex Guix System Distribution
|
||||
|
@ -9147,7 +9126,7 @@ available.
|
|||
@end menu
|
||||
|
||||
@node Limitations
|
||||
@subsection Limitations
|
||||
@section Limitations
|
||||
|
||||
As of version @value{VERSION}, the Guix System Distribution (GuixSD) is
|
||||
not production-ready. It may contain bugs and lack important
|
||||
|
@ -9191,7 +9170,7 @@ to report issues (and success stories!), and to join us in improving it.
|
|||
|
||||
|
||||
@node Hardware Considerations
|
||||
@subsection Hardware Considerations
|
||||
@section Hardware Considerations
|
||||
|
||||
@cindex hardware support on GuixSD
|
||||
GNU@tie{}GuixSD focuses on respecting the user's computing freedom. It
|
||||
|
@ -9226,7 +9205,7 @@ about their support in GNU/Linux.
|
|||
|
||||
|
||||
@node USB Stick and DVD Installation
|
||||
@subsection USB Stick and DVD Installation
|
||||
@section USB Stick and DVD Installation
|
||||
|
||||
An ISO-9660 installation image that can be written to a USB stick or
|
||||
burnt to a DVD can be downloaded from
|
||||
|
@ -9265,7 +9244,7 @@ and rerun the @code{gpg --verify} command.
|
|||
This image contains the tools necessary for an installation.
|
||||
It is meant to be copied @emph{as is} to a large-enough USB stick or DVD.
|
||||
|
||||
@unnumberedsubsubsec Copying to a USB Stick
|
||||
@unnumberedsubsec Copying to a USB Stick
|
||||
|
||||
To copy the image to a USB stick, follow these steps:
|
||||
|
||||
|
@ -9290,7 +9269,7 @@ sync
|
|||
Access to @file{/dev/sdX} usually requires root privileges.
|
||||
@end enumerate
|
||||
|
||||
@unnumberedsubsubsec Burning on a DVD
|
||||
@unnumberedsubsec Burning on a DVD
|
||||
|
||||
To copy the image to a DVD, follow these steps:
|
||||
|
||||
|
@ -9314,7 +9293,7 @@ growisofs -dvd-compat -Z /dev/srX=guixsd-install-@value{VERSION}.@var{system}.is
|
|||
Access to @file{/dev/srX} usually requires root privileges.
|
||||
@end enumerate
|
||||
|
||||
@unnumberedsubsubsec Booting
|
||||
@unnumberedsubsec Booting
|
||||
|
||||
Once this is done, you should be able to reboot the system and boot from
|
||||
the USB stick or DVD. The latter usually requires you to get in the
|
||||
|
@ -9325,7 +9304,7 @@ GuixSD in a virtual machine (VM).
|
|||
|
||||
|
||||
@node Preparing for Installation
|
||||
@subsection Preparing for Installation
|
||||
@section Preparing for Installation
|
||||
|
||||
Once you have successfully booted your computer using the installation medium,
|
||||
you should end up with the welcome page of the graphical installer. The
|
||||
|
@ -9354,7 +9333,7 @@ But it is also a full-blown GuixSD system, which means that you can
|
|||
install additional packages, should you need it, using @command{guix
|
||||
package} (@pxref{Invoking guix package}).
|
||||
|
||||
@subsubsection Keyboard Layout
|
||||
@subsection Keyboard Layout
|
||||
|
||||
@cindex keyboard layout
|
||||
The installation image uses the US qwerty keyboard layout. If you want
|
||||
|
@ -9369,7 +9348,7 @@ See the files under @file{/run/current-system/profile/share/keymaps} for
|
|||
a list of available keyboard layouts. Run @command{man loadkeys} for
|
||||
more information.
|
||||
|
||||
@subsubsection Networking
|
||||
@subsection Networking
|
||||
|
||||
Run the following command to see what your network interfaces are called:
|
||||
|
||||
|
@ -9462,7 +9441,7 @@ herd start ssh-daemon
|
|||
Make sure to either set a password with @command{passwd}, or configure
|
||||
OpenSSH public key authentication before logging in.
|
||||
|
||||
@subsubsection Disk Partitioning
|
||||
@subsection Disk Partitioning
|
||||
|
||||
Unless this has already been done, the next step is to partition, and
|
||||
then format the target partition(s).
|
||||
|
@ -9583,7 +9562,7 @@ file in its file system as described above, then the encryption also
|
|||
protects the swap file, just like any other file in that file system.
|
||||
|
||||
@node Proceeding with the Installation
|
||||
@subsection Proceeding with the Installation
|
||||
@section Proceeding with the Installation
|
||||
|
||||
With the target partitions ready and the target root mounted on
|
||||
@file{/mnt}, we're ready to go. First, run:
|
||||
|
@ -9680,7 +9659,7 @@ Join us on @code{#guix} on the Freenode IRC network or on
|
|||
good.
|
||||
|
||||
@node Installing GuixSD in a VM
|
||||
@subsection Installing GuixSD in a Virtual Machine
|
||||
@section Installing GuixSD in a Virtual Machine
|
||||
|
||||
@cindex virtual machine, GuixSD installation
|
||||
@cindex virtual private server (VPS)
|
||||
|
@ -9734,7 +9713,7 @@ Once installation is complete, you can boot the system that's on your
|
|||
that.
|
||||
|
||||
@node Building the Installation Image
|
||||
@subsection Building the Installation Image
|
||||
@section Building the Installation Image
|
||||
|
||||
@cindex installation image
|
||||
The installation image described above was built using the @command{guix
|
||||
|
@ -9748,7 +9727,7 @@ Have a look at @file{gnu/system/install.scm} in the source tree,
|
|||
and see also @ref{Invoking guix system} for more information
|
||||
about the installation image.
|
||||
|
||||
@subsection Building the Installation Image for ARM Boards
|
||||
@section Building the Installation Image for ARM Boards
|
||||
|
||||
Many ARM boards require a specific variant of the
|
||||
@uref{http://www.denx.de/wiki/U-Boot/, U-Boot} bootloader.
|
||||
|
@ -9765,7 +9744,7 @@ guix system disk-image --system=armhf-linux -e '((@@ (gnu system install) os-wit
|
|||
board, a list of possible boards will be printed.
|
||||
|
||||
@node System Configuration
|
||||
@section System Configuration
|
||||
@chapter System Configuration
|
||||
|
||||
@cindex system configuration
|
||||
The Guix System Distribution supports a consistent whole-system configuration
|
||||
|
@ -9808,7 +9787,7 @@ instance to support new system services.
|
|||
@end menu
|
||||
|
||||
@node Using the Configuration System
|
||||
@subsection Using the Configuration System
|
||||
@section Using the Configuration System
|
||||
|
||||
The operating system is configured by providing an
|
||||
@code{operating-system} declaration in a file that can then be passed to
|
||||
|
@ -9831,7 +9810,7 @@ Below we discuss the effect of some of the most important fields
|
|||
fields), and how to @dfn{instantiate} the operating system using
|
||||
@command{guix system}.
|
||||
|
||||
@unnumberedsubsubsec Bootloader
|
||||
@unnumberedsubsec Bootloader
|
||||
|
||||
@cindex legacy boot, on Intel machines
|
||||
@cindex BIOS boot, on Intel machines
|
||||
|
@ -9852,7 +9831,7 @@ the @code{bootloader} field should contain something along these lines:
|
|||
@xref{Bootloader Configuration}, for more information on the available
|
||||
configuration options.
|
||||
|
||||
@unnumberedsubsubsec Globally-Visible Packages
|
||||
@unnumberedsubsec Globally-Visible Packages
|
||||
|
||||
@vindex %base-packages
|
||||
The @code{packages} field lists packages that will be globally visible
|
||||
|
@ -9898,7 +9877,7 @@ version:
|
|||
%base-packages)))
|
||||
@end lisp
|
||||
|
||||
@unnumberedsubsubsec System Services
|
||||
@unnumberedsubsec System Services
|
||||
|
||||
@cindex services
|
||||
@vindex %base-services
|
||||
|
@ -9990,7 +9969,7 @@ following expression returns a list that contains all the services in
|
|||
%desktop-services)
|
||||
@end example
|
||||
|
||||
@unnumberedsubsubsec Instantiating the System
|
||||
@unnumberedsubsec Instantiating the System
|
||||
|
||||
Assuming the @code{operating-system} declaration
|
||||
is stored in the @file{my-system-config.scm}
|
||||
|
@ -10023,7 +10002,7 @@ the latest (e.g., after invoking @command{guix system roll-back}), since
|
|||
the operation might overwrite a later generation (@pxref{Invoking guix
|
||||
system}).
|
||||
|
||||
@unnumberedsubsubsec The Programming Interface
|
||||
@unnumberedsubsec The Programming Interface
|
||||
|
||||
At the Scheme level, the bulk of an @code{operating-system} declaration
|
||||
is instantiated with the following monadic procedure (@pxref{The Store
|
||||
|
@ -10044,7 +10023,7 @@ guts of GuixSD. Make sure to visit it!
|
|||
|
||||
|
||||
@node operating-system Reference
|
||||
@subsection @code{operating-system} Reference
|
||||
@section @code{operating-system} Reference
|
||||
|
||||
This section summarizes all the options available in
|
||||
@code{operating-system} declarations (@pxref{Using the Configuration
|
||||
|
@ -10198,7 +10177,7 @@ is that only @code{root} and members of the @code{wheel} group may use
|
|||
@end deftp
|
||||
|
||||
@node File Systems
|
||||
@subsection File Systems
|
||||
@section File Systems
|
||||
|
||||
The list of file systems to be mounted is specified in the
|
||||
@code{file-systems} field of the operating system declaration
|
||||
|
@ -10363,7 +10342,7 @@ and unmount user-space FUSE file systems. This requires the
|
|||
@end defvr
|
||||
|
||||
@node Mapped Devices
|
||||
@subsection Mapped Devices
|
||||
@section Mapped Devices
|
||||
|
||||
@cindex device mapping
|
||||
@cindex mapped devices
|
||||
|
@ -10484,7 +10463,7 @@ automatically later.
|
|||
|
||||
|
||||
@node User Accounts
|
||||
@subsection User Accounts
|
||||
@section User Accounts
|
||||
|
||||
@cindex users
|
||||
@cindex accounts
|
||||
|
@ -10619,7 +10598,7 @@ special-case and is automatically added whether or not it is specified.
|
|||
@end defvr
|
||||
|
||||
@node Locales
|
||||
@subsection Locales
|
||||
@section Locales
|
||||
|
||||
@cindex locale
|
||||
A @dfn{locale} defines cultural conventions for a particular language
|
||||
|
@ -10707,7 +10686,7 @@ instance it has @code{uk_UA.utf8} but @emph{not}, say,
|
|||
@code{uk_UA.UTF-8}.
|
||||
@end defvr
|
||||
|
||||
@subsubsection Locale Data Compatibility Considerations
|
||||
@subsection Locale Data Compatibility Considerations
|
||||
|
||||
@cindex incompatibility, of locale data
|
||||
@code{operating-system} declarations provide a @code{locale-libcs} field
|
||||
|
@ -10759,7 +10738,7 @@ both libc 2.21 and the current version of libc in
|
|||
|
||||
|
||||
@node Services
|
||||
@subsection Services
|
||||
@section Services
|
||||
|
||||
@cindex system services
|
||||
An important part of preparing an @code{operating-system} declaration is
|
||||
|
@ -10837,7 +10816,7 @@ declaration.
|
|||
@end menu
|
||||
|
||||
@node Base Services
|
||||
@subsubsection Base Services
|
||||
@subsection Base Services
|
||||
|
||||
The @code{(gnu services base)} module provides definitions for the basic
|
||||
services that one expects from the system. The services exported by
|
||||
|
@ -11652,7 +11631,7 @@ commonly used for real-time audio systems.
|
|||
@end deffn
|
||||
|
||||
@node Scheduled Job Execution
|
||||
@subsubsection Scheduled Job Execution
|
||||
@subsection Scheduled Job Execution
|
||||
|
||||
@cindex cron
|
||||
@cindex mcron
|
||||
|
@ -11753,7 +11732,7 @@ specifications,, mcron, GNU@tie{}mcron}).
|
|||
|
||||
|
||||
@node Log Rotation
|
||||
@subsubsection Log Rotation
|
||||
@subsection Log Rotation
|
||||
|
||||
@cindex rottlog
|
||||
@cindex log rotation
|
||||
|
@ -11855,7 +11834,7 @@ The list of syslog-controlled files to be rotated. By default it is:
|
|||
@end defvr
|
||||
|
||||
@node Networking Services
|
||||
@subsubsection Networking Services
|
||||
@subsection Networking Services
|
||||
|
||||
The @code{(gnu services networking)} module provides services to configure
|
||||
the network interface.
|
||||
|
@ -12800,7 +12779,7 @@ Package object of the Open vSwitch.
|
|||
@end deftp
|
||||
|
||||
@node X Window
|
||||
@subsubsection X Window
|
||||
@subsection X Window
|
||||
|
||||
@cindex X11
|
||||
@cindex X Window System
|
||||
|
@ -13084,7 +13063,7 @@ makes the good ol' XlockMore usable.
|
|||
|
||||
|
||||
@node Printing Services
|
||||
@subsubsection Printing Services
|
||||
@subsection Printing Services
|
||||
|
||||
@cindex printer support with CUPS
|
||||
The @code{(gnu services cups)} module provides a Guix service definition
|
||||
|
@ -13925,7 +13904,7 @@ this:
|
|||
|
||||
|
||||
@node Desktop Services
|
||||
@subsubsection Desktop Services
|
||||
@subsection Desktop Services
|
||||
|
||||
The @code{(gnu services desktop)} module provides services that are
|
||||
usually useful in the context of a ``desktop'' setup---that is, on a
|
||||
|
@ -14233,7 +14212,7 @@ Users need to be in the @code{lp} group to access the D-Bus service.
|
|||
@end deffn
|
||||
|
||||
@node Sound Services
|
||||
@subsubsection Sound Services
|
||||
@subsection Sound Services
|
||||
|
||||
@cindex sound support
|
||||
@cindex ALSA
|
||||
|
@ -14314,7 +14293,7 @@ details.
|
|||
|
||||
|
||||
@node Database Services
|
||||
@subsubsection Database Services
|
||||
@subsection Database Services
|
||||
|
||||
@cindex database
|
||||
@cindex SQL
|
||||
|
@ -14438,7 +14417,7 @@ Directory in which to store the database and related files.
|
|||
@end deftp
|
||||
|
||||
@node Mail Services
|
||||
@subsubsection Mail Services
|
||||
@subsection Mail Services
|
||||
|
||||
@cindex mail
|
||||
@cindex email
|
||||
|
@ -15909,7 +15888,7 @@ the @code{postmaster} mail to @code{bob} (which subsequently would
|
|||
deliver mail to @code{bob@@example.com} and @code{bob@@example2.com}).
|
||||
|
||||
@node Messaging Services
|
||||
@subsubsection Messaging Services
|
||||
@subsection Messaging Services
|
||||
|
||||
@cindex messaging
|
||||
@cindex jabber
|
||||
|
@ -16411,7 +16390,7 @@ and Error.
|
|||
@end deftp
|
||||
|
||||
@node Telephony Services
|
||||
@subsubsection Telephony Services
|
||||
@subsection Telephony Services
|
||||
|
||||
@cindex Murmur (VoIP server)
|
||||
@cindex VoIP server
|
||||
|
@ -16616,7 +16595,7 @@ If it is set your server will be linked by this host name instead.
|
|||
|
||||
|
||||
@node Monitoring Services
|
||||
@subsubsection Monitoring Services
|
||||
@subsection Monitoring Services
|
||||
|
||||
@subsubheading Tailon Service
|
||||
|
||||
|
@ -17121,7 +17100,7 @@ Defaults to @samp{10051}.
|
|||
@c %end of fragment
|
||||
|
||||
@node Kerberos Services
|
||||
@subsubsection Kerberos Services
|
||||
@subsection Kerberos Services
|
||||
@cindex Kerberos
|
||||
|
||||
The @code{(gnu services kerberos)} module provides services relating to
|
||||
|
@ -17247,7 +17226,7 @@ Local accounts with lower values will silently fail to authenticate.
|
|||
|
||||
|
||||
@node Web Services
|
||||
@subsubsection Web Services
|
||||
@subsection Web Services
|
||||
|
||||
@cindex web
|
||||
@cindex www
|
||||
|
@ -18048,7 +18027,7 @@ more information on X.509 certificates.
|
|||
@end quotation
|
||||
|
||||
@node Certificate Services
|
||||
@subsubsection Certificate Services
|
||||
@subsection Certificate Services
|
||||
|
||||
@cindex Web
|
||||
@cindex HTTP, HTTPS
|
||||
|
@ -18194,7 +18173,7 @@ For each @code{certificate-configuration}, the certificate is saved to
|
|||
@code{/etc/letsencrypt/live/@var{name}/fullchain.pem} and the key is
|
||||
saved to @code{/etc/letsencrypt/live/@var{name}/privkey.pem}.
|
||||
@node DNS Services
|
||||
@subsubsection DNS Services
|
||||
@subsection DNS Services
|
||||
@cindex DNS (domain name system)
|
||||
@cindex domain name system (DNS)
|
||||
|
||||
|
@ -18763,7 +18742,7 @@ Defaults to @samp{()}.
|
|||
|
||||
|
||||
@node VPN Services
|
||||
@subsubsection VPN Services
|
||||
@subsection VPN Services
|
||||
@cindex VPN (virtual private network)
|
||||
@cindex virtual private network (VPN)
|
||||
|
||||
|
@ -19121,7 +19100,7 @@ Defaults to @samp{#f}.
|
|||
|
||||
|
||||
@node Network File System
|
||||
@subsubsection Network File System
|
||||
@subsection Network File System
|
||||
@cindex NFS
|
||||
|
||||
The @code{(gnu services nfs)} module provides the following services,
|
||||
|
@ -19236,7 +19215,7 @@ If it is @code{#f} then the daemon will use the host's fully qualified domain na
|
|||
@end deftp
|
||||
|
||||
@node Continuous Integration
|
||||
@subsubsection Continuous Integration
|
||||
@subsection Continuous Integration
|
||||
|
||||
@cindex continuous integration
|
||||
@uref{https://git.savannah.gnu.org/cgit/guix/guix-cuirass.git, Cuirass} is a
|
||||
|
@ -19353,7 +19332,7 @@ The Cuirass package to use.
|
|||
@end deftp
|
||||
|
||||
@node Power Management Services
|
||||
@subsubsection Power Management Services
|
||||
@subsection Power Management Services
|
||||
|
||||
@cindex tlp
|
||||
@cindex power management with TLP
|
||||
|
@ -19887,7 +19866,7 @@ Package object of thermald.
|
|||
@end deftp
|
||||
|
||||
@node Audio Services
|
||||
@subsubsection Audio Services
|
||||
@subsection Audio Services
|
||||
|
||||
The @code{(gnu services audio)} module provides a service to start MPD
|
||||
(the Music Player Daemon).
|
||||
|
@ -19937,7 +19916,7 @@ an absolute path can be specified here.
|
|||
@end deftp
|
||||
|
||||
@node Virtualization Services
|
||||
@subsubsection Virtualization services
|
||||
@subsection Virtualization services
|
||||
|
||||
The @code{(gnu services virtualization)} module provides services for
|
||||
the libvirt and virtlog daemons, as well as other virtualization-related
|
||||
|
@ -20730,7 +20709,7 @@ Return the name of @var{platform}---a string such as @code{"arm"}.
|
|||
@end deffn
|
||||
|
||||
@node Version Control Services
|
||||
@subsubsection Version Control Services
|
||||
@subsection Version Control Services
|
||||
|
||||
The @code{(gnu services version-control)} module provides a service to
|
||||
allow remote access to local Git repositories. There are three options:
|
||||
|
@ -21918,7 +21897,7 @@ This setting controls the commands and features to enable within Gitolite.
|
|||
|
||||
|
||||
@node Game Services
|
||||
@subsubsection Game Services
|
||||
@subsection Game Services
|
||||
|
||||
@subsubheading The Battle for Wesnoth Service
|
||||
@cindex wesnothd
|
||||
|
@ -21949,7 +21928,7 @@ The port to bind the server to.
|
|||
@end deftp
|
||||
|
||||
@node Miscellaneous Services
|
||||
@subsubsection Miscellaneous Services
|
||||
@subsection Miscellaneous Services
|
||||
|
||||
@cindex fingerprint
|
||||
@subsubheading Fingerprint Service
|
||||
|
@ -22057,7 +22036,7 @@ that enables sharing the clipboard with a vm and setting the guest display
|
|||
resolution when the graphical console window resizes.
|
||||
@end deffn
|
||||
|
||||
@subsubsection Dictionary Services
|
||||
@subsection Dictionary Services
|
||||
@cindex dictionary
|
||||
The @code{(gnu services dict)} module provides the following service:
|
||||
|
||||
|
@ -22183,7 +22162,7 @@ The Containerd package to use.
|
|||
@end deftp
|
||||
|
||||
@node Setuid Programs
|
||||
@subsection Setuid Programs
|
||||
@section Setuid Programs
|
||||
|
||||
@cindex setuid programs
|
||||
Some programs need to run with ``root'' privileges, even when they are
|
||||
|
@ -22229,7 +22208,7 @@ files in this directory refer to the ``real'' binaries, which are in the
|
|||
store.
|
||||
|
||||
@node X.509 Certificates
|
||||
@subsection X.509 Certificates
|
||||
@section X.509 Certificates
|
||||
|
||||
@cindex HTTPS, certificates
|
||||
@cindex X.509 certificates
|
||||
|
@ -22292,7 +22271,7 @@ variable in the relevant documentation.
|
|||
|
||||
|
||||
@node Name Service Switch
|
||||
@subsection Name Service Switch
|
||||
@section Name Service Switch
|
||||
|
||||
@cindex name service switch
|
||||
@cindex NSS
|
||||
|
@ -22430,7 +22409,7 @@ Reference Manual}). For example:
|
|||
@end deftp
|
||||
|
||||
@node Initial RAM Disk
|
||||
@subsection Initial RAM Disk
|
||||
@section Initial RAM Disk
|
||||
|
||||
@cindex initrd
|
||||
@cindex initial RAM disk
|
||||
|
@ -22590,7 +22569,7 @@ automatically copied to the initrd.
|
|||
@end deffn
|
||||
|
||||
@node Bootloader Configuration
|
||||
@subsection Bootloader Configuration
|
||||
@section Bootloader Configuration
|
||||
|
||||
@cindex bootloader
|
||||
@cindex boot loader
|
||||
|
@ -22774,7 +22753,7 @@ logos.
|
|||
|
||||
|
||||
@node Invoking guix system
|
||||
@subsection Invoking @code{guix system}
|
||||
@section Invoking @code{guix system}
|
||||
|
||||
Once you have written an operating system declaration as seen in the
|
||||
previous section, it can be @dfn{instantiated} using the @command{guix
|
||||
|
@ -23202,7 +23181,7 @@ example graph.
|
|||
@end table
|
||||
|
||||
@node Running GuixSD in a VM
|
||||
@subsection Running GuixSD in a Virtual Machine
|
||||
@section Running GuixSD in a Virtual Machine
|
||||
|
||||
@cindex virtual machine
|
||||
To run GuixSD in a virtual machine (VM), one can either use the
|
||||
|
@ -23267,7 +23246,7 @@ to your system definition and start the VM using
|
|||
it uses the ICMP protocol. You'll have to use a different command to check for
|
||||
network connectivity, for example @command{guix download}.
|
||||
|
||||
@subsubsection Connecting Through SSH
|
||||
@subsection Connecting Through SSH
|
||||
|
||||
@cindex SSH
|
||||
@cindex SSH server
|
||||
|
@ -23293,7 +23272,7 @@ every time you modify your @command{config.scm} file and the
|
|||
@command{-o StrictHostKeyChecking=no} prevents you from having to allow a
|
||||
connection to an unknown host every time you connect.
|
||||
|
||||
@subsubsection Using @command{virt-viewer} with Spice
|
||||
@subsection Using @command{virt-viewer} with Spice
|
||||
|
||||
As an alternative to the default @command{qemu} graphical client you can
|
||||
use the @command{remote-viewer} from the @command{virt-viewer} package. To
|
||||
|
@ -23313,7 +23292,7 @@ name=com.redhat.spice.0
|
|||
You'll also need to add the @pxref{Miscellaneous Services, Spice service}.
|
||||
|
||||
@node Defining Services
|
||||
@subsection Defining Services
|
||||
@section Defining Services
|
||||
|
||||
The previous sections show the available services and how one can combine
|
||||
them in an @code{operating-system} declaration. But how do we define
|
||||
|
@ -23327,7 +23306,7 @@ them in the first place? And what is a service anyway?
|
|||
@end menu
|
||||
|
||||
@node Service Composition
|
||||
@subsubsection Service Composition
|
||||
@subsection Service Composition
|
||||
|
||||
@cindex services
|
||||
@cindex daemons
|
||||
|
@ -23383,7 +23362,7 @@ The following section describes the programming interface for service
|
|||
types and services.
|
||||
|
||||
@node Service Types and Services
|
||||
@subsubsection Service Types and Services
|
||||
@subsection Service Types and Services
|
||||
|
||||
A @dfn{service type} is a node in the DAG described above. Let us start
|
||||
with a simple example, the service type for the Guix build daemon
|
||||
|
@ -23520,7 +23499,7 @@ Still here? The next section provides a reference of the programming
|
|||
interface for services.
|
||||
|
||||
@node Service Reference
|
||||
@subsubsection Service Reference
|
||||
@subsection Service Reference
|
||||
|
||||
We have seen an overview of service types (@pxref{Service Types and
|
||||
Services}). This section provides a reference on how to manipulate
|
||||
|
@ -23745,7 +23724,7 @@ extend it by passing it lists of packages to add to the system profile.
|
|||
|
||||
|
||||
@node Shepherd Services
|
||||
@subsubsection Shepherd Services
|
||||
@subsection Shepherd Services
|
||||
|
||||
@cindex shepherd services
|
||||
@cindex PID 1
|
||||
|
@ -23889,7 +23868,7 @@ This service represents PID@tie{}1.
|
|||
|
||||
|
||||
@node Documentation
|
||||
@section Documentation
|
||||
@chapter Documentation
|
||||
|
||||
@cindex documentation, searching for
|
||||
@cindex searching for documentation
|
||||
|
@ -23953,7 +23932,7 @@ bindings to navigate manuals. @xref{Getting Started,,, info, Info: An
|
|||
Introduction}, for an introduction to Info navigation.
|
||||
|
||||
@node Installing Debugging Files
|
||||
@section Installing Debugging Files
|
||||
@chapter Installing Debugging Files
|
||||
|
||||
@cindex debugging files
|
||||
Program binaries, as produced by the GCC compilers for instance, are
|
||||
|
@ -24019,7 +23998,7 @@ the load. To check whether a package has a @code{debug} output, use
|
|||
|
||||
|
||||
@node Security Updates
|
||||
@section Security Updates
|
||||
@chapter Security Updates
|
||||
|
||||
@cindex security updates
|
||||
@cindex security vulnerabilities
|
||||
|
@ -24139,7 +24118,7 @@ lsof | grep /gnu/store/.*bash
|
|||
|
||||
|
||||
@node Package Modules
|
||||
@section Package Modules
|
||||
@chapter Package Modules
|
||||
|
||||
From a programming viewpoint, the package definitions of the
|
||||
GNU distribution are provided by Guile modules in the @code{(gnu packages
|
||||
|
@ -24201,7 +24180,7 @@ bootstrap)} module. For more information on bootstrapping,
|
|||
@pxref{Bootstrapping}.
|
||||
|
||||
@node Packaging Guidelines
|
||||
@section Packaging Guidelines
|
||||
@chapter Packaging Guidelines
|
||||
|
||||
@cindex packages, creating
|
||||
The GNU distribution is nascent and may well lack some of your favorite
|
||||
|
@ -24278,7 +24257,7 @@ needed is to review and apply the patch.
|
|||
@end menu
|
||||
|
||||
@node Software Freedom
|
||||
@subsection Software Freedom
|
||||
@section Software Freedom
|
||||
|
||||
@c Adapted from http://www.gnu.org/philosophy/philosophy.html.
|
||||
@cindex free software
|
||||
|
@ -24306,7 +24285,7 @@ upstream source.
|
|||
|
||||
|
||||
@node Package Naming
|
||||
@subsection Package Naming
|
||||
@section Package Naming
|
||||
|
||||
@cindex package name
|
||||
A package has actually two names associated with it:
|
||||
|
@ -24331,7 +24310,7 @@ Font package names are handled differently, @pxref{Fonts}.
|
|||
|
||||
|
||||
@node Version Numbers
|
||||
@subsection Version Numbers
|
||||
@section Version Numbers
|
||||
|
||||
@cindex package version
|
||||
We usually package only the latest version of a given free software
|
||||
|
@ -24422,7 +24401,7 @@ definition may look like this:
|
|||
@end example
|
||||
|
||||
@node Synopses and Descriptions
|
||||
@subsection Synopses and Descriptions
|
||||
@section Synopses and Descriptions
|
||||
|
||||
@cindex package description
|
||||
@cindex package synopsis
|
||||
|
@ -24502,7 +24481,7 @@ for the X11 resize-and-rotate (RandR) extension. @dots{}")
|
|||
|
||||
|
||||
@node Python Modules
|
||||
@subsection Python Modules
|
||||
@section Python Modules
|
||||
|
||||
@cindex python
|
||||
We currently package Python 2 and Python 3, under the Scheme variable names
|
||||
|
@ -24523,7 +24502,7 @@ for instance, the module python-dateutil is packaged under the names
|
|||
starts with @code{py} (e.g.@: @code{pytz}), we keep it and prefix it as
|
||||
described above.
|
||||
|
||||
@subsubsection Specifying Dependencies
|
||||
@subsection Specifying Dependencies
|
||||
@cindex inputs, for Python packages
|
||||
|
||||
Dependency information for Python packages is usually available in the
|
||||
|
@ -24577,7 +24556,7 @@ size}}).
|
|||
|
||||
|
||||
@node Perl Modules
|
||||
@subsection Perl Modules
|
||||
@section Perl Modules
|
||||
|
||||
@cindex perl
|
||||
Perl programs standing for themselves are named as any other package,
|
||||
|
@ -24593,7 +24572,7 @@ prefix. For instance, @code{libwww-perl} becomes @code{perl-libwww}.
|
|||
|
||||
|
||||
@node Java Packages
|
||||
@subsection Java Packages
|
||||
@section Java Packages
|
||||
|
||||
@cindex java
|
||||
Java programs standing for themselves are named as any other package,
|
||||
|
@ -24613,7 +24592,7 @@ dashes and prepend the prefix @code{java-}. So the class
|
|||
|
||||
|
||||
@node Fonts
|
||||
@subsection Fonts
|
||||
@section Fonts
|
||||
|
||||
@cindex fonts
|
||||
For fonts that are in general not installed by a user for typesetting
|
||||
|
@ -24652,7 +24631,7 @@ fonts.
|
|||
|
||||
|
||||
@node Bootstrapping
|
||||
@section Bootstrapping
|
||||
@chapter Bootstrapping
|
||||
|
||||
@c Adapted from the ELS 2013 paper.
|
||||
|
||||
|
@ -24681,7 +24660,7 @@ Binutils, libc, and the other packages mentioned above---the
|
|||
These bootstrap binaries are ``taken for granted'', though we can also
|
||||
re-create them if needed (more on that later).
|
||||
|
||||
@unnumberedsubsec Preparing to Use the Bootstrap Binaries
|
||||
@unnumberedsec Preparing to Use the Bootstrap Binaries
|
||||
|
||||
@c As of Emacs 24.3, Info-mode displays the image, but since it's a
|
||||
@c large image, it's hard to scroll. Oh well.
|
||||
|
@ -24732,7 +24711,7 @@ derivations @code{gcc-bootstrap-0.drv}, @code{glibc-bootstrap-0.drv},
|
|||
etc., at which point we have a working C tool chain.
|
||||
|
||||
|
||||
@unnumberedsubsec Building the Build Tools
|
||||
@unnumberedsec Building the Build Tools
|
||||
|
||||
Bootstrapping is complete when we have a full tool chain that does not
|
||||
depend on the pre-built bootstrap tools discussed above. This
|
||||
|
@ -24787,7 +24766,7 @@ implicitly used by any package that uses @code{gnu-build-system}
|
|||
(@pxref{Build Systems, @code{gnu-build-system}}).
|
||||
|
||||
|
||||
@unnumberedsubsec Building the Bootstrap Binaries
|
||||
@unnumberedsec Building the Bootstrap Binaries
|
||||
|
||||
@cindex bootstrap binaries
|
||||
Because the final tool chain does not depend on the bootstrap binaries,
|
||||
|
@ -24813,7 +24792,7 @@ unknown, but if you would like to investigate further (and have
|
|||
significant computational and storage resources to do so), then let us
|
||||
know.
|
||||
|
||||
@unnumberedsubsec Reducing the Set of Bootstrap Binaries
|
||||
@unnumberedsec Reducing the Set of Bootstrap Binaries
|
||||
|
||||
Our bootstrap binaries currently include GCC, Guile, etc. That's a lot
|
||||
of binary code! Why is that a problem? It's a problem because these
|
||||
|
@ -24836,7 +24815,7 @@ a simple and auditable assembler. Your help is welcome!
|
|||
|
||||
|
||||
@node Porting
|
||||
@section Porting to a New Platform
|
||||
@chapter Porting to a New Platform
|
||||
|
||||
As discussed above, the GNU distribution is self-contained, and
|
||||
self-containment is achieved by relying on pre-built ``bootstrap
|
||||
|
|
Loading…
Reference in a new issue