Utiliser GitHub Actions pour se connecter à Azure SQL Database
S’applique à : Azure SQL Database
Familiarisez-vous avec GitHub Actions en utilisant un workflow pour déployer des mises à jour de base de données sur Azure SQL Database.
Prérequis
Ce dont vous avez besoin :
- Compte Azure avec un abonnement actif. Créez un compte gratuitement.
- Un dépôt GitHub avec un package dacpac (
Database.dacpac
). Si vous n’avez pas de compte GitHub, inscrivez-vous gratuitement. - Une base de données Azure SQL. Démarrage rapide : créer une base de données unique pour la base de données Azure SQL
- Un fichier .dacpac à importer dans votre base de données.
Vue d’ensemble du fichier de workflow
Un workflow GitHub Actions est défini par un fichier YAML (.yml) dans le chemin /.github/workflows/
de votre dépôt. Cette définition contient les étapes et les paramètres qui composent le workflow.
Le fichier comporte deux sections :
Section | Tâches |
---|---|
Authentification | 1.1. Générez les informations d’identification du déploiement. |
Déployer | 1. Déployez la base de données. |
Générer les informations d’identification du déploiement
Créez un principal de service à l’aide de la commande az ad sp create-for-rbac dans Azure CLI. Exécutez cette commande en utilisant Azure Cloud Shell dans le portail Azure ou en sélectionnant le bouton Essayer.
az ad sp create-for-rbac --name "myML" --role contributor \
--scopes /subscriptions/<subscription-id>/resourceGroups/<group-name> \
--json-auth
Le paramètre --json-auth
est disponible dans les versions d’Azure CLI >= 2.51.0. Les versions antérieures à celle-ci utilisent --sdk-auth
avec un avertissement de dépréciation.
Dans l’exemple ci-dessus, remplacez les espaces réservés par votre ID d’abonnement, le nom de votre groupe de ressources et le nom de votre application. La sortie correspond à un objet JSON avec les informations d’identification de l’attribution de rôle qui fournit l’accès à votre application App Service, similaire à ce qui suit. Copiez cet objet JSON pour une version ultérieure.
{
"clientId": "<GUID>",
"clientSecret": "<GUID>",
"subscriptionId": "<GUID>",
"tenantId": "<GUID>",
(...)
}
Copier la chaîne de connexion SQL
Dans le portail Azure, accédez à votre base de données Azure SQL Database, puis ouvrez Paramètres>Chaînes de connexion. Copiez la chaîne de connexion ADO.NET. Remplacez les valeurs d’espace réservé spécifiées pour your_database
et your_password
.
Vous définissez la chaîne de connexion comme un secret GitHub, AZURE_SQL_CONNECTION_STRING
.
Configurer les secrets GitHub
Dans GitHub, accédez à votre dépôt.
Sélectionnez Paramètres dans le volet de navigation.
Sélectionnez Sécurité > Secrets et variables > Actions.
Sélectionnez New repository secret (Nouveau secret de dépôt).
Collez l’intégralité de la sortie JSON de la commande Azure CLI dans le champ de valeur du secret. Nommez le secret
AZURE_CREDENTIALS
.Sélectionnez Ajouter un secret.
Ajouter le secret de la chaîne de connexion SQL
Dans GitHub, accédez à votre dépôt.
Sélectionnez Paramètres dans le volet de navigation.
Sélectionnez Sécurité > Secrets et variables > Actions.
Sélectionnez New repository secret (Nouveau secret de dépôt).
Collez votre chaîne de connexion SQL. Nommez le secret
AZURE_SQL_CONNECTION_STRING
.Sélectionnez Ajouter un secret.
Ajouter votre workflow
Accédez à Actions pour votre référentiel GitHub.
Sélectionnez Configurer vous-même un workflow.
Supprimez tous les éléments après la section
on:
de votre fichier de workflow. Par exemple, votre workflow restant peut ressembler à ce qui suit.name: SQL for GitHub Actions on: push: branches: [ main ] pull_request: branches: [ main ]
Renommez votre workflow
SQL for GitHub Actions
et ajoutez les actions d’extraction et de connexion. Ces actions extraient le code de votre site et vous authentifient auprès d’Azure en utilisant le secret GitHubAZURE_CREDENTIALS
que vous avez créé précédemment.name: SQL for GitHub Actions on: push: branches: [ main ] pull_request: branches: [ main ] jobs: build: runs-on: windows-latest steps: - uses: actions/checkout@v1 - uses: azure/login@v1 with: creds: ${{ secrets.AZURE_CREDENTIALS }}
Utilisez l’action Déployer d’Azure SQL pour vous connecter à votre instance SQL. Vous devez disposer d’un package dacpac (
Database.dacpac
) au niveau racine de votre dépôt. Utilisez le secret GitHubAZURE_SQL_CONNECTION_STRING
que vous avez créé précédemment.- uses: azure/sql-action@v2 with: connection-string: ${{ secrets.AZURE_SQL_CONNECTION_STRING }} path: './Database.dacpac' action: 'Publish'
Terminez votre workflow en ajoutant une action permettant de vous déconnecter d’Azure. Voici le workflow terminé. Le fichier apparaît dans le dossier
.github/workflows
de votre dépôt.name: SQL for GitHub Actions on: push: branches: [ main ] pull_request: branches: [ main ] jobs: build: runs-on: windows-latest steps: - uses: actions/checkout@v1 - uses: azure/login@v1 with: creds: ${{ secrets.AZURE_CREDENTIALS }} - uses: azure/sql-action@v2 with: connection-string: ${{ secrets.AZURE_SQL_CONNECTION_STRING }} path: './Database.dacpac' action: 'Publish' # Azure logout - name: logout run: | az logout
Vérifier votre déploiement
Accédez à Actions pour votre référentiel GitHub.
Ouvrez le premier résultat pour afficher les journaux détaillés de l’exécution de votre workflow.
Nettoyer les ressources
Quand votre dépôt et votre base de données Azure SQL ne sont plus nécessaires, nettoyez les ressources que vous avez déployées en supprimant le groupe de ressources et votre dépôt GitHub.