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

Windows Discussion :

WMI : scanner l'état d'un service


Sujet :

Windows

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre chevronné
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    434
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 434
    Par défaut WMI : scanner l'état d'un service
    Bonjour,

    voilà, je souhaite démarrer (ou arreter) un service via le WMI.
    Super facile.

    Par contre, je voudrais avoir une alerte quand le service est effectivement démarré. En effet, entre la demande de démarrage et le démarrage, il peut se passer plusieurs secondes.

    Voici un script que j'ai écris, j'indique dedans la commande qui me manque :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    Dim Services, ObjetSet, Objet
    Set Services = GetObject("winmgmts:\\")
    Set ObjetSet = Services.InstancesOf("Win32_Service")
    Dim etat
    For Each Objet In ObjetSet
    if Objet.name = "MSSQLSERVER" Then
    etat = ucase(Objet.state)
    if etat <> "RUNNING" Then
    	Objet.StartService
    	etat = ucase&#40;Objet.state&#41;
                    'ici je cherche un truc genre &#40;tant que en cours de demaraage&#41;...
    	while &#40;etat <>"RUNNING"&#41;
    		etat = ucase&#40;Objet.state&#41;
    		
    	wend
    End If
    End If
    Next
    Il semble que la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    etat = ucase&#40;Objet.state&#41;
    dans le while ne soit jamais remise à jour car même lorsque le service est en état demarrer dans windows, la variable ETAT est toujours à STOPPED.

    Une idée ?

  2. #2
    Expert confirmé

    Homme Profil pro
    pdg
    Inscrit en
    Juin 2003
    Messages
    5 756
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : pdg

    Informations forums :
    Inscription : Juin 2003
    Messages : 5 756
    Billets dans le blog
    3
    Par défaut Re: WMI : scanner l'état d'un service
    Citation Envoyé par ZERS
    Il semble que la ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    etat = ucase&#40;Objet.state&#41;
    dans le while ne soit jamais remise à jour car même lorsque le service est en état demarrer dans windows, la variable ETAT est toujours à STOPPED.
    ben si tu réaffecte jamais etat, je vois pas trop pourquoi elle changerait toute seule de valeur. Note que y'a un boolean Started dans la classe, et que ta boucle risque d'être sans fin si le démarrage du service échoue.
    La commande "net start MSSQLSERVER" fait ce que tu recherches...

  3. #3
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1

Discussions similaires

  1. Réponses: 1
    Dernier message: 02/04/2010, 13h40
  2. Connaitre l''état d'un service Windows
    Par cyber_zeus72 dans le forum API standards et tierces
    Réponses: 1
    Dernier message: 13/05/2009, 16h34
  3. envoi état d'un service
    Par marsu1983 dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 23/11/2008, 19h43
  4. Réponses: 2
    Dernier message: 18/10/2007, 15h32
  5. Connaître l'état d'un service
    Par NoisetteProd dans le forum API, COM et SDKs
    Réponses: 5
    Dernier message: 06/08/2003, 17h04

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