Déployer le fournisseur de ressources SQL Server sur Azure Stack Hub

Important

À partir de la build Azure Stack Hub 2108, les fournisseurs de ressources SQL et MySQL sont proposés aux abonnements auxquels l’accès a été accordé. Si vous souhaitez commencer à utiliser cette fonctionnalité ou si vous devez effectuer une mise à niveau à partir d’une version précédente, ouvrez un cas de support. Nos ingénieurs du support vous guideront tout au long du processus de déploiement ou de mise à niveau.

Utilisez le fournisseur de ressources SQL Server d'Azure Stack Hub pour exposer des bases de données SQL en tant que service d'Azure Stack Hub.

Le fournisseur de ressources SQL s’exécute en tant que service sur une machine virtuelle Windows Server 2016 Server Core.

Le fournisseur de ressources SQL s’exécute en tant que service sur un serveur Add-on RP Windows Server spécial.

Important

Seul le fournisseur de ressources doit créer des éléments sur les serveurs qui hébergent SQL ou MySQL. Les éléments créés sur un serveur hôte, et qui ne sont pas créés par le fournisseur de ressources, ne sont pas pris en charge. Ils peuvent entraîner un état incompatible.

Important

Le fournisseur de ressources SQL/MySQL V2.x utilise le mécanisme d’installation du fournisseur de ressources de déploiement (DRP), qui n’est pas pris en charge sur l’ASDK. Par conséquent, le fournisseur de ressources SQL/MySQL V2.x n’est pas pris en charge sur l’ASDK.

Conditions préalables requises

Si vous avez déjà installé un fournisseur de ressources, vous avez probablement rempli les prérequis suivants et pouvez ignorer cette section. Sinon, faites ce qui suit avant de continuer :

  1. Inscrivez votre instance Azure Stack Hub auprès d’Azure si ce n’est déjà fait. Cette étape est nécessaire, car vous allez vous connecter à la Place de marché et y télécharger des éléments à partir d’Azure.

  2. Si vous ne connaissez pas la fonctionnalité Gestion de la Place de marché du portail administrateur Azure Stack Hub, consultez Télécharger des éléments de la Place de marché Azure et les publier sur Azure Stack Hub. Cet article vous guide tout au long du processus de téléchargement des éléments à partir d’Azure vers la Place de marché Azure Stack Hub. Il couvre les deux scénarios, connecté et déconnecté. Si votre instance Azure Stack Hub est déconnectée ou partiellement connectée, d’autres prérequis doivent être respectés en vue de l’installation.

  3. Mettez à jour votre répertoire de base Microsoft Entra. À partir de la build 1910, une nouvelle application doit être inscrite dans votre abonné de répertoire de base. Cette application permet à Azure Stack Hub de créer et d’inscrire avec succès des fournisseurs de ressources plus récents (comme Event Hubs et d’autres) auprès de votre locataire Microsoft Entra. Il s’agit d’une action ponctuelle qui doit être effectuée après la mise à niveau vers la build 1910 ou une build plus récente. Si cette étape n’est pas effectuée, les installations du fournisseur de ressources échouent.

Prérequis pour le fournisseur de ressources SQL Server

  • Vous avez besoin d’un ordinateur et d’un compte pouvant accéder :

    • au portail administrateur Azure Stack Hub
    • au point de terminaison privilégié (nécessaire uniquement pour le déploiement du fournisseur de ressources SQL Server V1 ou la mise à niveau du fournisseur de ressources SQL Server V1 vers le fournisseur de ressources SQL Server V2)
    • au point de terminaison d’administration Azure Resource Manager, https://adminmanagement.region.<fqdn>, où <fqdn> représente votre nom de domaine complet
    • Internet, si votre Azure Stack Hub a été déployé pour utiliser Microsoft Entra ID comme fournisseur d’identité.
  • Téléchargez la version prise en charge du fichier binaire du fournisseur de ressources SQL en fonction du tableau de mappage de versions ci-dessous. Pour le fournisseur de ressources SQL V2, téléchargez l’élément de la Place de Marché vers Azure Stack Hub.

    Versions d’Azure Stack Hub prises en charge Version SQL RP Windows Server sur lequel le service RP s’exécute
    2206, 2301, 2306 SQL RP version 2.0.13.x Microsoft AzureStack Add-on RP Windows Server 1.2009.0
    2108, 2206 Fournisseur de ressources SQL version 2.0.6.x Microsoft AzureStack Add-on RP Windows Server 1.2009.0
  • Veillez à ce que la machine virtuelle Windows Server requise soit téléchargée sur la Place de Marché Azure Stack Hub. Téléchargez manuellement l’image en fonction de la table de mappage de versions ci-dessus, si nécessaire.

  • Vérifiez que les conditions préalables d’intégration du centre de données sont remplies :

    Configuration requise Informations de référence
    La redirection DNS conditionnelle est correctement définie. Intégration au centre de données Azure Stack Hub - DNS
    Les ports d’entrée pour les fournisseurs de ressources sont ouverts. Intégration au centre de données Azure Stack Hub - Ports et protocoles entrants
    Les objets du certificat PKI et SAN sont correctement définis. Prérequis PKI obligatoires pour le déploiement d'Azure Stack Hub
    Prérequis de certificat PaaS pour le déploiement d'Azure Stack Hub
  • Préparer le certificat. (Pour les installations de systèmes intégrés uniquement.)

    • Vous devez fournir le certificat PKI SQL Paas décrit dans la section facultative consacrée aux certificats PaaS de Exigences relatives à l'infrastructure de clés publiques pour le déploiement d'Azure Stack Hub. L’autre nom de l’objet doit respecter le modèle de nommage suivant : CN=*.dbadapter.<région>.<fqdn>, avec protection par mot de passe. Capture d’écran des packages téléchargés par la gestion de la place de marché.
    • Quand vous déployez le fournisseur de ressources SQL Server V1, placez le fichier .pfx à l’emplacement spécifié par le paramètre DependencyFilesLocalPath. Ne fournissez pas de certificat pour les systèmes ASDK.
    • Quand vous déployez le fournisseur de ressources SQL Server V2, préparez le certificat pour les étapes d’installation suivantes.

Scénario déconnecté

Quand vous déployez le fournisseur de ressources SQL Server V2 dans un scénario déconnecté, suivez les instructions Télécharger des éléments de la Place de Marché vers Azure Stack Hub pour télécharger l’élément du fournisseur de ressources SQL Server et l’élément Add-on RP Windows Server dans votre environnement Azure Stack Hub.

Quand vous déployez le fournisseur de ressources SQL Server V1 dans un scénario déconnecté, effectuez les étapes suivantes pour télécharger les modules PowerShell requis et inscrire le référentiel manuellement.

  1. Connectez-vous à un ordinateur disposant d'une connexion Internet et utilisez les scripts suivants pour télécharger les modules PowerShell.

    Import-Module -Name PowerShellGet -ErrorAction Stop
    Import-Module -Name PackageManagement -ErrorAction Stop
    
    # path to save the packages, c:\temp\azs1.6.0 as an example here
    $Path = "c:\temp\azs1.6.0"
    
  2. Selon la version du fournisseur de ressources que vous déployez, exécutez l’un des scripts.

    # for resource provider version >= 1.1.93.0
    Save-Package -ProviderName NuGet -Source https://www.powershellgallery.com/api/v2 -Name AzureRM -Path $Path -Force -RequiredVersion 2.5.0
    Save-Package -ProviderName NuGet -Source https://www.powershellgallery.com/api/v2 -Name AzureStack -Path $Path -Force -RequiredVersion 1.8.2
    
    # for resource provider version <= 1.1.47.0
    Save-Package -ProviderName NuGet -Source https://www.powershellgallery.com/api/v2 -Name AzureRM -Path $Path -Force -RequiredVersion 2.3.0
    Save-Package -ProviderName NuGet -Source https://www.powershellgallery.com/api/v2 -Name AzureStack -Path $Path -Force -RequiredVersion 1.6.0
    
  3. Copiez ensuite les packages téléchargés sur un périphérique USB.

  4. Connectez-vous à la station de travail déconnectée, puis copiez les packages du périphérique USB vers un emplacement sur la station de travail.

  5. Enregistrez cet emplacement en tant que référentiel local.

    # requires -Version 5
    # requires -RunAsAdministrator
    # requires -Module PowerShellGet
    # requires -Module PackageManagement
    
    $SourceLocation = "C:\temp\azs1.6.0"
    $RepoName = "azs1.6.0"
    
    Register-PSRepository -Name $RepoName -SourceLocation $SourceLocation -InstallationPolicy Trusted
    
    New-Item -Path $env:ProgramFiles -name "SqlMySqlPsh" -ItemType "Directory"
    

Déployer le fournisseur de ressources SQL V2

Si vous effectuez une mise à niveau à partir d’une version V1, reportez-vous au document Mettre à jour le fournisseur de ressources SQL Server.

Démarrer l’installation

  1. Si ce n'est déjà fait, connectez-vous au portail d'administration Azure Stack Hub, sélectionnez Gestion de la Place de marché sur la gauche, puis choisissez Fournisseurs de ressources.

  2. Une fois que le fournisseur de ressources SQL et les autres logiciels requis ont été téléchargés, la page Gestion de la Place de Marché affiche les packages « SQL Server resource provider » avec l’état « Non installé ». Il peut y avoir d’autres packages qui affichent l’état « Téléchargé ». Capture d’écran de la gestion de la Place de marché avant d’installer le rp.

  3. Sélectionnez la ligne que vous souhaitez installer. Une bannière bleue apparaît en haut de la page des packages d’installation de fournisseur de ressources SQL Server. Sélectionnez la bannière pour démarrer l’installation. Capture d’écran de l’installation de la gestion de la Place de marché.

Prérequis à installer

  1. Vous êtes ensuite dirigé vers la page d’installation. Sélectionnez Prérequis pour l’installation pour commencer le processus d’installation. Capture d’écran des prérequis d’installation de la gestion de la Place de marché.

  2. Attendez la fin de l’installation des prérequis. Vous devez voir une coche verte en regard de Prérequis pour l’installation avant de passer à l’étape suivante. Capture d’écran des conditions préalables d’installation de la gestion de la Place de marché réussies.

Préparer les secrets

  1. Sous l’étape 2. Préparer les secrets, sélectionnez Ajouter un certificat et le panneau Ajouter un certificat s’affiche. Capture d’écran de la gestion de la place de marché préparer les secrets.

  2. Sélectionnez le bouton Parcourir sur Ajouter un certificat, juste à droite du champ de nom de fichier du certificat. Sélectionnez le fichier de certificat .pfx que vous avez obtenu lors de la finalisation des prérequis.

  3. Entrez le mot de passe que vous avez fourni pour créer une chaîne sécurisée pour le certificat SSL du fournisseur de ressources SQL Server. Sélectionnez ensuite Ajouter. Capture d’écran de l’ajout d’un certificat de gestion de la Place de marché.

Installer le fournisseur de ressources

  1. Lorsque l’installation du certificat aboutit, vous devez voir une coche verte en regard de Préparer les secrets avant de passer à l’étape suivante. À présent, sélectionnez le bouton Installer en regard de 3 Installer le fournisseur de ressources. Capture d’écran de l’installation du rp de démarrage de la gestion de la Place de marché.

  2. La page suivante s’affiche, indiquant que le fournisseur de ressources SQL est en cours d’installation. Capture d’écran de l’installation du rp de gestion de la place de marché.

  3. Attendez la notification de fin de l’installation. Ce processus prend généralement une ou plusieurs heures, en fonction de votre type Azure Stack Hub. Capture d’écran de l’installation de rp de gestion de la place de marché en cours.

  4. Vérifiez que l’installation du fournisseur de ressources SQL Server a réussi en revenant à la page Gestion de la Place de Marché, Fournisseurs de ressources. L’état du fournisseur de ressources SQL Server doit être « Installé ». Capture d’écran du RP de gestion de la place de marché installé.

Déployer le fournisseur de ressources SQL V1

Une fois tous les prérequis respectés, exécutez l’auto-extracteur pour extraire le package d’installation téléchargé dans un répertoire temporaire. Exécutez le script DeploySqlProvider.ps1 à partir d’un ordinateur ayant accès au point de terminaison d’administration Azure Resource Manager d’Azure Stack Hub ainsi qu’au point de terminaison privilégié pour déployer le fournisseur de ressources SQL. Le script DeploySqlProvider.ps1 est extrait du binaire du fournisseur de ressources SQL que vous avez téléchargé pour votre version d'Azure Stack Hub.

Important

Avant de déployer le fournisseur de ressources, passez en revue les notes de publication pour en savoir plus sur les nouvelles fonctionnalités, les correctifs et les problèmes connus qui pourraient affecter votre déploiement.

Pour déployer le fournisseur de ressources SQL, ouvrez une nouvelle fenêtre PowerShell (pas PowerShell ISE) avec élévation de privilèges et basculez vers le répertoire où vous avez extrait les fichiers binaires du fournisseur de ressources SQL.

Important

Nous vous recommandons vivement d’utiliser Clear-AzureRmContext -Scope CurrentUser et Clear-AzureRmContext -Scope Process pour effacer le cache avant d’exécuter le script de déploiement ou de mise à jour.

Exécutez le script DeploySqlProvider.ps1, qui complète les tâches suivantes :

  • Chargement des certificats et autres artefacts sur un compte de stockage d'Azure Stack Hub.
  • Publication des packages de la galerie afin que vous puissiez déployer des bases de données SQL à l’aide de la galerie.
  • Publication d’un package de galerie pour déployer des serveurs d’hébergement.
  • Déploiement d’une machine virtuelle à l’aide de l’image Windows Server 2016 Core ou de l’image Microsoft AzureStack Add-on RP Windows Server que vous avez téléchargée, puis installation du fournisseur de ressources SQL.
  • Inscription d’un enregistrement DNS local mappé à la machine virtuelle de votre fournisseur de ressources.
  • Inscription de votre fournisseur de ressources auprès de l’Azure Resource Manager local pour le compte d’opérateur.

Notes

Lorsque le déploiement du fournisseur de ressources SQL démarre, le groupe de ressources system.local.sqladapter est créé. Il peut falloir jusqu’à 75 minutes pour terminer les déploiements requis dans ce groupe de ressources. Vous ne devez pas placer d’autres ressources dans le groupe de ressources system.local.sqladapter.

Paramètres de DeploySqlProvider.ps1

Vous pouvez spécifier les paramètres suivants à partir de la ligne de commande. Si vous ne le faites pas, ou si la validation d’un paramètre échoue, vous êtes invité à fournir les paramètres requis.

Nom du paramètre Description Commentaire ou valeur par défaut
CloudAdminCredential Informations d’identification de l’administrateur du cloud, nécessaires pour accéder au point de terminaison privilégié. Obligatoire
AzCredential Informations d'identification du compte administrateur de service Azure Stack Hub. Utilisez les mêmes informations d'identification que celles utilisées pour le déploiement d'Azure Stack Hub. Le script échoue si le compte que vous utilisez avec AzCredential nécessite une authentification multifacteur (MFA). Obligatoire
VMLocalCredential Informations d’identification du compte d’administrateur local de la machine virtuelle du fournisseur de ressources SQL. Obligatoire
PrivilegedEndpoint Adresse IP ou nom DNS du point de terminaison privilégié. Obligatoire
AzureEnvironment Environnement Azure du compte administrateur de service utilisé pour déployer Azure Stack Hub. Obligatoire uniquement pour les déploiements Microsoft Entra. Les noms d’environnement pris en charge sont AzureCloud, AzureUSGovernment ou, si vous utilisez un ID china Microsoft Entra, AzureChinaCloud. AzureCloud
DependencyFilesLocalPath Pour les systèmes intégrés uniquement, votre fichier de certificat .pfx doit être placé dans ce répertoire. Vous pouvez éventuellement copier un package MSU Windows Update ici. Facultatif (obligatoire pour les systèmes intégrés)
DefaultSSLCertificatePassword Mot de passe pour le certificat .pfx. Obligatoire
MaxRetryCount Nombre de fois où vous souhaitez réessayer chaque opération en cas d’échec. 2
RetryDuration Délai d’attente entre les tentatives, en secondes. 120
Désinstaller Supprime le fournisseur de ressources et toutes les ressources associées (voir les remarques ci-dessous). Non
DebugMode Empêche le nettoyage automatique en cas d’échec. Non

Déployer le fournisseur de ressources SQL à l’aide d’un script personnalisé

Si vous déployez la version 1.1.33.0 ou une version antérieure du fournisseur de ressources SQL, vous devez installer des versions spécifiques des modules Azure Stack Hub et AzureRm.Bootstrapper dans PowerShell.

Si vous déployez le fournisseur de ressources SQL version 1.1.47.0 ou ultérieure, le script de déploiement télécharge et installe automatiquement les modules PowerShell nécessaires sous C:\Program Files\SqlMySqlPsh.

# Install the AzureRM.Bootstrapper module, set the profile, and install the AzureStack module
# Note that this might not be the most currently available version of Azure Stack Hub PowerShell
Install-Module -Name AzureRm.BootStrapper -RequiredVersion 0.5.0 -Force
Use-AzureRmProfile -Profile 2018-03-01-hybrid -Force
Install-Module -Name AzureStack -RequiredVersion 1.6.0

Remarque

Dans un scénario déconnecté, vous devez télécharger les modules PowerShell requis et inscrire manuellement le référentiel en tant que condition préalable.

Pour éliminer toute configuration manuelle lors du déploiement du fournisseur de ressources, vous pouvez personnaliser le script suivant. Modifiez les informations de compte et les mots de passe par défaut en fonction des besoins de votre déploiement Azure Stack Hub.

# Use the NetBIOS name for the Azure Stack Hub domain. On the Azure Stack Hub SDK, the default is AzureStack but could have been changed at install time.
$domain = "AzureStack"

# For integrated systems, use the IP address of one of the ERCS VMs
$privilegedEndpoint = "AzS-ERCS01"

# Provide the Azure environment used for deploying Azure Stack Hub. Required only for Azure AD deployments. Supported values for the <environment name> parameter are AzureCloud, AzureChinaCloud, or AzureUSGovernment depending which Azure subscription you're using.
$AzureEnvironment = "<EnvironmentName>"

# Point to the directory where the resource provider installation files were extracted.
$tempDir = 'C:\TEMP\SQLRP'

# The service admin account can be Azure Active Directory or Active Directory Federation Services.
$serviceAdmin = "admin@mydomain.onmicrosoft.com"
$AdminPass = ConvertTo-SecureString 'P@ssw0rd1' -AsPlainText -Force
$AdminCreds = New-Object System.Management.Automation.PSCredential ($serviceAdmin, $AdminPass)

# Set credentials for the new resource provider VM local admin account.
$vmLocalAdminPass = ConvertTo-SecureString 'P@ssw0rd1' -AsPlainText -Force
$vmLocalAdminCreds = New-Object System.Management.Automation.PSCredential ("sqlrpadmin", $vmLocalAdminPass)

# Add the cloudadmin credential that's required for privileged endpoint access.
$CloudAdminPass = ConvertTo-SecureString 'P@ssw0rd1' -AsPlainText -Force
$CloudAdminCreds = New-Object System.Management.Automation.PSCredential ("$domain\cloudadmin", $CloudAdminPass)

# Change the following as appropriate.
$PfxPass = ConvertTo-SecureString 'P@ssw0rd1' -AsPlainText -Force

# For version 1.1.47.0 or later, the PowerShell modules used by the RP deployment are placed in C:\Program Files\SqlMySqlPsh
# The deployment script adds this path to the system $env:PSModulePath to ensure correct modules are used.
$rpModulePath = Join-Path -Path $env:ProgramFiles -ChildPath 'SqlMySqlPsh'
$env:PSModulePath = $env:PSModulePath + ";" + $rpModulePath 

# Change to the directory folder where you extracted the installation files. Don't provide a certificate on ASDK!
. $tempDir\DeploySQLProvider.ps1 `
    -AzCredential $AdminCreds `
    -VMLocalCredential $vmLocalAdminCreds `
    -CloudAdminCredential $cloudAdminCreds `
    -PrivilegedEndpoint $privilegedEndpoint `
    -AzureEnvironment $AzureEnvironment `
    -DefaultSSLCertificatePassword $PfxPass `
    -DependencyFilesLocalPath $tempDir\cert

Au terme du script d'installation du fournisseur de ressources, actualisez votre navigateur pour vous assurer que vous pouvez voir les dernières mises à jour, puis fermez la session PowerShell en cours.

Vérifier le déploiement de la V1 à l’aide du portail Azure Stack Hub

  1. Connectez-vous au portail d’administration en tant qu’administrateur de service.
  2. Sélectionnez Groupes de ressources.
  3. Sélectionnez le groupe de ressources system.<location>.sqladapter.
  4. La page de la vue d’ensemble du groupe de ressources ne doit pas indiquer que des déploiements ont échoué.
  5. Enfin, sélectionnez Machines virtuelles dans le portail administrateur pour vérifier que la machine virtuelle du fournisseur de ressources SQL a été correctement créée et est en cours d’exécution.

Configuration importante pour Microsoft Entra ID

Si votre Azure Stack Hub utilise Microsoft Entra ID comme fournisseur d’identité, vérifiez que la machine virtuelle qui a installé SQL Server fournisseur de ressources dispose d’une connectivité Internet sortante.

Si vous avez besoin de l’IP de la machine virtuelle sur laquelle est installé le fournisseur de ressources SQL Server (par exemple, pour l’ajouter à la liste d’autorisation de votre pare-feu), vous devez ouvrir un cas de support et demander à l’ingénieur du support de rendre l’abonnement du fournisseur de ressources SQL Server temporairement visible. Vous pouvez ensuite localiser la machine virtuelle dans l’abonnement et obtenir son IP.

Étapes suivantes

Ajouter des serveurs d’hébergement