Herausforderungen bei der Überwachung von Knockout.js Webanwendungen

Webanwendungen wie Knockout.js helfen Ihnen, Ihr Publikum und Ihre Kunden zu erreichen. Und wenn Ihr Kundenstamm wächst, entwickelt sich Ihre Webanwendung weiter, sodass Sie auf die unterschiedlichen Bedürfnisse eingehen können. Je mehr Features Sie jedoch in Ihre Anwendung einführen, desto mehr Anforderungen und Antworten müssen von Ihren Anwendungen verarbeitet werden. Das, gepaart mit dem Design (CSS), kann Ihre Webanwendungen ziemlich sperrig machen. Ihr müsst denken: “Na und! Die meisten meiner Kunden haben Zugang zu Highspeed-Internet.” Nun, laut einer
von Google durchgeführten Studie
verlassen 53 Prozent der mobilen Nutzer eine Website, wenn das Laden länger als 3 Sekunden dauert. Das ist ungefähr die gleiche Zeit, die Sie gebraucht haben, um den letzten Satz zu lesen. Sie müssen also sicherstellen, dass Ihre Website leicht ist, und sie regelmäßig überwachen, um sicherzustellen, dass die Funktionsupdates und die Patch-Releases keine Lade- oder Leistungsprobleme verursachen.

Ja, clientseitiges Scripting (JavaScript) kann Ihnen zu Hilfe kommen, aber die Verwendung von JavaScript und Datenbindungs-Frameworks wie Knockout.js kann neben ihren Vorteilen auch einige Herausforderungen mit sich bringen. In diesem Artikel werden wir darüber sprechen, wie JavaScript-Bibliotheken ausgelöst werden und wie der beste synthetische Überwachungsansatz für Knockout.js basierte Webanwendungen ist.

 

Das Aufkommen von JavaScript-Bibliotheken

Vor einigen Jahrzehnten waren Webanwendungen noch einfach. Sie würden HTML für das DOM und ein Minimum an CSS verwenden. Jede Anfrage vom Client wird an den Server gesendet, und eine entsprechende Antwort wird zurückgesendet. Anders ausgedrückt: Um eine Änderung an einem DOM-Element widerzuspiegeln, musste die gesamte Seite aktualisiert werden. Angesichts der begrenzten Bandbreite können solche Anfragen viel Zeit in Anspruch nehmen. Doch nach der Einführung von JavaScript im Jahr 1995 änderte sich alles.

Wenn jetzt eine Webseite geladen wird, werden neben HTML und CSS auch einige clientseitige Skriptdateien (JavaScripts und Bibliotheken) gesendet. Diese Skripte enthalten eine Reihe von Aktionen, die benutzergesteuert sind. Solche Bibliotheken ermöglichen es der Webanwendung auch, Anforderungen zu senden und Antworten an externe APIs oder Webdienste zu empfangen, die das HTTP-Protokoll verwenden. JavaScript-Bibliotheken werden auch für AJAX-Aufrufe und Lazy Loading von Webanwendungen verwendet. Diese JavaScript-Funktionen und andere Bibliotheken helfen Ihrer Webanwendung, die Netzwerkbandbreite effizienter zu nutzen. Es lädt die absoluten minimalen Elemente und das Design, wenn die Anwendung geladen wird, und je nach den Interaktionen und Anforderungen der Benutzer lösen diese Skripte und Bibliotheken Ereignisse aus, um Daten zu verarbeiten oder abzurufen. Bis Sie also eine Aktion ausführen, ist das HTML-Rendering relativ statisch. Aber in dem Moment, in dem Sie auf eine Schaltfläche oder eine solche Aktion klicken, wird das JavaScript-Ereignis ausgelöst, um die Anfrage zu verarbeiten, wodurch die Anwendung dynamisch wird.

 

Knockout.js, nicht nur ein Chip aus dem alten Block

Knockout.js ist nur ein weiteres clientseitiges Scripting-Framework, aber seine Spezialität sind DOM-Manipulationen. Während andere JavaScript-Frameworks an das vollständige DOM angehängt werden, bindet Knockout.js an einen bestimmten DOM-Container Ihrer Wahl. Es wird hauptsächlich für Webanwendungen verwendet, bei denen die HTML-Struktur dynamisch ist und von den Interaktionen der Benutzer diktiert wird. Einige wichtige Funktionen von Knockout.js sind die folgenden;

  • MVVM-Architektur. Die MVVM-Architektur (Model – View – View Model) erleichtert die Erstellung dynamischer Benutzeroberflächen. Es hilft, die Renderinglogik von der Anwendungslogik zu abstrahieren.
  • Deklarative Bindung. Anstatt Code von Grund auf neu zu schreiben, können Sie mit Knockout.js Datenbindungsausdrücke in Ihren HTML-Code einbetten. Dies vereinfacht die Anbindung von UI-Teilen an das Datenmodell.
  • Zwei-Wege-Datenbindung. Durch die bidirektionale Datenbindung zwischen dem Datenmodell und der Benutzeroberfläche können Änderungen im Datenmodell sofort auf der Benutzeroberfläche widergespiegelt werden und umgekehrt.

 

Gewöhnliche Überwachungstechniken und Knockout.js Apps

Um sicherzustellen, dass Featurereleases oder Fehlerbehebungen die Leistung Ihrer Anwendungen nicht beeinträchtigen, müssen Sie das Verhalten Ihrer Webanwendung regelmäßig testen und überwachen. Sie sollten die Leistung der Anwendung sowohl auf dem Prinzipalserver als auch auf den Spiegelservern überwachen. Sie sollten die Leistung auch unter hoher Last (Netzwerkverkehr) testen, um sicherzustellen, dass die Server in der Lage sind, diesen Datenverkehr zu verarbeiten. Bei Überwachungstools, die nur auf die HTTP-Antworten angewiesen sind, fehlen die clientseitigen Antworten. Selbst wenn eine HTTP-Antwort erfolgreich ist, bedeutet dies nicht, dass alle JavaScript-Dateien vom Browser ausgeführt und gerendert wurden. Der Unterschied zwischen dem Zeitpunkt, an dem eine Anwendung “vollständig” geladen wird, und dem Zeitpunkt, an dem der Benutzer mit der Anwendung interagieren kann, kann mehrere Sekunden betragen. Was HTTP-Überwachungstechniken nicht berücksichtigen, sind die dynamischen Entitäten in einer Webanwendung. Die Reaktionen auf Benutzerinteraktionen durch JavaScript, komplexe AJAX-Anfragen, API-Aufrufe und das Laden von iFrames (beim Laden von Werbung, abhängig vom vorhandenen Inhalt).

Bei Knockout.js-basierten Webanwendungen, die sich mit der Echtzeit-Datenbindung mit dem DOM befassen, hängen die Leistung und die Seitenladezeit von einer Vielzahl von Benutzerinteraktionen und der Art und Weise ab, wie das Skript die vom Benutzer bereitgestellten Daten verarbeitet. Aus diesem Grund ist das erfolgreiche Laden der Skripte allein kein realistisches Mittel, um die Leistung zu überwachen. Es kann Fälle geben, in denen die tatsächliche Ladezeit einer Knockout.js Anwendung mehrere Sekunden länger dauern kann, um die dynamischen Module des DOM auszulösen und zu laden. Die Verwendung gewöhnlicher Überwachungstechniken würde Ihnen fehlerhafte Statistiken liefern und Sie werden nicht in der Lage sein, die Leistung der Anwendung aus der Perspektive eines echten Endbenutzers wahrzunehmen. Dies wiederum kann sich auf Ihr Geschäft auswirken und die Benutzererfahrung Ihres Kundenstamms ruinieren. Für solche dynamischen Anwendungen sollten wir einen etwas ausgefeilteren Ansatz verwenden.

 

Synthetische Überwachung und Knockout.js-basierte Webanwendungen

Um die tatsächliche Leistung aus der Sicht des Benutzers und Ladezeitstatistiken für Ihre Knockout.js basierte Webanwendung zu ermitteln, müssen Sie eine Möglichkeit finden, die Ladezeit Ihrer Anwendungen und die Zeit zu überwachen, die von den Skripten zum Auslösen der JavaScript-Ereignisse benötigt wird. Der beste Weg, dies zu tun, ist die Verwendung von synthetischem Monitoring, um dynamische Elemente zu überwachen.

  • Verwendung von echten Browsern, um die Benutzerinteraktion zu simulieren. Anstatt Headless-Browser für die Überwachung zu verwenden, verwenden Sie echte Browser, um Benutzerinteraktionen zu simulieren. Dieser Ansatz würde die Zeit berücksichtigen, die der Browsertreiber benötigt, um das DOM zu lesen und zu rendern und die Skripte auf der aktuellen Webseite zu laden.
  • Zeichnen Sie Benutzerinteraktionen auf und geben Sie sie wieder, um JavaScript-Ereignisse auszulösen. Wenn Sie einen Skriptrekorder verwenden, um Benutzerinteraktionen zu skripten und wiederzugeben, können Sie die verschiedenen Benutzerinteraktionen aufzeichnen, insbesondere diejenigen, die die von Knockout.js abhängigen DOM-Container auslösen. Wenn also das Überwachungsskript auf dem Server ausgeführt wird, lädt es Ihre Webanwendung in einem echten Browser und führt die vorab aufgezeichneten Benutzerinteraktionen von verschiedenen geografischen Standorten aus durch. Auf diese Weise wäre Ihr synthetisches Überwachungsskript in der Lage, die Ladezeit des Servers und die Zeit, die benötigt wurde, um die JavaScript-Ereignisse vollständig auszulösen, zu berücksichtigen und Ihnen tatsächliche Ergebnisse der Benutzerleistung zu liefern.
  • Validierung von Inhalten. Dies ist die wichtigste Validierung, wenn es um die Überwachung Ihrer dynamischen Webanwendung geht. Die Inhaltsüberprüfung wird verwendet, um zu überprüfen, ob die JavaScript-Ereignisse tatsächlich abgeschlossen wurden und die Änderung in der Benutzeroberfläche widergespiegelt wird. Sobald die Inhaltsvalidierung erfolgreich ist, bedeutet dies, dass alle angeforderten Änderungen und Ereignisse ausgelöst und abgeschlossen wurden. Die Zeit, die seit dem Senden der Webanwendungsanforderung an den Server benötigt wurde, bis zur Überprüfung des Inhalts spiegelt die tatsächliche Ladezeit und Leistung Ihrer Webanwendung wider. Im Allgemeinen kann der Inhalt Text oder Bild sein, abhängig von der Art des DOM, an das das Knockout.js Skript gebunden ist.

 

Zusammenfassung

In den letzten zehn Jahren gab es große Fortschritte bei den Techniken und Strategien zur Entwicklung von Webanwendungen. Um sicherzustellen, dass Ihre Anwendungen weiterhin effektiv funktionieren und die Anforderungen Ihrer Kunden erfüllen, benötigen Sie eine innovative Lösung, die die Überwachung dynamischer Anwendungen, Webseiten und Technologien wie Knockout.js unterstützt.
Dotcom-Monitor
bietet Ihnen die Tools, wie den
EveryStep Web Recorder
, und alle Funktionen, die Sie benötigen, um selbst die komplexesten Webanwendungen und Websites mühelos zu überwachen.

 


Testen Sie die vollständige Dotcom-Monitor-Plattform 30 Tage lang kostenlos
.

 

Latest Web Performance Articles​

Start Dotcom-Monitor for free today​

No Credit Card Required