AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi Fehlermeldung "Microsoft MSXML ist nicht installiert" bei Service-Anwendung
Thema durchsuchen
Ansicht
Themen-Optionen

Fehlermeldung "Microsoft MSXML ist nicht installiert" bei Service-Anwendung

Ein Thema von KaiW · begonnen am 22. Jun 2016 · letzter Beitrag vom 22. Jun 2016
Antwort Antwort
KaiW

Registriert seit: 5. Feb 2016
6 Beiträge
 
Delphi XE7 Architect
 
#1

Fehlermeldung "Microsoft MSXML ist nicht installiert" bei Service-Anwendung

  Alt 22. Jun 2016, 09:05
Hallo zusammen,

ich erstelle aktuell mit Delphi XE7 unter Windows 7 eine Service-Anwendung, welche per REST XML-Daten mit einem Remote-Host austauscht. Den ganzen Ablauf und die entwickelten Klassen habe ich der besseren Fehler-Analysierbarkeit wegen vorher in einer "normalen" VCL-Anwendung getestet, alles lief bestens. Mein Service wirft jedoch nun die Fehlermeldung "Microsoft MSXML ist nicht installiert".
Ich nutze TXMLDocument in einer TMyServer-Klasse, abgeleitet von TObject.
Die zugehörige Variable FServer ist im private-Abschnitt des Services deklariert.
Die MyServer-Instanz wird im OnCreate des Service erzeugt.
Die Aufrufe der MyServer-Methoden erfolgen im OnExecute des Services in einer endlos-Schleife nebst Sleep(250) und ServiceThread.ProcessRequests(False);.

Bei der Lösungssuche habe ich hier im Forum den Artikel http://www.delphipraxis.net/177162-m...tcpserver.html
gefunden. Das dortige Problem scheint ähnlich, daher habe ich im Constructor des Service die Methode "CoInitialize(nil);" aufgerufen (unit ActiveX habe ich im implementation-Teil in die uses-Klausel aufgenommen).

Nach dem neu-Erzeugen (Build) des Services bekomme ich jedoch noch immer die gleiche Fehlermeldung.

Nach weitergehender Recherche bin ich auf den Artikel http://www.delphigroups.info/2/76/471694.html gestoßen. Es ist also möglich, dass es am Thread-Kontext liegt. Es wird u.a. empfohlen, Synchronize() aufzurufen.
Ich selbst erstelle im Service keinerlei Threads, kenne also nur den "ServiceThread", den mir Delphi im Service automatisch zur Verfügung stellt.
Angenommen, das ist der Hauptthread, dann darf ich synchronize daraus nicht aufrufen, da ansonsten eine Endlosschleife droht http://docwiki.embarcadero.com/Libra...ad.Synchronize
Zudem behauptet der Win7 Ressourcen-Monitor, der Service hätte 6-9 Threads.

Ich habe dann den Aufruf von "CoInitialize(nil);" in das OnExecute-Event des Services verlegt und verhindere über eine private Variable FInitialized, dass das ganze mehrfach aufgerufen wird.

Nun klappt es. Aber das Ganze erweckt bei mir den Anschein eines Work-arounds. Gibt es dazu Anmerkungen? Spricht etwas dagegen, es dabei zu belassen? Was ist mit dem Aufruf von CoUninitialize()? Wo packe ich den am besten hin, oder ist der letztenendes unnötig, da beim Beenden des Services eh alles automatisch resettet wird?

Gruß
Kai

Geändert von KaiW (22. Jun 2016 um 10:25 Uhr)
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.176 Beiträge
 
Delphi 10 Seattle Enterprise
 
#2

AW: Fehlermeldung "Microsoft MSXML ist nicht installiert" bei Service-Anwendung

  Alt 22. Jun 2016, 09:59
Hallo-

Ich habe nicht viel Ahnung von Diensten und ohne Code zu sehen wird das noch schwieriger. Ich würde aber raten dass dein Fehler hier steckt:
Zitat:
. Das dortige Problem scheint ähnlich, daher habe ich im Constructor des Service die Methode "CoInitialize(nil);" aufgerufen
Ohne es ausprobiert zu haben würde ich raten dass der Konstruktor des Service nicht in dem Thread-Kontext stattfindet in welchem er später läuft und seine Anforderungen entgegen nimmt. Vergleiche doch mit dem Debugger einfach mal welcher Thread es ist in welchem du CoInitialize aufrufst und welcher Thread es ist der dann die Exception wirft.


PS: Ich habe es grade einmal ausprobiert und habe keine Probleme damit:
- Im Service die Events OnStart und OnStop mit dem Starten und Beenden meines Hintergrund-Threads belegt
- Im "Execute()" meines Threads am Anfang einmal "CoInizialize" aufgerufen
- Dann wild mit XML hantiert
- Alles geht

PPS: Jepp, Das OnCreate-Ereignis ist ein anderer Thread-Kontext als OnStart. OnExecute wahrscheinlich genauso. Dein CoInitialize ist damit im OnCreate definitiv falsch. (Wofür ist OnExcute eigentlich gut? Ich nehme immer nur OnStart und OnStop und werde glücklich damit)

Geändert von Der schöne Günther (22. Jun 2016 um 10:25 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: Fehlermeldung "Microsoft MSXML ist nicht installiert" bei Service-Anwendung

  Alt 22. Jun 2016, 10:47
Das OnExecute ist im Prinzip das gleiche, wie das Execute beim Thread.

Ist OnExecute verdrahtet, dann wird ein Thread gestartet und dieses OnExecute vom Thread im Execute ausgeführt. (dient nur der Veranschaulichung)

Ich nehme allerdings auch immer separate Threads (oder eben nur einen) und kontrolliere den/dieses über die Events des Services.

Zur Frage selber:

Jeder Thread-Kontext der mit MSXML arbeiten möchte muss zwangsweise erst ein CoInitialize aufrufen, sonst geht da gar nichts (in diesem Thread-Kontext)
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)

Geändert von Sir Rufo (22. Jun 2016 um 10:50 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 16:29 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz