PostgreSQL: Automatiser avec la CLI
Démarrez PostgreSQL, récupérez ses identifiants et modifiez sa configuration par programmation avec la CLI Stackhero
👋 Bienvenue sur la documentation de Stackhero !
Stackhero propose une solution PostgreSQL cloud prête à l'emploi qui offre de nombreux avantages, notamment :
- Connexions et transferts de données illimités.
- Interface web PgAdmin incluse.
- De nombreux modules inclus comme
PostGIS,TimescaleDBetPgVector.- Mises à jour simplifiées en un clic.
- Performance optimale et sécurité renforcée grâce à une VM privée et dédiée.
Gagnez du temps et simplifiez-vous la vie : il suffit de 5 minutes pour essayer la solution PostgreSQL cloud hosting de Stackhero !
Ce guide vous montre comment créer un service PostgreSQL, lire ses identifiants et mettre à jour sa configuration entièrement en ligne de commande, sans aucun clic sur le tableau de bord. C'est idéal pour les scripts, les pipelines CI et les agents IA.
Nous allons utiliser la CLI Stackhero pour toutes les opérations. Si ce n'est pas déjà fait, vous pouvez l'installer avec :
curl -fsSL https://www.stackhero.io/install.sh | sh
1. Authentification
La façon la plus simple de commencer est de vous connecter via votre navigateur. Lorsque vous lancez la commande de connexion, la CLI ouvre une page web où vous pouvez approuver l'accès. Aucun mot de passe ni code 2FA n'est saisi dans la CLI elle-même.
stackhero login
Après la connexion, vos identifiants sont stockés localement et seront utilisés automatiquement par les prochaines commandes CLI.
Pour les environnements entièrement automatisés comme les scripts ou les pipelines CI, vous pouvez préférer un jeton d'accès non interactif. Vous pouvez en créer un depuis votre tableau de bord (Compte > Access tokens), puis l'exporter comme variable d'environnement. La CLI, ainsi que tout script que vous exécutez, le détectera automatiquement.
export STACKHERO_TOKEN="usr-xxxxxx:your-token"
2. Trouver le store de service PostgreSQL
Ensuite, vous voudrez lister les stores de service PostgreSQL disponibles sur votre compte. La CLI accepte directement le nom du store (postgresql), il n'est donc pas nécessaire de rechercher ou copier des IDs.
# Liste les stores de service PostgreSQL (ajoutez --organization si vous en gérez plusieurs)
stackhero services-store-list --name="postgresql"
Vous pouvez utiliser le nom du store postgresql dans les commandes suivantes, ou choisir un ID spécifique svs-xxxxxx de la liste si vous le souhaitez.
3. Choisir une taille d'instance et une région
# Liste les tailles d'instance pour votre store de service (utilisez la colonne NAME pour --instance)
stackhero instances-store-list --service-store=postgresql
# Liste les régions disponibles (noms comme "europe")
stackhero regions-list
4. Créer le service
Voici un exemple de script qui crée un stack, ajoute votre service PostgreSQL dessus, attend son démarrage, récupère sa configuration (y compris les identifiants générés), puis applique une nouvelle configuration.
#!/bin/bash
set -e
export STACKHERO_TOKEN="usr-xxxxxx:your-token"
serviceStore="postgresql" # Le nom du store de service PostgreSQL (voir étape 2)
instance="..." # Une taille d'instance de l'étape 3
region="europe" # Un nom de région de l'étape 3
# Créez un stack pour votre service (utilise votre organisation par défaut ; ajoutez --organization si besoin)
stackId=$(stackhero --format=script stack-create \
--name="My PostgreSQL stack")
echo "Stack créé : ${stackId}"
# Ajoutez PostgreSQL au stack (les noms sont résolus automatiquement)
serviceId=$(stackhero --format=script service-add \
--stack="My PostgreSQL stack" \
--service-store="${serviceStore}" \
--instance="${instance}" \
--region="${region}")
echo "Service ajouté : postgresql"
# Attendez que le service soit totalement opérationnel (cela peut prendre quelques minutes)
stackhero service-wait-for --service="postgresql"
# Récupérez la configuration du service, y compris les identifiants générés
stackhero service-configuration-get --service="postgresql" --format=json
5. Récupérer les identifiants
La commande service-configuration-get retourne la configuration complète de votre service, incluant les mots de passe générés automatiquement et les informations de connexion. Le résultat est au format JSON, ce qui facilite son utilisation dans des scripts et automatisations.
stackhero service-configuration-get --service=svc-xxxxxx --format=json
6. Modifier la configuration
Vous pouvez consulter un exemple de schéma de configuration puis appliquer vos propres paramètres. Lors de la mise à jour de la configuration, le service peut redémarrer pour appliquer les changements.
# Affichez le schéma de configuration et un exemple pour votre service
stackhero service-configuration-example --service=svc-xxxxxx
# Appliquez une configuration personnalisée (le service redémarre si nécessaire)
stackhero service-configuration-set \
--service=svc-xxxxxx \
--configuration='{ "...": "..." }'
# Attendez que la nouvelle configuration soit appliquée
stackhero service-wait-for --service=svc-xxxxxx
Et voilà. Vous avez maintenant vu tout le cycle de vie : démarrer un service, récupérer ses identifiants et le reconfigurer, le tout de façon scriptable et automatisée. Pour aller plus loin, consultez la documentation complète de la CLI, qui couvre également l'authentification non interactive STACKHERO_TOKEN présentée ici.