Stocker des packages Apt dans Artifact Registry
Ce guide de démarrage rapide vous explique comment configurer un dépôt Apt Artifact Registry privé, y ajouter un package Debian et l'installer sur une VM Compute Engine exécutant un système d'exploitation basé sur Debian.
Pour en savoir plus sur la gestion des packages Debian, consultez Utiliser des packages Debian.
Avant de commencer
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Artifact Registry API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles. -
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
Roles required to select or create a project
- Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
-
Create a project: To create a project, you need the Project Creator role
(
roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
-
Verify that billing is enabled for your Google Cloud project.
-
Enable the Artifact Registry API.
Roles required to enable APIs
To enable APIs, you need the Service Usage Admin IAM role (
roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles. Accédez à la console Google Cloud .
Dans la console Google Cloud , cliquez sur Activer Cloud Shell
.Créez le dépôt :
Console
Ouvrez la page Dépôts dans la console Google Cloud .
Cliquez sur Créer un dépôt.
Spécifiez
quickstart-apt-repocomme nom de dépôt.Sélectionnez le format Apt.
Sous Type d'emplacement, sélectionnez Région, puis l'emplacement
us-west1.Cliquez sur Créer.
Le dépôt est ajouté à la liste des dépôts.
gcloud
Dans Cloud Shell, exécutez la commande suivante pour créer un dépôt Apt dans le projet actuel nommé
quickstart-apt-repoà l'emplacementus-west1.gcloud artifacts repositories create quickstart-apt-repo \ --repository-format=apt \ --location=us-west1 \ --description="Apt repository"Exécutez la commande suivante pour vérifier que votre dépôt a bien été créé :
gcloud artifacts repositories list
Accédez à la page des instances de VM.
Sur la ligne correspondant à votre VM, cliquez sur SSH. Une nouvelle fenêtre s'ouvre avec une session de terminal sur la VM.
Exécutez
gcloud initpour initialiser Google Cloud CLI sur votre VM.Mettre à jour Apt :
sudo apt updateTéléchargez le package curl avec la commande suivante :
apt download curlApt télécharge la dernière version du package disponible dans les dépôts Apt que vous avez configurés.
Get:1 file:/etc/apt/mirrors/debian.list Mirrorlist [30 B] Get:2 https://deb.debian.org/debian bookworm/main amd64 curl amd64 7.88.1-10+deb12u14 [316 kB] Fetched 316 kB in 0s (3078 kB/s)Exécutez
lspour obtenir le nom de fichier du package curl. Le nom du fichier est semblable àcurl_7.88.1-10+deb12u14_amd64.deb.Pour simplifier les commandes
gcloud, définissez le dépôt par défaut surquickstart-apt-repoet l'emplacement par défaut surus-west1. Une fois les valeurs définies, vous n'avez pas besoin de les spécifier dans les commandesgcloudnécessitant un dépôt ou un emplacement.Pour définir le dépôt, exécutez la commande suivante :
gcloud config set artifacts/repository quickstart-apt-repoPour définir l'emplacement, exécutez la commande suivante :
gcloud config set artifacts/location us-west1Pour plus d'informations sur ces commandes, consultez la documentation gcloud config set.
Exécutez
gcloud artifacts apt uploadpour importer le package dans le dépôt :gcloud artifacts apt upload quickstart-apt-repo \ --source=FILE_NAMERemplacez
FILE_NAMEpar le chemin d'accès au package curl.Ouvrez la page Dépôts dans la console Google Cloud .
Dans la liste des dépôts, cliquez sur le dépôt quickstart-apt-repo.
La page Packages répertorie les packages du dépôt.
Installez le programme d'assistance pour les informations d'identification Apt sur la VM pour permettre à Apt d'effectuer l'authentification :
sudo apt install apt-transport-artifact-registryConfigurez votre VM pour accéder aux packages Artifact Registry :
echo 'deb ar+https://us-west1-apt.pkg.dev/projects/PROJECT quickstart-apt-repo main' | sudo tee -a /etc/apt/sources.list.d/artifact-registry.listRemplacez PROJECT par l'ID de votre projet Google Cloud.
Mettez à jour la liste des packages disponibles :
sudo apt updateInstallez le package à partir de votre dépôt.
sudo apt install curl/quickstart-apt-repoLes informations d'installation renvoyées ressemblent à l'exemple suivant :
Reading package lists... Done Building dependency tree... Done Reading state information... Done Selected version '7.88.1-10+deb12u14' (quickstart-apt-repo:quickstart-apt-repo, Debian:12.12/oldstable [amd64]) for 'curl' The following additional packages will be installed: libcurl3-gnutls libcurl4 The following packages will be upgraded: curl libcurl3-gnutls libcurl4 3 upgraded, 0 newly installed, 0 to remove and 77 not upgraded. Need to get 1093 kB of archives. After this operation, 0 B of additional disk space will be used. Do you want to continue? [Y/n] y Get:1 file:/etc/apt/mirrors/debian.list Mirrorlist [30 B] Get:2 https://deb.debian.org/debian bookworm/main amd64 libcurl4 amd64 7.88.1-10+deb12u14 [392 kB] Get:3 https://deb.debian.org/debian bookworm/main amd64 libcurl3-gnutls amd64 7.88.1-10+deb12u14 [386 kB] Get:4 ar+https://us-west1-apt.pkg.dev/projects/PROJECT quickstart-apt-repo/main amd64 curl amd64 7.88.1-10+deb12u14 [316 kB] Fetched 1093 kB in 1s (947 kB/s) Reading changelogs... Done (Reading database ... 72080 files and directories currently installed.) Preparing to unpack .../curl_7.88.1-10+deb12u14_amd64.deb ... Unpacking curl (7.88.1-10+deb12u14) over (7.88.1-10+deb12u12) ... Preparing to unpack .../libcurl4_7.88.1-10+deb12u14_amd64.deb ... Unpacking libcurl4:amd64 (7.88.1-10+deb12u14) over (7.88.1-10+deb12u12) ... Preparing to unpack .../libcurl3-gnutls_7.88.1-10+deb12u14_amd64.deb ... Unpacking libcurl3-gnutls:amd64 (7.88.1-10+deb12u14) over (7.88.1-10+deb12u12) ... Setting up libcurl3-gnutls:amd64 (7.88.1-10+deb12u14) ... Setting up libcurl4:amd64 (7.88.1-10+deb12u14) ... Setting up curl (7.88.1-10+deb12u14) ... Processing triggers for man-db (2.11.2-2) ... Processing triggers for libc-bin (2.36-9+deb12u10) ...
Ouvrez la page Dépôts dans la console Google Cloud .
Dans la liste des dépôts, sélectionnez le dépôt quickstart-apt-repo.
Cliquez sur Supprimer.
Pour supprimer le dépôt
quickstart-apt-repo, exécutez la commande suivante :gcloud artifacts repositories delete quickstart-apt-repoSi vous souhaitez supprimer le dépôt par défaut et les paramètres d'emplacement que vous avez définis pour la configuration
gcloudactive, exécutez les commandes suivantes :gcloud config unset artifacts/repository gcloud config unset artifacts/location- Découvrez comment utiliser les packages Deb.
- Découvrez le DevOps et le programme de recherche DevOps.
Lancer Cloud Shell
Cloud Shell est préinstallé avec la Google Cloud CLI. gcloud CLI fournit l'interface de ligne de commande principale pour Google Cloud.
Lancez Cloud Shell :
Une session Cloud Shell s'ouvre dans un cadre situé en bas de la console.
Vous utiliserez ce shell pour exécuter les commandes gcloud afin de créer une VM et un dépôt.
Créer un dépôt
Créez le dépôt pour vos artefacts.
Vous pouvez désormais ajouter un package au dépôt. Cloud Shell utilise une image Ubuntu créée par Google, et non Debian. Pour gérer les packages Debian dans le dépôt, vous utiliserez une VM qui utilise une image Debian OS.
Créer une VM
Créez une instance de VM Compute Engine sur laquelle vous installerez le package d'exemple.
Dans Cloud Shell, exécutez la commande suivante pour créer une instance de VM nommée quickstart-apt-vm :
gcloud compute instances create quickstart-apt-vm \
--image-family=debian-12 \
--image-project=debian-cloud \
--scopes=cloud-platform
Par défaut, la VM ne dispose pas des niveaux d'accès requis pour fonctionner avec le dépôt. L'indicateur --scopes définit le niveau d'accès de la VM sur cloud-platform.
Ajouter un package au dépôt
Vous pouvez importer un package dans un dépôt à l'aide de Google Cloud CLI ou importer un package stocké dans Cloud Storage. Si vous créez des packages à l'aide de Cloud Build, la compilation peut stocker les packages dans Cloud Storage pour que vous puissiez les importer.Pour ce guide de démarrage rapide, vous allez importer un exemple de fichier à l'aide de la commande gcloud artifacts apt upload.
Afficher le package dans le dépôt
Vérifiez que votre package a bien été ajouté au dépôt.
Console
gcloud
Pour lister les packages dans le dépôt quickstart-apt-repo, exécutez la commande suivante :
gcloud artifacts packages list
Pour afficher les versions d'un package dans quickstart-apt-repo, exécutez la commande suivante :
gcloud artifacts versions list --package=apt-dpkg-ref
Configurer le gestionnaire de packages
Pour installer un package sur la VM, ajoutez le dépôt que vous avez créé au fichier de configuration Apt qui définit les dépôts de packages.
Installer le package
Installez le package que vous avez ajouté au dépôt.
Effectuer un nettoyage
Pour éviter que les ressources utilisées dans cette démonstration soient facturées sur votre compte Google Cloud , procédez comme suit :
Avant de supprimer le dépôt, assurez-vous que tous les packages que vous souhaitez conserver sont disponibles à un autre emplacement.
Pour supprimer le dépôt :
Console
gcloud
Pour supprimer la VM que vous avez créée, exécutez la commande suivante :
gcloud compute instances delete quickstart-apt-vm