Optimierung der SQL Server-Speichernutzung mit SqlDependency
Die Herausforderung:
Die Verwendung der SqlDependency
-Klasse von SQL Server führt häufig zu einem Speicherverlust. Ungenutzte SqlDependency
-Objekte sammeln sich an, was zu einem hohen Ressourcenverbrauch und potenzieller Speichererschöpfung führt, was sich insbesondere in SQL Server Express bemerkbar macht. Die effiziente Beseitigung dieser veralteten Abhängigkeiten ist der Schlüssel zur Aufrechterhaltung einer optimalen Leistung.
Die Lösung:
Abhängigkeiten einfach mit SqlDependency.Stop()
zu stoppen, reicht nicht aus; Konversationsgruppen und Endpunkte bleiben in der Datenbank. Um dieses Problem zu beheben, führen Sie das folgende SQL-Skript aus, um diese verbleibenden Ressourcen zu bereinigen:
<code class="language-sql">DECLARE @ConvHandle uniqueidentifier DECLARE Conv CURSOR FOR SELECT CEP.conversation_handle FROM sys.conversation_endpoints CEP WHERE CEP.state = 'DI' or CEP.state = 'CD' OPEN Conv; FETCH NEXT FROM Conv INTO @ConvHandle; WHILE (@@FETCH_STATUS = 0) BEGIN END CONVERSATION @ConvHandle WITH CLEANUP; FETCH NEXT FROM Conv INTO @ConvHandle; END CLOSE Conv; DEALLOCATE Conv;</code>
Eine überlegene Alternative: SqlDependencyEx
Die Standardklasse SqlDependency
weist Einschränkungen auf, insbesondere die Unfähigkeit, alle Tabellenänderungen während der erneuten Anmeldung zuverlässig zu verfolgen. Eine robustere Alternative ist SqlDependencyEx
, eine Open-Source-Lösung, die Datenbank-Trigger und native Service Broker-Benachrichtigungen nutzt. Dies sorgt für zuverlässigere Änderungsbenachrichtigungen und vermeidet die mit der Microsoft-Implementierung verbundenen Speicherprobleme.
Hier ist ein Beispiel mit SqlDependencyEx
:
<code class="language-csharp">int changesReceived = 0; using (SqlDependencyEx sqlDependency = new SqlDependencyEx( TEST_CONNECTION_STRING, TEST_DATABASE_NAME, TEST_TABLE_NAME)) { sqlDependency.TableChanged += (o, e) => changesReceived++; sqlDependency.Start(); // Simulate table changes. MakeTableInsertDeleteChanges(changesCount); // Allow time for change detection. Thread.Sleep(1000); } Assert.AreEqual(changesCount, changesReceived);</code>
Dieser Ansatz stellt eine rechtzeitige Benachrichtigung über Datenänderungen sicher und entschärft effektiv die Speicherprobleme, die mit der integrierten SqlDependency
-Klasse verbunden sind.
Das obige ist der detaillierte Inhalt vonWie optimiere ich die SQL Server-Speichernutzung bei Verwendung von SqlDependency?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!