IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Administration SQL Server Discussion :

Sauvegarder base de données sur un serveur lié


Sujet :

Administration SQL Server

  1. #1
    Membre à l'essai
    Femme Profil pro
    Consultant fonctionnel
    Inscrit en
    septembre 2019
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Consultant fonctionnel
    Secteur : Industrie

    Informations forums :
    Inscription : septembre 2019
    Messages : 13
    Points : 15
    Points
    15
    Par défaut Sauvegarder base de données sur un serveur lié
    bonjour a tous ,
    J'essaye de sauvegarder une base de données sur ServerA via ServerB.
    J'ai fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    DECLARE @SQL NVARCHAR(100)
    SET @SQL = 'BACKUP DATABASE DBname to disk=''\\ServerB\E$\folder\DBname.bak'''
    EXECUTE ServerA.master.dbo.sp_executesql @SQL
    J'exécute ceci sur ServerB mais j'obtiens une erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Msg 3013, Level 16, State 1, Line 9 BACKUP DATABASE is terminating abnormally. Msg 3201, Level 16, State 1, Line 9 Cannot open backup device '\ServerB\E$\folder\DBname.bak'. Operating system error 5(Access is denied.).
    J'ai donné à NT SERVICE \ MSSQLSERVER un contrôle total sur le dossier mais cela n'a pas fonctionné.
    merci pour vos aides

  2. #2
    Rédacteur
    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    mai 2002
    Messages
    20 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : mai 2002
    Messages : 20 481
    Points : 48 362
    Points
    48 362
    Par défaut
    Un serveur lié est fait pour l'exécution de requêtes distantes, pas de commandes SQL de type BACKUP.

    Pour effectuer un backup sur un serveur distant il faut que le compte de ,service de SQL Server ait les droits d'accès en écriture sur le serveur distant.

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre expérimenté

    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    septembre 2003
    Messages
    718
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : septembre 2003
    Messages : 718
    Points : 1 596
    Points
    1 596
    Billets dans le blog
    8
    Par défaut
    Bonjour,

    En complément de la réponse de SQLPro,
    Vous pouvez, depuis le serveur ServerB déléguer le traitement de sauvegarde sur le Serveur ServerA par le biais du Serveur lié nommé ServerA
    Pour cela, et pour diverses raisons que je ne vais détailler ici, vous ne pourrez pas utiliser la commande sp_executesql !
    Il vous faudra recourir à la commande EXEC comme suit :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    SET @SqlStmt = N'BACKUP DATABASE ....'; 
    EXEC (@SqlStmt) AT [ServerA];
    Voilà techniquement, c'est possible, mais cela est fortement déconseillé, et ce, pour des raisons évidentes de sécurité, notamment si le Serveur A est un serveur de production.
    Et comme l'a souligné SQLPro, les Serveurs liés ne sont pas faits ni prévus pour ce genre de traitement.

    A+
    "Une idée mal écrite est une idée fausse !"
    http://hamid-mira.blogspot.com

Discussions similaires

  1. Réponses: 3
    Dernier message: 30/03/2008, 16h20
  2. Connexion à la base de donnée sur le serveur
    Par abbd dans le forum Windows Forms
    Réponses: 1
    Dernier message: 30/03/2008, 16h16
  3. mise d'une base de données sur un serveur
    Par Jasmine80 dans le forum Installation
    Réponses: 2
    Dernier message: 28/11/2007, 10h39
  4. base de données sur le serveur
    Par faamugol dans le forum Access
    Réponses: 8
    Dernier message: 06/06/2006, 11h13

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo