Remettre un instantané via FTP

Cette rubrique explique comment remettre un instantané via FTP dans SQL Server 2014 à l’aide de SQL Server Management Studio ou de Transact-SQL.

Limitations et restrictions

  • L'Agent d'instantané doit posséder des autorisations en écriture sur le répertoire spécifié et les Agents de distribution et de fusion des autorisations en lecture. Si vous utilisez des abonnements extraits, vous devez définir un répertoire partagé en tant que chemin d'accès UNC, par exemple \serveurftp\home\snapshots. Pour plus d’informations, consultez Sécuriser le dossier d’instantanés.

Prérequis

  • Pour transférer des fichiers d'instantanés via FTP (File Transfer Protocol), vous devez avant tout configurer un serveur FTP. Pour plus d'informations, consultez la documentation de Microsoft Internet Information Services (IIS).

Sécurité

Pour améliorer la sécurité, nous vous recommandons d'implémenter un réseau privé virtuel (VPN) lorsque vous utilisez la remise d'instantanés via FTP sur Internet. Pour plus d’informations, consultez Publier des données sur Internet à l’aide d’un réseau privé virtuel.

La méthode de sécurité conseillée consiste à désactiver l'accès anonyme au serveur FTP. L'Agent d'instantané doit posséder des autorisations en écriture sur le répertoire spécifié et les Agents de distribution et de fusion des autorisations en lecture. Si vous utilisez des abonnements extraits, vous devez définir un répertoire partagé en tant que chemin d'accès UNC, par exemple \serveurftp\home\snapshots. Pour plus d’informations, consultez Sécuriser le dossier d’instantanés.

Lorsque cela est possible, invitez les utilisateurs à saisir leurs informations d'identification au moment de l'exécution. Si vous stockez les informations d'identification dans un fichier de script, vous devez sécuriser ce fichier.

Utilisation de SQL Server Management Studio

Une fois le serveur FTP configuré, spécifiez le répertoire et les informations de sécurité pour ce serveur dans la boîte de dialogue Publication> des propriétés < de publication. Pour plus d'informations sur l'accès à cette boîte de dialogue, consultez Afficher et modifier les propriétés d’un serveur de publication.

Pour spécifier des informations FTP

  1. Dans la boîte de dialogue Propriétés de la publication - <Publication>, sélectionnez Autoriser les abonnés à télécharger instantané fichiers à l’aide de FTP à partir de l’une des pages suivantes :
    • La page Instantané FTP, pour les publications instantané et transactionnelles, et les publications de fusion pour les serveurs de publication exécutant des versions antérieures à Microsoft SQL Server 2005.
    • Page Capture instantanée FTP et Internet pour les publications de fusion à partir de serveurs de publication exécutant SQL Server 2005 ou une version ultérieure.
  2. Spécifiez des valeurs dans les zones de texte Nom du serveur FTP, Numéro de port, Chemin d'accès au dossier racine FTP, Nom de connexionet Mot de passe.
    Par exemple, si la racine du serveur FTP est \\ftpserver\home et que vous souhaitez que les instantanés soient stockés dans \\ftpserver\home\snapshots, spécifiez \snapshots\ftp pour la propriété Path du dossier racine FTP (la réplication ajoute « ftp » au chemin d’accès du dossier instantané lorsqu’elle crée des fichiers instantané).
  3. Spécifiez que l'Agent d'instantané doit écrire les fichiers d'instantanés dans le répertoire défini à l'étape 2. Par exemple, pour que l'Agent d'instantané écrive les fichiers d'instantanés dans \\serveurftp\home\snapshots\ftp, vous devez définir le chemin d'accès \\serveurftp\home\snapshots dans l'un ou l'autre emplacement :
    • Emplacement des instantanés par défaut sur le serveur de distribution associé à cette publication.
      Pour plus d’informations sur la spécification de l’emplacement de instantané par défaut, consultez Spécifier l’emplacement d’instantané par défaut.
    • Autre emplacement de dossier d'instantanés pour cette publication. Un autre emplacement est requis si l'instantané est compressé.
      Entrez le chemin d’accès dans la zone de texte Placer les fichiers dans le dossier suivant de la page Instantané de la boîte de dialogue Propriétés de la publication - <Publication> .
  4. Cliquez sur OK.

Utilisation de Transact-SQL

L'option permettant de rendre disponibles sur un serveur FTP des fichiers d'instantanés peut être définie et ces paramètres FTP peuvent être modifiés par programme en utilisant des procédures stockées de réplication. La procédure utilisée dépend du type de publication. La remise d'instantanés via FTP est utilisée uniquement avec les abonnements par extraction.

Pour activer la remise d'instantanés via FTP pour une publication transactionnelle ou d'instantané

  1. Dans la base de données de publication sur le serveur de publication, exécutez sp_addpublication. Spécifiez @publication, la valeur true pour @enabled_for_internet et les valeurs appropriées pour les paramètres suivants :

    • @ftp_address : adresse du serveur FTP utilisé pour remettre le instantané.
    • (Facultatif) @ftp_port - le port utilisé par le serveur FTP.
    • (Facultatif) @ftp_subdirectory - le sous-répertoire du répertoire FTP par défaut affecté à une connexion FTP. Par exemple, si la racine du serveur FTP est \\ftpserver\home et que vous souhaitez que les instantanés soient stockés dans \\ftpserver\home\snapshots, spécifiez \snapshots\ftp pour @ftp_subdirectory (la réplication ajoute « ftp » au chemin du dossier instantané lorsqu’elle crée instantané fichiers).
    • (Facultatif) @ftp_login - un compte de connexion utilisé lors de la connexion au serveur FTP.
    • (Facultatif) @ftp_password - le mot de passe de la connexion FTP.

    Une publication qui utilise FTP est alors créée. Pour plus d’informations, voir Create a Publication.

Pour activer la remise d'instantanés via FTP pour une publication de fusion

  1. Dans la base de données de publication sur le serveur de publication, exécutez sp_addmergepublication. Spécifiez @publication, la valeur true pour @enabled_for_internet et les valeurs appropriées pour les paramètres suivants :

    • @ftp_address : adresse du serveur FTP utilisé pour remettre le instantané.
    • (Facultatif) @ftp_port - le port utilisé par le serveur FTP.
    • (Facultatif) @ftp_subdirectory - le sous-répertoire du répertoire FTP par défaut affecté à une connexion FTP. Par exemple, si la racine du serveur FTP est \\ftpserver\home et que vous souhaitez que les instantanés soient stockés dans \\ftpserver\home\snapshots, spécifiez \snapshots\ftp pour @ftp_subdirectory (la réplication ajoute « ftp » au chemin du dossier instantané lorsqu’elle crée instantané fichiers).
    • (Facultatif) @ftp_login - un compte de connexion utilisé lors de la connexion au serveur FTP.
    • (Facultatif) @ftp_password - le mot de passe de la connexion FTP.

    Une publication qui utilise FTP est alors créée. Pour plus d’informations, voir Create a Publication.

Pour créer un abonnement par extraction vers une publication transactionnelle ou d'instantané qui utilise la remise d'instantanés via FTP

  1. Dans la base de données d'abonnement de l'Abonné, exécutez sp_addpullsubscription. Spécifiez @publisher et @publication.

    • Dans la base de données d'abonnement de l'Abonné, exécutez sp_addpullsubscription_agent. Spécifiez @publisher, @publisher_db@publication, les informations d’identification Microsoft Windows sous lesquelles le Agent de distribution sur l’Abonné s’exécute pour @job_login et @job_password, et la valeur true pour @use_ftp.
  2. Dans la base de données de publication sur le serveur de publication, exécutez sp_addsubscription pour inscrire l'abonnement par extraction. Pour plus d’informations, consultez Créer un abonnement par extraction de données (pull).

Pour créer un abonnement par extraction à une publication de fusion qui utilise la remise d'instantanés via FTP

  1. Dans la base de données d'abonnement de l'Abonné, exécutez sp_addmergepullsubscription. Spécifiez @publisher et @publication.
  2. Dans la base de données d'abonnement de l'Abonné, exécutez sp_addmergepullsubscription_agent. Spécifiez @publisher, @publisher_db@publication, les informations d’identification Windows sous lesquelles le Agent de distribution sur l’Abonné s’exécute pour @job_login et @job_password, ainsi qu’une true valeur pour @use_ftp.
  3. Dans la base de données de publication sur le serveur de publication, exécutez sp_addmergesubscription pour inscrire l'abonnement par extraction. Pour plus d’informations, consultez Créer un abonnement par extraction de données (pull).

Pour modifier un ou plusieurs paramètres de remise d'instantanés sur FTP pour une publication transactionnelle ou d'instantané

  1. Dans la base de données de publication sur le serveur de publication, exécutez sp_changepublication. Affectez l'une des valeurs suivantes à @property et une nouvelle valeur de ce paramètre à @value:

    • ftp_address - l'adresse du serveur FTP utilisé pour remettre l'instantané.
    • ftp_port - le port utilisé par le serveur FTP.
    • ftp_subdirectory - le sous-répertoire du répertoire FTP par défaut utilisé pour l'instantané FTP.
    • ftp_login - une connexion utilisée pour la connexion au serveur FTP.
    • ftp_password - le mot de passe utilisé pour la connexion FTP.
  2. (Facultatif) Répétez l'étape 1 pour chaque paramètre FTP modifié.

  3. (Facultatif) Pour désactiver la remise d'instantanés via FTP, exécutez sp_changepublication au niveau du serveur de publication dans la base de données de publication. Spécifiez la valeur enabled_for_internet pour @property et la valeur false pour @value.

Pour modifier les paramètres de remise d'instantanés via FTP pour une publication de fusion

  1. Dans la base de données de publication sur le serveur de publication, exécutez sp_changemergepublication. Affectez l'une des valeurs suivantes à @property et une nouvelle valeur de ce paramètre à @value:

    • ftp_address - l'adresse du serveur FTP utilisé pour remettre l'instantané.
    • ftp_port - le port utilisé par le serveur FTP.
    • ftp_subdirectory - le sous-répertoire du répertoire FTP par défaut utilisé pour l'instantané FTP.
    • ftp_login - une connexion utilisée pour la connexion au serveur FTP.
    • ftp_password - le mot de passe utilisé pour la connexion FTP.
  2. (Facultatif) Répétez l'étape 1 pour chaque paramètre FTP modifié.

  3. (Facultatif) Pour désactiver la remise d'instantanés via FTP, exécutez sp_changemergepublication au niveau du serveur de publication dans la base de données de publication. Spécifiez la valeur enabled_for_internet pour @property et la valeur false pour @value.

Exemples (Transact-SQL)

L'exemple suivant crée une publication de fusion qui permet aux Abonnés d'accéder aux données des instantanés en utilisant FTP. L'Abonné doit utiliser une connexion VPN sécurisée lors de l'accès au partage FTP. Les variables de scriptsqlcmd sont utilisées pour fournir les valeurs de connexion et de mot de passe. Pour plus d’informations, consultez Utiliser sqlcmd avec des variables de script.

-- This script uses sqlcmd scripting variables. They are in the form
-- $(MyVariable). For information about how to use scripting variables  
-- on the command line and in SQL Server Management Studio, see the 
-- "Executing Replication Scripts" section in the topic
-- "Programming Replication Using System Stored Procedures".

-- Declarations for adding a merge publication.
DECLARE @publicationDB AS sysname;
DECLARE @publication AS sysname;
DECLARE @ftp_server AS sysname;
DECLARE @login AS sysname;
DECLARE @password AS sysname;
DECLARE @ftp_login AS sysname;
DECLARE @ftp_password AS sysname;
DECLARE @ftp_directory AS sysname;
DECLARE @snapshot_folder AS sysname;
DECLARE @article AS sysname;
DECLARE @owner AS sysname;
SET @publicationDB = N'AdventureWorks'; 
SET @publication = N'AdvWorksSalesOfferMergeFtp'; 
SET @ftp_server = $(Server);
SET @login = $(Login);
SET @password = $(Password);
SET @ftp_login = $(FtpLogin);
SET @ftp_password = $(FtpPassword);
SET @ftp_directory = N'\snapshots\ftp';
-- The snapshot folder is the root FTP folder on the server 
-- with the \snapshot subdirectory.
SET @snapshot_folder = $(AlternateFolder);
SET @article = N'SpecialOffer'; 
SET @owner = N'Sales' 

-- Enable merge replication on the publication database.
USE master
EXEC sp_replicationdboption 
    @dbname = @publicationDB, 
    @optname=N'merge publish',
    @value = N'true' ;

-- Create a new merge publication, enabling FTP snapshot delivery. 
-- Specify the publication compatibility level or it will default to 
-- SQL Server 2000.
USE [AdventureWorks]
EXEC sp_addmergepublication 
-- Specify the required parameters.
    @publication = @publication,
    @publication_compatibility_level = N'90RTM',
    @enabled_for_internet = N'true',
    @snapshot_in_defaultfolder = N'true',
    @alt_snapshot_folder = @snapshot_folder,
    @ftp_address = @ftp_server,
    @ftp_subdirectory = @ftp_directory,
    @ftp_login = @ftp_login,
    @ftp_password = @ftp_password;

-- Create the snapshot job for the publication, using the defaults.
EXEC sp_addpublication_snapshot 
    @publication = @publication, 
    @job_login = @login, 
    @job_password = @password;

-- Add an unfiltered article for the Customer table.
EXEC sp_addmergearticle 
    @publication = @publication, 
    @article = @article, 
    @source_object = @article, 
    @type = N'table', 
    @source_owner = @owner, 
    @destination_owner = @owner, 
    @column_tracking = N'true'; 

-- Start the snapshot job for the publication.
EXEC sp_startpublication_snapshot 
    @publication = @publication;
GO

L'exemple suivant crée un abonnement à une publication de fusion, dans lequel l'Abonné obtient l'instantané en utilisant FTP. L'Abonné doit utiliser une connexion VPN sécurisée lors de l'accès au partage FTP. Les variables de scriptsqlcmd sont utilisées pour fournir les valeurs de connexion et de mot de passe. Pour plus d’informations, consultez Utiliser sqlcmd avec des variables de script.

-- This script uses sqlcmd scripting variables. They are in the form
-- $(MyVariable). For information about how to use scripting variables  
-- on the command line and in SQL Server Management Studio, see the 
-- "Executing Replication Scripts" section in the topic
-- "Programming Replication Using System Stored Procedures".

-- Execute this batch at the Publisher.
DECLARE @publication AS sysname;
DECLARE @subscriber AS sysname;
DECLARE @subscriptionDB AS sysname;
SET @publication = N'AdvWorksSalesOfferMergeFtp';
SET @subscriber = $(SubServer);
SET @subscriptionDB = N'AdventureWorksReplica';

-- At the Publisher, register the subscription, using the defaults.
EXEC sp_addmergesubscription 
    @publication = @publication, 
    @subscriber = @subscriber, 
    @subscriber_db = @subscriptionDB, 
    @subscription_type = N'pull', 
    @subscriber_type = N'local', 
    @subscription_priority = 0, 
    @sync_type = N'Automatic';
GO
-- This script uses sqlcmd scripting variables. They are in the form
-- $(MyVariable). For information about how to use scripting variables  
-- on the command line and in SQL Server Management Studio, see the 
-- "Executing Replication Scripts" section in the topic
-- "Programming Replication Using System Stored Procedures".

-- Execute this batch at the Subscriber.
DECLARE @publicationDB AS sysname;
DECLARE @publication AS sysname;
DECLARE @publisher AS sysname;
DECLARE @login AS sysname;
DECLARE @password AS sysname;
DECLARE @subscriber AS sysname;
DECLARE @subscriptionDB AS sysname;
SET @publicationDB = N'AdventureWorks'; 
SET @publication = N'AdvWorksSalesOfferMergeFtp'; 
SET @publisher = $(PubServer);
SET @login = $(Login);
SET @password = $(Password);
SET @subscriber = $(SubServer);
SET @subscriptionDB = N'AdventureWorksReplica';

EXEC sp_addmergepullsubscription 
    @publisher = @publisher, 
    @publication = @publication, 
    @publisher_db = @publicationDB, 
    @subscriber_type = N'Local', 
    @subscription_priority = 0, 
    @sync_type = N'Automatic';

exec sp_addmergepullsubscription_agent 
    @publisher = @publisher, 
    @publisher_db = @publicationDB, 
    @publication = @publication, 
    @distributor = @publisher, 
    @distributor_security_mode = 1, 
    @use_ftp = N'true', 
    @job_login = @login, 
    @job_password = @password, 
    @publisher_security_mode = 1, 
    @use_web_sync = 0;
GO

Voir aussi

Replication System Stored Procedures Concepts
Transférer des instantanés via FTP
Modifier les propriétés des publications et des articles
Initialiser un abonnement avec un instantané