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 :

Job Failed alors que la requête marche


Sujet :

Administration SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Par défaut Job Failed alors que la requête marche
    Bonjour,
    Il y a 2 jours lors d'une livraison, j'étais confronté à un problème de JOB qui renvoit l'erreur
    Executed as user : NT AUTHORITY\SYSTEM. Login failed for user 'NT AUTHORITY\ANONYMOUS LOGON'.[SQLSTATE 28000][Error 18456]. The step failed.
    .

    OS = W2K8 et SERVER SQL = 2005 SP3
    Le contenu du JOB :Une partie du code de maProcStock :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    CREATE PROCEDURE maProcStock                
    AS
    DECLARE
    @colFICHE INT
    --  Sur le serveur Srv1 Recuperer la valeur de la colonne Srv1.maBase1.T_LIST_TABLE.colFICHE de la table T_LIST_TABLE (contient une SEULE ligne). 
    SET @colFICHE  = (SELECT CAST(colFICHE AS INT) FROM OPENDATASOURCE('SQLNCLI','Data Source=Srv1;Integrated Security=SSPI') .maBase1.dbo.T_LIST_TABLE)
    
    -- Sur le serveur Srv2 Positionner la valeur courante du champ IDENTITY de la table Srv2.maBase2.FICHE sur @colFICHE 
    
    USE maBase2 
    DBCC CHECKIDENT ("FICHE", RESEED, @colFICHE);
    1 ) La procédure stockée marche nickel
    2 ) La requête ci-dessous marche nickel :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT CAST(colFICHE AS INT) FROM OPENDATASOURCE('SQLNCLI','Data Source=Srv1;Integrated Security=SSPI') .maBase1.dbo.T_LIST_TABLE
    3 ) Mais quand je crée un JOB T-SQL qui contient tout simplement le code j'ai l'erreur
    Executed as user : NT AUTHORITY\SYSTEM. Login failed for user 'NT AUTHORITY\ANONYMOUS LOGON'.[SQLSTATE 28000][Error 18456]. The step failed.
    .
    4 ) Et la solution de contournement que j'ai utilisé c'était de créer un fichier .cmd qui appelle la requête en utilisant Sqlcmd et ça marche nickel !
    Mais j'arrive pas à m'expliquer pourquoi le JOB tombe en erreur alors que la requête SQL qu'il contient marche bien !
    J'ai besoin de votre éclairage
    PS :
    - J'utilise l'authentification Windows /Administrator pour ce connecter au server SQL
    - Et j'ai tous les droits sur les 2 serveurs

    Merci d'avance

    A+
    Etienne ZINZINDOHOUE
    Etienne ZINZINDOHOUE
    Billets-Articles

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Février 2008
    Messages
    758
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 758
    Par défaut
    Il faudrait voir le message d'erreur du step. Regardes dans msdb.dbo.sysjobhistory, la colonne message.

    David B.

  3. #3
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Bonjour,

    En attendant le message d'erreur .. quel compte de service pour l'agent SQL Server ?

    ++

  4. #4
    Membre Expert

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Par défaut
    Citation Envoyé par mikedavem Voir le message
    Bonjour,
    En attendant le message d'erreur .. quel compte de service pour l'agent SQL Server ?
    ++
    Aaaah ! si mes souvenirs sont bons il me semble que SQL Agent utilise le compte LocalSystem

    Etienne ZINZINDOHOUE
    Etienne ZINZINDOHOUE
    Billets-Articles

  5. #5
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Je pense donc que ton problème vient de là.

    Dans ta procédure tu utilises ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ... OPENDATASOURCE('SQLNCLI','Data Source=Srv1;Integrated Security=SSPI') ...
    .. donc dans le contexte de sécurité actuel ... A l'exécution de ton job c'est le compte de service de l'agent SQL qui est utilisé.

    ++

  6. #6
    Membre Expert

    Homme Profil pro
    Chargé de Développement et d'Analyse de données
    Inscrit en
    Mars 2010
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé de Développement et d'Analyse de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2010
    Messages : 1 278
    Par défaut
    Hello David,
    Actuellement, je n'ai plus la main sur le serveur du client.
    Dans le feu de l'action le jour de la livraison je n'ai pas copier le message du msdb.dbo.sysjobhistory, mais c'était le même message que ce qu'il y a dans cette copie d'écran ci-joint.
    A+
    Etienne ZINZINDOHOUE
    Etienne ZINZINDOHOUE
    Billets-Articles

  7. #7
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Personnellement et de loin je pencherais par le compte de l'agent SQL Server qui n'a pas les droits suffisants pour exécuter ta procédure ..

    Il faudrait regarder quel compte de service il utilise ..

    ++

Discussions similaires

  1. [AC-97] Recordset vide alors que la requête SQL pure marche
    Par BornToBe dans le forum VBA Access
    Réponses: 9
    Dernier message: 06/11/2012, 18h43
  2. [XL-2003] Bouton inactif alors que le programme marche
    Par Loki83 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 12/04/2010, 10h49
  3. [MySQL] Erreur sql alors que la requête est correcte sur mysql
    Par toshiro92 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 09/04/2009, 00h58
  4. pb .bat, alors que ça marche sous Eclipse
    Par mimi31110 dans le forum Langage
    Réponses: 5
    Dernier message: 15/06/2006, 16h06
  5. Réponses: 12
    Dernier message: 21/01/2006, 20h27

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