Freigeben über


Leistung

In diesem Thema wird die Maximierung der Leistung bei Verwendung des Datenanbieters erläutert.

Konfigurieren der Leistung

Konfigurieren Sie die Anbieter wie Folgend, um die Leistung zu verbessern.

Pooling von OLE DB-Ressourcen, um die Dauer des Verbindungsstarts zu verkürzen

Durch das OLE DB-Ressourcenpooling und das Anbieterverbindungspooling kann die Leistung gesteigert werden, indem die Dauer des Verbindungsstarts verkürzt wird. Das Ressourcenpooling wird durch die OLE DB-Dienstkomponenten aktiviert, die Teil des Betriebssystems Windows sind. Sie können das OLE DB-Ressourcenpooling durch Festlegen von OLE DB-Initialisierungseigenschaften und Registrierungseinstellungen aktivieren. Weitere Informationen finden Sie unter OLE DB-Ressourcenpooling (https://go.microsoft.com/fwlink/?LinkID=180446).

Pooling von Anbieterressourcen, um die Dauer des Verbindungsstarts zu verkürzen

Verbindungspooling ist eine clientseitige Optimierung, die die Dauer des Verbindungsstarts verkürzt und die Arbeitsspeicherauslastung auf dem Clientcomputer verringert. Der Datenanbieter unterstützt Verbindungspooling. Sie können das Pooling mithilfe der Initialisierungszeichenfolge von OLE DB-Datenquellen (Connection Pooling=True) angeben. Sie können das Pooling auch mithilfe des Dialogfelds Advanced (Erweitert) des Datenquellen-Assistenten und auf der Registerkarte All (Alle) im Dialogfeld mit den Datenverknüpfungen konfigurieren.

Der Anbieter verwaltet basierend auf der Eigenschaft Max. Poolgröße einen Verbindungscache. Die Standardpoolgröße umfasst 100 Verbindungen (Max Pool Size=100). Sie können diesen Wert mithilfe des Dialogfelds All (Alle) des Datenquellen-Assistenten oder des Dialogfelds „Data links“ (Datenverknüpfungen) anpassen. Es gibt keine Obergrenze für die Eigenschaft Max. Poolgröße. Wenn Sie für die Eigenschaft Max. Poolgröße einen kleineren Wert als 0 konfigurieren, wird der Standardwert 100 verwendet. Optional können Sie die Anzahl von Sekunden angeben, die der Datenanbieter warten soll, bis mithilfe von clientseitigem Pooling Verbindungen hergestellt werden. Wenn alle Verbindungen in einem Pool in Gebrauch sind und der Timeoutzeitraum abläuft, gibt der Datenanbieter einen Fehler ("Die Verbindung ist nicht verfügbar") an den Datenconsumer zurück. Der Standardwert ist 15 Sekunden (Connect Timeout=15). Sie können diesen Wert mithilfe des Dialogfelds All (Alle) des Datenquellen-Assistenten oder des Dialogfelds „Data Links“ (Datenverknüpfungen) anpassen. Es gibt keine Obergrenze für die Eigenschaft Verbindungstimeout. Geben Sie „–1“ an, um den Datenanbieter anzuweisen, unbegrenzt lange auf eine offene Verbindung auf Seiten des clientseitigen Verbindungspools zu warten.

Optimieren des Rowsetcaches beim Abrufen von Daten

Die Eigenschaft RowSetCacheSize weist den Datenanbieter an, Zeilen von DB2 vorab abzurufen, während gleichzeitig Zeilen verarbeitet und an den Datenconsumer zurückgegeben werden. Diese Funktion kann die Leistung in schreibgeschützten Massenoperationen auf Computern mit mehreren Prozessoren bzw. Kernen verbessern. Der Standardwert für diese Eigenschaft ist 0 (RowsetCacheSize=0). Die optionale Vorabruffunktion ist somit „deaktiviert“. Es wird empfohlen, einen Wert zwischen 10 und 100 mit einem empfohlenen Anfangswert von 10 festzulegen. Sie können diesen Wert mithilfe des Dialogfelds All (alle) des Datenquellen-Assistenten oder des Dialogfelds „Data Links“ (Datenverknüpfungen) anpassen. Auf diese Weise wird der Datenanbieter angewiesen, die angegebene Anzahl von Tabellenzeilen vorab abzurufen, die im Rowsetcache des Datenanbieters gespeichert werden. Die Größe der Tabellenzeilen wird automatisch basierend auf dem Wert für cRows in der vom Consumer festgelegten OLE DB-Schnittstelle IRowset::GetNextRows bestimmt.

Die Vorbereitung von Befehlen mithilfe von Parametern bis zur Ausführung zurückstellen

Die Eigenschaft „Defer Prepare“ (Vorbereitung zurücksetzen) weist den Datenanbieter an, die Verarbeitung von parametrisierten INSERT-, UPDATE-, DELETE- und SELECT-Befehlen zu optimieren. Sie können diese Option mithilfe der ADO.NET-Verbindungszeichenfolge oder der Initialisierungszeichenfolge der OLE DB-Datenquellen (Defer Prepare=True) angeben. Sie können das Pooling auch mithilfe des Dialogfelds Advanced (Erweitert) des Datenquellen-Assistenten und auf der Registerkarte All (Alle) im Dialogfeld mit den Datenverknüpfungen konfigurieren. Für die INSERT-, UPDATE- und DELETE-Befehle fasst der Datenanbieter Vorbereitungs- und Ausführungsbefehle sowie Befehle zum Ausführen von Commits in einem Netzwerkdatenstrom für die Remotedatenbank zusammen. Für die SELECT-Anweisung fasst der Datenanbieter Vorbereitungs- und Ausführungsbefehle in einem Netzwerkdatenstrom zusammen. Auf diese Weise wird der Netzwerkverkehr minimiert und häufig die Gesamtleistung verbessert.

Abrufen von Schemainformationen aus einem DB2-Schattenkatalog

Die Eigenschaft Schattenkatalog weist den Datenanbieter an, Schemainformationen aus einem DB2-Schattenkatalog abzurufen. Der DB2-Administrator kann einen Schattenkatalog so definieren, dass die Schemainformationen für Tabellen, Spalten, primäre Schlüssel und Indizes enthalten sind. Alle Datenconsumer verwenden diese Schemainformationen zur Entwurfszeit. Einige Datenconsumer verwenden diese Schemainformationen zur Laufzeit. Auf den DB2-Schemakatalog kann aufgrund von Sperren während Schreibvorgängen (Ausführung von CREATE- und ALTER-Anweisungen) ggf. nicht mehr zugegriffen werden. Außerdem kann das DB2-Standardschema groß sein und daher zu Wartezeiten bei Vorgängen des Datenconsumers zur Entwurfs- und Laufzeit führen. Ein Schattenkatalog kann Konflikte verringern und die Leistung verbessern, wenn Schemaabrufvorgänge ausgeführt werden.

Senden mehrerer Zeilen in einer einzelnen Arbeitseinheit

Der Datenanbieter unterstützt die OLE DB-Schnittstelle IRowsetFastLoad, um Consumern (z. B. Integration Services) das Ausführen mehrerer INSERT-Anweisungen in optimierten Batches zu ermöglichen. Dies hat eine bessere Verwendung von TCP/IP-Netzwerkpaketen und eine Verbesserung der Gesamtleistung zur Folge. Sie wählen RowsetFastLoad aus, wenn Sie OLE DB-Ziele in Datenflüssen in Integration Services-Paketen mithilfe des Business Intelligence Developer-Paket-Designers konfigurieren. Die IRowsetFastLoad-Schnittstelle wird beim Einfügen in DB2 unterstützt. Weitere Informationen finden Sie unter Access Mode for Integration Services OLE DB Destination Custom Properties (https://go.microsoft.com/fwlink/?LinkId=241518).

Festlegen eines Timeouts, um Abfragen mit langer Ausführungszeit zu beenden

Der Datenanbieter bietet eine Eigenschaft für einen Befehlstimeout, damit Sie Abfragen mit langer Ausführungszeit automatische beenden können, die sich ggf. negativ auf die Leistung auswirken. Der Standardwert für das OLE DB-Rowset DBPROP_COMMANDTIMEOUT ist 0. Dies bedeutet, dass kein Timeout auftritt.

Sie können den Wert für den Befehlstimeout von einer Vielzahl von Consumern angeben. Der Datenanbieter bietet eine DBPROP_COMMANDTIMEOUT-Eigenschaft für OLE DB-Rowsets, um Entwicklern das automatische Beenden von Abfragen mit langer Ausführungszeit zu ermöglichen, da diese sich ggf. negativ auf die Leistung auswirken. Integration Services und Analysis Services stellen diese Eigenschaft in Business Intelligence Development Studio mithilfe der Option Data Source Query Timeout bereit. Reporting Services stellt diese Eigenschaft in Business Intelligence Development Studio mithilfe der Option Dataset Properties Timeout bereit. Replikations- und Abfrageprozessor machen diese Eigenschaft über das sp_serveroption, @optname=query Timeout verfügbar.

Messen der Leistung

Der Datenanbieter stellt Leistungsindikatoren zum Messen der Leistung bereit. Standardmäßig sind die Leistungsindikatoren deaktiviert. Sie können aktiviert werden, indem der folgende Registrierungsschlüssel auf den Wert 1 festgelegt wird:

HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Host Integration Server\Data Integration\UpdateCounters = 1

Die Leistungsindikatoren des Datenanbieters zeichnen Informationen zu offenen Verbindungen, offenen Anweisungen, gesendeten und empfangenen Paketen und Bytes, der durchschnittlichen Verarbeitungszeit des Hosts (DB2-Server), Befehlsausführungen, Datenabrufen und Commits/Rollbacks von Transaktionen auf. Weitere Informationen finden Sie unter Leistungsindikatoren (https://go.microsoft.com/fwlink/?LinkID=119211).