Optimieren der SQL Server Leistung mit Dynamics 365 Business Central on-Prem

Optimieren der SQL Server Leistung mit Dynamics 365 Business Central on-Prem und Dynamics NAV (alle Vorgängerversionen). Es gibt so viele Faktoren, die zu Leistungsproblemen in der SQL-Welt beitragen, dass es geradezu verwirrend sein kann, wo man überhaupt anfangen soll.

Wenn die Dynamics Anwendung und die zugehörige SQL Datenbanken wächst, ändern sich die Dinge. Zeilen werden geändert, das Schema wird aktualisiert und häufig verlangsamen sich die Dinge. Diese Leistungsschwächen können plötzlich oder zeitweise auftreten, aber es ist wichtig zu wissen, wie man Leistungsprobleme unterscheidet, damit man das einzelne Problem beheben kann.

Der Beitrag befasst sich mit einigen Schritten, die Sie ausführen sollten, wenn sich Ihre SQL Datenbank seltsam verhält. Damit Sie genau diagnostizieren können, was falsch läuft, und sich darauf konzentrieren, die Dinge zu beschleunigen. Optimieren der SQL Server Leistung mit Dynamics 365 Business Central sollte möglichst mit der Überprüfung der SQL Server Konfiguration starten.


Ist es die Datenbank? Oder der Server?

Wenn Sie Zugriff auf den Server haben, können Sie ein Tool wie System Monitor oder Perfmon verwenden, um die Prozesse zu überprüfen, die auf dem Server selbst ausgeführt werden. Hohe Speichernutzung, hohe CPU-Auslastung und langsamer Netzwerkverkehr sind rote Fahnen, bei denen das Problem möglicherweise nicht die Datenbank selbst ist.

Es gibt viele andere Systemdiagnosetools z.B. V8 Search XE , die bei diesem Prozess helfen können. Eines davon sollte Sie jedoch zumindest in die richtige Richtung weisen, bevor Sie unzählige Stunden damit verbringen, Tabellen, Indizes und mehr zu betrachten.

SQL Server verfügt über ein hervorragendes Profiling-Tool, mit dem sowohl vorhandene Probleme behoben als auch langsam laufende Abfragen isoliert werden können. Der XEvent Profiler zeigt eine Liveansicht erweiterter Ereignisse an. Es ist auch eine fantastische Möglichkeit, zusätzliche Daten zu Ihrer Datenbank für Leistungsoptimierungszwecke abzurufen (z.B. zu sehen, welche Abfragen am häufigsten ausgeführt werden, Dinge wie Speicher- und CPU-Auslastung zu untersuchen, potenzielle Blöcke zu identifizieren usw.).

In V8 Search XE die Optimieren der SQL Server Leistung mit Dynamics 365 Business Central in mehrere Bereiche aufgeteilt.


SQL Server System Check
V8 Search XE SQL Optimierung
V8 Search XE SQL Optimierung

V8 Search XE ist unendlich nützlich und ein guter erster Schritt zur Diagnose einer schlechten Leistung (oder von Fehlern im Allgemeinen). Er ist sowohl in Entwicklungs- als auch in Produktionsumgebungen nützlich.

Standardmäßig sind alle Datenbanken in der SQL Server-Instanz für die verschiedenen datenbankspezifischen Prüfungen geeignet, und Sie können den optionalen Parameter verwenden, um diese Prüfungen auf bestimmte Datenbanken einzuschränken. Gültig ab SQL Server 2012 aufwärts.


Performs checks:
  • Processor
  • Memory
  • Pagefile
  • I/O
  • Server
  • Service Accounts
  • Instance
  • Database and tempDB
  • Performance
  • Indexes and Statistics
  • Naming Convention
  • Security
  • Maintenance and Monitoring

Diese verschiedenen leistungsbezogenen Abfragen können es wert sein, regelmäßig überprüft zu werden, um potenzielle Probleme zu finden, die im Laufe der Zeit auftreten können.


Den Täter gefunden? Finden Sie jetzt heraus, warum die Abfrage langsam ist.

Sobald Sie eine bestimmte Abfrage identifiziert haben, die in den Analyse-Ansichten im V8 Search XE “SQL Server Check” als langsam ausgeführt indentifiziert wurde, können Sie sich den Ausführungsplan anzeigen, um genau zu sehen, was SQL Server hinter den Kulissen tut. Sie können von einer bestimmten Abfrage aus einfach über, die Schaltfläche “Show Plan” in der Symbolleiste oder über das Menüband darauf zugreifen:

V8 Query Plan

Ausführungspläne können auf einfache Weise potenzielle Probleme im Zusammenhang mit der Indizierung aufdecken , die dazu führen, dass Ihre gesamte Tabelle gescannt wird, anstatt genau das zu suchen, was sie benötigt. Auf den ersten Blick mögen sie unglaublich komplex erscheinen (und sie können es auch sein), aber sobald Sie mit ihnen gearbeitet haben, lernen Sie, Muster zu identifizieren und was sie damit verbunden sind (z. B. zeigt die X-Operation einen fehlenden Index für eine Tabelle usw. an).


Ein paar Dinge, auf die Sie hier achten sollten:
  • Suchen Sie nach Warnungen – Warnungen wie “No Join Predicate” sollten sehr offensichtliche rote Fahnen sein, die Sie wahrscheinlich ansprechen müssen. Die meisten Warnungen sollten zumindest weitere Untersuchungen rechtfertigen.
  • Reihenfolge der Vorgänge (Kosten) – Betrachten Sie die teuersten Operationen und festzustellen , ob solche Bestellung machen Sinn. Verbraucht ein einfacher Join 90% der Rechenleistung für den gesamten Anruf? Wenn ja, könnte etwas falsch sein.
  • Scans vs. Seeks – Beides ist nicht unbedingt schlecht, aber wenn eines viel länger dauert als erwartet (eines davon), lohnt es sich wahrscheinlich festzustellen, ob ein Index fehlt (d.h. der SQL Server scannt die gesamte Tabelle, anstatt auf einen gut definierten Suchwert zu greifen).

Das Verständnis von Ausführungsplänen ist mit Erfahrung verbunden, und Sie müssen sich hoffentlich nicht zu häufig mit ihnen befassen. Aber wenn Sie dies tun, wissen Sie, dass sie ein wertvoller Verbündeter im Kampf gegen schlechte Leistungen sein können.


Untersuchen Sie mögliche schlechte / fehlende Indizes

SQL-Indizes sind das A und O für die Leistungsoptimierung in Ihrer Dynamics NAV SQL Datenbank. Sie können sich diese ähnlich wie die Indizes vorstellen, die Sie möglicherweise in einem Buch finden, da sie es SQL ermöglichen, zu “wissen”, wo sie nach bestimmten Daten suchen müssen, anstatt willkürlich Seite für Seite durchzublättern.

Es ist erwähnenswert, dass Indizes nicht “fehlerfrei” sind und wie bei den meisten Dingen, wenn Sie sie falsch verwenden, sie mehr schaden als nützen können (d.h. stellen Sie sich vor, Sie gehen auf eine Schnitzeljagd mit außergewöhnlich Wegen oder lausigen Hinweisen).

Eine großartige Sache ist, dass Sie diese Arbeit nicht immer selbst erledigen müssen. Leute wie wir, haben Tools wie V8 Search XE entwickelt, um Indizes basierend auf der Tabellennutzung zu empfehlen. Für die Optimieren der SQL Server Leistung mit Dynamics 365 Business Central on-Prem und Dynamics NAV von unschätzbaren Wert!


Statistiken

So wertvoll es auch sein kann, SQL-Abfragen zu optimieren, es ist erwähnenswert, dass SQL Server einige davon “gut” und andere “schlecht” selbst erledigt. Dies wird durch die Verwendung von Statistiken erreicht, indem getätigte Anrufe überwacht, Ausführungspläne zwischengespeichert und Beurteilungen darüber vorgenommen werden, wie ein bestimmter Anruf am besten ausgeführt werden könnte/sollte.
Beachten Sie, dass wir “gut oder schlechten” erwähnt haben und das ist beabsichtigt. Statistiken sind zwar unglaublich wertvoll, können aber auch Probleme verursachen, wenn sie nicht korrekt erfasst werden oder veraltet sind. In den meisten Szenarien müssen Sie sich wahrscheinlich nicht regelmäßig mit diesen befassen, aber es ist wichtig zu wissen, dass sie existieren.


Wie bei fast jeder Technologien ist es sehr unwahrscheinlich, dass nur eines dieser Elemente alle Ihre Leistungsprobleme mit SQL Servern und Dynamics 365 Business Central bzw. Dynamics NAV heilt. Betrachten Sie all dies als wertvolle Werkzeuge in Ihrem Arsenal zur Fehlerbehebung und verwenden Sie sie zusammen, wenn Probleme auftreten.


Gerne beantworten wir Ihnen persönlich weitergehende Fragen zu diesem Thema.
Ihr dynamicsproject.com Team