Suivant: Dérivations, Précédent: Chemins de recherche, Monter: Interface de programmation [Table des matières][Index]
Conceptuellement, le dépôt est l’endroit où les dérivations qui ont bien été construites sont stockées — par défaut, /gnu/store. Les sous-répertoires dans le dépôt s’appellent des éléments du dépôt ou parfois des chemins du dépôt. Le dépôt a une base de données associée qui contient des informations comme les chemins du dépôt auxquels se réfèrent chaque chemin du dépôt et la liste des éléments du dépôt valides — les résultats d’une construction réussie. Cette base de données se trouve dans localstatedir/guix/db où localstatedir est le répertoire d’états spécifié via --localstatedir à la configuration, typiquement /var.
C’est toujours le démon qui accède au dépôt pour le compte de ses
clients (voir Invoquer guix-daemon
). Pour manipuler le dépôt, les
clients se connectent au démon par un socket Unix-domain, envoient une
requête dessus et lisent le résultat — ce sont des appels de procédures
distantes, ou RPC.
Remarque : Les utilisateurs ne doivent jamais modifier les fichiers dans /gnu/store directement. Cela entraînerait des incohérences et casserait l’hypothèse d’immutabilité du modèle fonctionnel de Guix (voir Introduction).
Voir
guix gc --verify
, pour des informations sur la manière de vérifier l’intégrité du dépôt et d’essayer de réparer des modifications accidentelles.
Le module (guix store)
fournit des procédures pour se connecter au
démon et pour effectuer des RPCs. Elles sont décrites plus bas. Par
défaut, open-connection
, et donc toutes les commandes guix
se connectent au démon local ou à l’URI spécifiée par la variable
d’environnement GUIX_DAEMON_SOCKET
.
Lorsqu’elle est initialisée, la valeur de cette variable devrait être un nom de fichier ou une URI qui désigne l’extrémité du démon. Lorsque c’est un nom de fichier, il dénote un socket Unix-domain où se connecter. En plus des noms de fichiers, les schémas d’URI supportés sont :
file
unix
Pour les sockets Unix-domain. file:///var/guix/daemon-socket/socket
est équivalent à /var/guix/daemon-socket/socket.
guix
¶Ces URI dénotent des connexions par TCP/IP, sans chiffrement ni authentification de l’hôte distant. L’URI doit spécifier le nom d’hôte et éventuellement un numéro de port (par défaut 44146) :
guix://master.guix.example.org:1234
Ce paramétrage est adapté aux réseaux locaux, comme dans le cas de grappes
de serveurs, où seuls des noms de confiance peuvent se connecter au démon de
construction sur master.guix.example.org
.
L’option --listen
de guix-daemon
peut être utilisé pour lui
dire d’écouter les connexions TCP (voir --listen).
ssh
¶Ces URI vous permettent de vous connecter à un démon distant via SSH.
Cette fonctionnalité nécessite Guile-SSH (voir Prérequis) et un
binaire guile
fonctionnel dans PATH
sur la machine de
destination. Elle prend en charge l’authentification par clé publique et
GSSAPI. Une URL typique pourrait ressembler à ceci :
ssh://charlie@guix.example.org:22
Comme pour guix copy
, les fichiers de configuration du client
OpenSSH sont pris en compte (voir Invoquer guix copy
).
Des schémas d’URI supplémentaires pourraient être supportés dans le futur.
Remarque : La capacité de se connecter à un démon de construction distant est considéré comme expérimental à la version ee64bcf. Contactez-nous pour partager vos problèmes ou des suggestions que vous pourriez avoir (voir Contribuer).
Se connecte au démon à travers le socket Unix-domain à uri (une chaîne de caractères). Lorsque reserve-space? est vrai, cela demande de réserver un peu de place supplémentaire sur le système de fichiers pour que le ramasse-miette puisse opérer au cas où le disque serait plein. Renvoie un objet serveur.
file prend par défaut la valeur %default-socket-path
, qui est
l’emplacement normal compte tenu des options qui ont été passées à
configure
.
Ferme la connexion au serveur.
Cette variable est liée à un paramètre SRFI-39, qui se réfère au port où les journaux de construction et d’erreur envoyés par le démon devraient être écrits.
Les procédures qui font des RPC prennent toutes un objet serveur comme premier argument.
Renvoie #t
lorsque path désigne un élément valide du dépôt et
#f
sinon (un élément invalide peut exister sur le disque mais être
toujours invalide, par exemple parce qu’il est le résultat d’une
construction avortée ou échouée).
Une condition &store-protocol-error
est levée si path n’est pas
préfixée par le répertoire du dépôt (/gnu/store).
Ajoute text dans le fichier name dans le dépôt et renvoie son chemin. references est la liste des chemins du dépôt référencés par le chemin du dépôt qui en résulte.
Construit derivations, une liste d’objets <derivation>
, de noms
de fichiers .drv, ou de paires dérivation/sortie, en utilisant le
mode—(build-mode normal)
spécifié par défaut.
Remarque que le module (guix monads)
fournit une monade ainsi que des
version monadiques des procédures précédentes, avec le but de rendre plus
facile de travailler avec le code qui accède au dépôt (voir La monade du dépôt).
Cette section est actuellement incomplète.
Suivant: Dérivations, Précédent: Chemins de recherche, Monter: Interface de programmation [Table des matières][Index]