Si vous avez Machine Learning Services installé sur SQL Server 2019, les extensions de langage sont déjà installées et vous pouvez ignorer cette étape.
Suivez les étapes ci-dessous pour installer les Extensions de langage SQL Server, qui sont utilisées pour le runtime personnalisé Python.
Démarrez l’Assistant Installation de SQL Server 2019.
Sous l’onglet Installation, sélectionnez Nouvelle installation autonome de SQL Server ou ajout de fonctionnalités à une installation existante.
Dans la page Sélection de fonctionnalités , sélectionnez les options suivantes :
Services Moteur de base de données
Pour utiliser les extensions de langage avec SQL Server, vous devez installer une instance du moteur de base de données. Vous pouvez utiliser une instance nouvelle ou existante.
Machine Learning Services et extensions de langage
Sélectionnez Machine Learning Services et extensions de langage. Ne sélectionnez pas Python, car vous installerez le runtime python personnalisé ultérieurement.
Dans la page Prêt pour l’installation, vérifiez que ces sélections sont incluses, puis choisissez Installer.
Services Moteur de base de données
Machine Learning Services et extensions de langage
Une fois l’installation terminée, redémarrez la machine si vous y êtes invité.
L’extension de langage Python utilisée pour le runtime python personnalisé prend actuellement en charge Python 3.7 uniquement. Si vous souhaitez utiliser une autre version de Python, suivez les instructions du référentiel GitHub de l’extension de langage Python pour modifier et régénérer l’extension.
Téléchargez Python 3.7 pour Windows et exécutez le programme d’installation sur le serveur.
Sélectionnez Add Python 3.7 to PATH (Ajouter Python 3.7 à PATH), puis Customize installation (Personnaliser l’installation).
Sous Optional Features (Fonctionnalités facultatives), laissez les valeurs par défaut et sélectionnez Next (Suivant).
Sélectionnez Install for all users (Installer pour tous les utilisateurs) et notez l’emplacement de l’installation.
Sélectionnez Installer.
Installer pandas
Installez le package pandas pour Python à partir d’une invite de commandes avec élévation de privilèges (Exécuter en tant qu’administrateur) :
python.exe -m pip install pandas
Accordez l’accès au dossier Python
Exécutez les commandes icacls suivantes à partir d’une nouvelle invite de commandes avec élévation de privilèges pour accorder l’accès READ & EXECUTE à l’emplacement d’installation de Python au service SQL Server Launchpad et au SID S-1-15-2-1 (ALL_APPLICATION_PACKAGES).
Les exemples ci-dessous utilisent l’emplacement d’installation de Python suivant : C:\Program Files\Python37. Si votre emplacement est différent, modifiez-le dans la commande.
Accordez des autorisations pour le nom d’utilisateur du service SQL Server Launchpad.
Pour une instance nommée, la commande est icacls "C:\Program Files\Python37" /grant "NT Service\MSSQLLAUNCHPAD$SQL01":(OI)(CI)RX /T pour une instance appelée SQL01.
La commande précédente accorde des autorisations au SID de l’ordinateur S-1-15-2-1, ce qui équivaut à ALL APPLICATION PACKAGES sur une version en anglais de Windows. Vous pouvez également utiliser icacls "C:\Program Files\Python37" /grant "ALL APPLICATION PACKAGES":(OI)(CI)RX /T sur une version en anglais de Windows.
Redémarrer SQL Server Launchpad
Procédez comme suit pour redémarrer le service SQL Server Launchpad.
Sous Services SQL Server, cliquez avec le bouton droit sur SQL Server Launchpad (MSSQLSERVER) et sélectionnez Redémarrer. Si vous utilisez une instance nommée, le nom de l’instance est indiqué à la place de (MSSQLSERVER) .
Inscrivez l’extension de langage
Procédez comme suit pour télécharger et inscrire l’extension de langage Python, qui est utilisée pour le runtime personnalisé Python.
Vous pouvez également utiliser la version debug (python-lang-extension-windows-debug.zip) dans un environnement de développement ou de test. La version debug fournit des informations de journalisation détaillées pour examiner les erreurs, et n’est pas recommandée pour les environnements de production.
Utilisez Azure Data Studio pour vous connecter à votre instance SQL Server et exécutez la commande T-SQL suivante pour inscrire l’extension de langage Python avec CREATE EXTERNAL LANGUAGE.
Modifiez le chemin dans cette instruction pour refléter l’emplacement du fichier zip de l’extension de langage téléchargé (python-lang-extension-windows-release.zip) et l’emplacement de votre installation de Python (C:\\Program Files\\Python37).
CREATE EXTERNAL LANGUAGE [myPython]
FROM (CONTENT = N'C:\path\to\python-lang-extension-windows-release.zip',
FILE_NAME = 'pythonextension.dll',
ENVIRONMENT_VARIABLES = N'{"PYTHONHOME": "C:\\Program Files\\Python37"}');
GO
Exécutez l’instruction pour chaque base de données dans laquelle vous souhaitez utiliser l’extension de langage Python.
Notes
Python est un mot réservé et ne peut pas être utilisé comme nom pour un nouveau nom de langue externe. Utilisez un autre nom à la place. Par exemple, l’instruction ci-dessus utilise myPython.
Prérequis
Avant d’installer un runtime Python personnalisé, installez ce qui suit :
Installez SQL Server 2019 pour Linux. Vous pouvez installer SQL Server sur Red Hat Enterprise Linux (RHEL), SUSE Linux Enterprise Server (SLES) et Ubuntu. Pour plus d’informations, voir Conseils d’installation pour SQL Server sur Linux.
Effectuez une mise à niveau vers la mise à jour cumulative (CU) 3 ou version ultérieure pour SQL Server 2019. Effectuez les étapes suivantes :
Si vous avez Machine Learning Services installé sur SQL Server 2019, le package mssql-server-extensibility pour les extensions de langage est déjà installée et vous pouvez ignorer cette étape.
Exécutez les commandes ci-dessous pour installer les extensions de langage SQL Server sur Ubuntu Linux, qui sont utilisées pour le runtime Python personnalisé.
Si possible, exécutez cette commande pour actualiser les packages sur le système avant l’installation.
# Install as root or sudo
sudo apt-get update
Ubuntu n’a peut-être pas l’option de transport https apt. Pour l’installer, exécutez la commande suivante.
# Install as root or sudo
apt-get install apt-transport-https
Installez mssql-server-extensibility à l’aide de cette commande.
# Install as root or sudo
sudo apt-get install mssql-server-extensibility
Installez Python 3.7 et pandas
L’extension de langage Python utilisée pour le runtime Python personnalisé prend uniquement en charge Python 3.7 pour l’instant. Si vous souhaitez utiliser une autre version de Python, suivez les instructions du référentiel GitHub de l’extension de langage Python pour modifier et régénérer l’extension.
Exécutez les commandes ci-dessous pour installer Python 3.7.
# Install python3.7 and the corresponding library:
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt-get update
sudo apt-get install python3.7 python3-pip libpython3.7
Exécutez la commande ci-dessous pour installer le package pandas.
Si vous avez installé Python 3.7 à l’emplacement par défaut de /usr/lib/python3.7, vous pouvez ignorer cette section et passer à la section Inscrire l’extension de langage.
Si vous avez créé votre propre version de Python 3.7, utilisez les commandes suivantes pour faire savoir à SQL Server votre installation personnalisée.
Ajouter une variable d’environnement
Modifiez d’abord le service mssql-launchpad pour ajouter la variable d’environnement PYTHONHOME au fichier /etc/systemd/system/mssql-launchpadd.service.d/override.conf
Ouvrez le fichier avec systemctl
sudo systemctl edit mssql-launchpadd
Insérez le texte suivant dans le fichier /etc/systemd/system/mssql-launchpadd.service.d/override.conf qui s’ouvre. Définissez la valeur de PYTHONHOME sur le chemin d’installation de Python personnalisé.
[Service]
Environment="PYTHONHOME=<path to the python3.7 lib>"
Enregistrez le fichier et fermez l’éditeur.
Ensuite, assurez-vous que libpython3.7m.so.1.0 peut être chargé.
Créez un fichier custom-python.conf dans /etc/ld.so.conf.d.
sudo vi /etc/ld.so.conf.d/custom-python.conf
Dans le fichier qui s’ouvre, ajoutez le chemin d’accès à libpython3.7m.so.1.0 de l’installation Python personnalisée.
<path to the python3.7 lib>
Enregistrez le nouveau fichier et fermez l’éditeur.
Exécutez ldconfig et vérifiez que libpython3.7m.so.1.0 peut être chargé en exécutant la commande suivante et en vérifiant que toutes les bibliothèques dépendantes peuvent être trouvées.
sudo ldconfig
ldd <path to the python3.7 lib>/libpython3.7m.so.1.0
Accordez l’accès au dossier Python
Définissez l’option datadirectories de la section extensibility du fichier /var/opt/mssql/mssql.conf avec l’installation personnalisée de Python.
sudo /opt/mssql/bin/mssql-conf set extensibility.datadirectories <path to python3.7>
Redémarrez mssql-launchpadd
Exécutez la commande suivante pour redémarrer mssql-launchpadd.
sudo systemctl restart mssql-launchpadd
Inscrivez l’extension de langage
Procédez comme suit pour télécharger et inscrire l’extension de langage Python, qui est utilisée pour le runtime personnalisé Python.
Vous pouvez également utiliser la version debug (python-lang-extension-linux-debug.zip) dans un environnement de développement ou de test. La version debug fournit des informations de journalisation détaillées pour examiner les erreurs, et n’est pas recommandée pour les environnements de production.
Utilisez Azure Data Studio pour vous connecter à votre instance SQL Server et exécutez la commande T-SQL suivante pour inscrire l’extension de langage Python avec CREATE EXTERNAL LANGUAGE.
Modifiez le chemin dans cette instruction pour refléter l’emplacement du fichier zip de l’extension de langage téléchargé (python-lang-extension-linux-release.zip).
CREATE EXTERNAL LANGUAGE [myPython]
FROM (CONTENT = N'/path/to/python-lang-extension-linux-release.zip', FILE_NAME = 'libPythonExtension.so.1.1');
GO
Exécutez l’instruction pour chaque base de données dans laquelle vous souhaitez utiliser l’extension de langage Python.
Notes
Python est un mot réservé et ne peut pas être utilisé comme nom pour un nouveau nom de langue externe. Utilisez un autre nom à la place. Par exemple, l’instruction ci-dessus utilise myPython.
Prérequis
Avant d’installer un runtime Python personnalisé, installez ce qui suit :
Installez SQL Server 2019 pour Linux. Vous pouvez installer SQL Server sur Red Hat Enterprise Linux (RHEL), SUSE Linux Enterprise Server (SLES) et Ubuntu. Pour plus d’informations, voir Conseils d’installation pour SQL Server sur Linux.
Effectuez une mise à niveau vers la mise à jour cumulative (CU) 3 ou version ultérieure pour SQL Server 2019. Effectuez les étapes suivantes :
Si vous avez Machine Learning Services installé sur SQL Server 2019, le package mssql-server-extensibility pour les extensions de langage est déjà installée et vous pouvez ignorer cette étape.
Exécutez la commande ci-dessous pour installer les extensions de langage SQL Server sur RHEL (Red Hat Enterprise Linux), qui sont utilisées pour le runtime Python personnalisé.
# Install as root or sudo
sudo yum install mssql-server-extensibility
Installez Python 3.7 et pandas
L’extension de langage Python utilisée pour le runtime Python personnalisé prend uniquement en charge Python 3.7 pour l’instant. Si vous souhaitez utiliser une autre version de Python, suivez les instructions du référentiel GitHub de l’extension de langage Python pour modifier et régénérer l’extension.
Exécutez les commandes ci-dessous pour installer Python 3.7.
# Install python3.7 and the corresponding library:
yum install gcc openssl-devel bzip2-devel libffi-devel zlib-devel
cd /usr/src
wget https://www.python.org/ftp/python/3.7.9/Python-3.7.9.tgz
tar xzf Python-3.7.9.tgz
cd Python-3.7.9
./configure --enable-optimizations --prefix=/usr
make altinstall
Exécutez la commande ci-dessous pour installer le package pandas.
Si vous avez installé Python 3.7 à l’emplacement par défaut de /usr/lib/python3.7, vous pouvez ignorer cette section et passer à la section Inscrire l’extension de langage.
Si vous avez créé votre propre version de Python 3.7, utilisez les commandes suivantes pour faire savoir à SQL Server votre installation personnalisée.
Ajouter une variable d’environnement
Modifiez d’abord le service mssql-launchpad pour ajouter la variable d’environnement PYTHONHOME au fichier /etc/systemd/system/mssql-launchpadd.service.d/override.conf
Ouvrez le fichier avec systemctl
sudo systemctl edit mssql-launchpadd
Insérez le texte suivant dans le fichier /etc/systemd/system/mssql-launchpadd.service.d/override.conf qui s’ouvre. Définissez la valeur de PYTHONHOME sur le chemin d’installation de Python personnalisé.
[Service]
Environment="PYTHONHOME=<path to the python3.7 lib>"
Enregistrez le fichier et fermez l’éditeur.
Ensuite, assurez-vous que libpython3.7m.so.1.0 peut être chargé.
Créez un fichier custom-python.conf dans /etc/ld.so.conf.d.
sudo vi /etc/ld.so.conf.d/custom-python.conf
Dans le fichier qui s’ouvre, ajoutez le chemin d’accès à libpython3.7m.so.1.0 de l’installation Python personnalisée.
<path to the python3.7 lib>
Enregistrez le nouveau fichier et fermez l’éditeur.
Exécutez ldconfig et vérifiez que libpython3.7m.so.1.0 peut être chargé en exécutant la commande suivante et en vérifiant que toutes les bibliothèques dépendantes peuvent être trouvées.
sudo ldconfig
ldd <path to the python3.7 lib>/libpython3.7m.so.1.0
Accordez l’accès au dossier Python
Définissez l’option datadirectories de la section extensibility du fichier /var/opt/mssql/mssql.conf avec l’installation personnalisée de Python.
sudo /opt/mssql/bin/mssql-conf set extensibility.datadirectories <path to python3.7>
Redémarrez mssql-launchpadd
Exécutez la commande suivante pour redémarrer mssql-launchpadd.
sudo systemctl restart mssql-launchpadd
Inscrivez l’extension de langage
Procédez comme suit pour télécharger et inscrire l’extension de langage Python, qui est utilisée pour le runtime personnalisé Python.
Vous pouvez également utiliser la version debug (python-lang-extension-linux-debug.zip) dans un environnement de développement ou de test. La version debug fournit des informations de journalisation détaillées pour examiner les erreurs, et n’est pas recommandée pour les environnements de production.
Utilisez Azure Data Studio pour vous connecter à votre instance SQL Server et exécutez la commande T-SQL suivante pour inscrire l’extension de langage Python avec CREATE EXTERNAL LANGUAGE.
Modifiez le chemin dans cette instruction pour refléter l’emplacement du fichier zip de l’extension de langage téléchargé (python-lang-extension-linux-release.zip).
CREATE EXTERNAL LANGUAGE [myPython]
FROM (CONTENT = N'/path/to/python-lang-extension-linux-release.zip', FILE_NAME = 'libPythonExtension.so.1.1');
GO
Exécutez l’instruction pour chaque base de données dans laquelle vous souhaitez utiliser l’extension de langage Python.
Notes
Python est un mot réservé et ne peut pas être utilisé comme nom pour un nouveau nom de langue externe. Utilisez un autre nom à la place. Par exemple, l’instruction ci-dessus utilise myPython.
Prérequis
Avant d’installer un runtime Python personnalisé, installez ce qui suit :
Installez SQL Server 2019 pour Linux. Vous pouvez installer SQL Server sur Red Hat Enterprise Linux (RHEL), SUSE Linux Enterprise Server (SLES) et Ubuntu. Pour plus d’informations, voir Conseils d’installation pour SQL Server sur Linux.
Effectuez une mise à niveau vers la mise à jour cumulative (CU) 3 ou version ultérieure pour SQL Server 2019. Effectuez les étapes suivantes :
Si vous avez Machine Learning Services installé sur SQL Server 2019, le package mssql-server-extensibility pour les extensions de langage est déjà installée et vous pouvez ignorer cette étape.
Exécutez la commande ci-dessous pour installer les extensions de langage SQL Server sur SLES (SUSE Linux Enterprise Server), qui sont utilisées pour le runtime Python personnalisé.
# Install as root or sudo
sudo zypper install mssql-server-extensibility
Installez Python 3.7 et pandas
L’extension de langage Python utilisée pour le runtime Python personnalisé prend uniquement en charge Python 3.7 pour l’instant. Si vous souhaitez utiliser une autre version de Python, suivez les instructions du référentiel GitHub de l’extension de langage Python pour modifier et régénérer l’extension.
Si vous avez installé Python 3.7 à l’emplacement par défaut de /usr/lib/python3.7, vous pouvez ignorer cette section et passer à la section Inscrire l’extension de langage.
Si vous avez créé votre propre version de Python 3.7, utilisez les commandes suivantes pour faire savoir à SQL Server votre installation personnalisée.
Ajouter une variable d’environnement
Modifiez d’abord le service mssql-launchpad pour ajouter la variable d’environnement PYTHONHOME au fichier /etc/systemd/system/mssql-launchpadd.service.d/override.conf
Ouvrez le fichier avec systemctl
sudo systemctl edit mssql-launchpadd
Insérez le texte suivant dans le fichier /etc/systemd/system/mssql-launchpadd.service.d/override.conf qui s’ouvre. Définissez la valeur de PYTHONHOME sur le chemin d’installation de Python personnalisé.
[Service]
Environment="PYTHONHOME=<path to the python3.7 lib>"
Enregistrez le fichier et fermez l’éditeur.
Ensuite, assurez-vous que libpython3.7m.so.1.0 peut être chargé.
Créez un fichier custom-python.conf dans /etc/ld.so.conf.d.
sudo vi /etc/ld.so.conf.d/custom-python.conf
Dans le fichier qui s’ouvre, ajoutez le chemin d’accès à libpython3.7m.so.1.0 de l’installation Python personnalisée.
<path to the python3.7 lib>
Enregistrez le nouveau fichier et fermez l’éditeur.
Exécutez ldconfig et vérifiez que libpython3.7m.so.1.0 peut être chargé en exécutant la commande suivante et en vérifiant que toutes les bibliothèques dépendantes peuvent être trouvées.
sudo ldconfig
ldd <path to the python3.7 lib>/libpython3.7m.so.1.0
Accordez l’accès au dossier Python
Définissez l’option datadirectories de la section extensibility du fichier /var/opt/mssql/mssql.conf avec l’installation personnalisée de Python.
sudo /opt/mssql/bin/mssql-conf set extensibility.datadirectories <path to python3.7>
Redémarrez mssql-launchpadd
Exécutez la commande suivante pour redémarrer mssql-launchpadd.
sudo systemctl restart mssql-launchpadd
Inscrivez l’extension de langage
Procédez comme suit pour télécharger et inscrire l’extension de langage Python, qui est utilisée pour le runtime personnalisé Python.
Vous pouvez également utiliser la version debug (python-lang-extension-linux-debug.zip) dans un environnement de développement ou de test. La version debug fournit des informations de journalisation détaillées pour examiner les erreurs, et n’est pas recommandée pour les environnements de production.
Utilisez Azure Data Studio pour vous connecter à votre instance SQL Server et exécutez la commande T-SQL suivante pour inscrire l’extension de langage Python avec CREATE EXTERNAL LANGUAGE.
Modifiez le chemin dans cette instruction pour refléter l’emplacement du fichier zip de l’extension de langage téléchargé (python-lang-extension-linux-release.zip).
CREATE EXTERNAL LANGUAGE [myPython]
FROM (CONTENT = N'/path/to/python-lang-extension-linux-release.zip', FILE_NAME = 'libPythonExtension.so.1.1');
GO
Exécutez l’instruction pour chaque base de données dans laquelle vous souhaitez utiliser l’extension de langage Python.
Notes
Python est un mot réservé et ne peut pas être utilisé comme nom pour un nouveau nom de langue externe. Utilisez un autre nom à la place. Par exemple, l’instruction ci-dessus utilise myPython.
Pour activer les scripts externes, utilisez Azure Data Studio pour exécuter l’instruction ci-dessous.
sp_configure 'external scripts enabled', 1;
RECONFIGURE WITH OVERRIDE;
Vérifier l'installation
Utilisez le script SQL suivant pour vérifier l’installation et les fonctionnalités du runtime personnalisé Python. Dans l’exemple de script ci-dessous, myPython est utilisé comme nom de langage car le nom de langage par défaut Python ne peut pas être fourni pour un runtime personnalisé.
Vous pouvez utiliser des Notebooks polyglottes pour créer et exécuter du code dans plusieurs langues dans un seul document. Ce module vous présente les Notebooks polyglottes et vous montre comment créer et exécuter du code dans plusieurs langues.