Fallstudien

Monzo steigert Leistungskennzahlen mit einem einfachen R8-Update um bis zu 35 %

Lesezeit: 2 Minuten
Ben Weiss
Developer Relations Engineer

Monzo ist eine digitale Bank im Vereinigten Königreich mit 15 Millionen Kunden und Tendenz steigend. Mit zunehmender Größe der App stellte das Entwicklungsteam fest, dass die App-Startzeit ein kritischer Bereich für Verbesserungen war. Es befürchtete jedoch, dass dies erhebliche Änderungen an der Codebasis erfordern würde.

Durch die vollständige Aktivierung der R8-Optimierungen konnte Monzo die Rate von „App antwortet nicht“-Fehlern (ANR) um 35% senken. Diese einfache Änderung zeigte, dass wirkungsvolle Optimierungen nicht immer komplexe technische Maßnahmen erfordern.

Umfassende Leistungssteigerungen mit dem vollständigen R8-Modus

Monzo sah im vollständigen R8-Modus eine einfache Lösung, die einen Versuch wert war. Und es funktionierte. Die Leistung wurde in allen Bereichen verbessert:

  • Zuverlässigkeit beim Starten:Kaltstarts wurden um 30%, Warmstarts um 24 % und Hotstarts um 14 % verbessert.
  • Startgeschwindigkeit:Die P50-Startzeiten wurden um 11% und die P90-Startzeiten um 12 % verbessert.
  • Effizienz:Die Gesamtgröße der App wurde um 9 % reduziert.
  • Stabilität:Die ANR-Rate wurde um 35 % gesenkt.
AANDDM_Monzo_Quote-1.png
large_AANDDM_Monzo_Quote-2.png

Optimierungen mit einer einzigen Änderung aktivieren

Viele Android-Apps verwenden eine veraltete Standardkonfigurationsdatei, die die meisten Funktionen des R8-Optimierers deaktiviert. Die wichtigste Änderung, die Monzo vorgenommen hat, um diese Leistungsverbesserungen zu erzielen, bestand darin, die Standarddatei proguard-android.txt durch proguard-android-optimize.txt zu ersetzen. Durch diese Änderung wird die Anweisung -dontoptimize entfernt und R8 kann seine Aufgabe ordnungsgemäß ausführen.

  buildTypes {
  release {
    isMinifyEnabled = true
    isShrinkResources = true
    proguardFiles(
      getDefaultProguardFile("proguard-android-optimize.txt"),
    )
  }
}

Nachdem Sie diese Änderung vorgenommen haben, sollten Sie sich Ihre Keep-Konfigurationsdateien ansehen. In diesen Dateien wird R8 mitgeteilt, welche Teile des Codes nicht geändert werden sollen (in der Regel, weil sie dynamisch oder von externen Bibliotheken aufgerufen werden). Wenn Sie unnötige Keep-Regeln entfernen, kann R8 mehr tun.

Scrollleistung mit Baseline-Profilen verbessern

Um die Nutzerfreundlichkeit weiter zu verbessern, hat Monzo Baseline-Profile implementiert, die speziell auf die Scroll- und Renderingleistung im Hauptfeed ausgerichtet sind. Mit dieser Strategie wurden die häufigsten Nutzeraktionen – das Öffnen der App und das Scrollen durch den Feed – vollständig optimiert. Die Auswirkungen auf das Rendering waren erheblich: Die P90-Scrollleistung wurde um 71% und die P95-Scrollleistung um 87 % verbessert. Das Scrollen in der App ist jetzt reibungsloser als zuvor.

Monzo hat dies in den Releaseprozess integriert, um diese Verbesserungen langfristig beizubehalten. „Wir lösen die Generierung von Baseline-Profilen jeden Wochentag aus, bevor wir unsere nächtlichen Builds ausführen, und übernehmen die neuesten Änderungen, sobald sie abgeschlossen sind“, erklärt Neumayer.

Mit der modernen Android-Entwicklung Schritt halten

Die Erfahrungen von Monzo zeigen, was möglich ist, wenn Sie sich an die Empfehlungen für Android-Build-Tools halten. Während ältere Apps oft mit der komplexen Verwendung von Reflection zu kämpfen haben, war die Umstellung für Monzo unkompliziert, da die Keep-Regeln ordnungsgemäß dokumentiert wurden. „Wir fügen immer einen Kommentar hinzu, in dem erklärt wird, warum Keep-Regeln vorhanden sind. So wissen wir, wann es sicher ist, die Regeln zu entfernen“, sagt Neumayer.

Was rät Neumayer anderen Teams? Überprüfen Sie Ihre Praktiken regelmäßig anhand der aktuellen Standards: „Sehen Sie sich die neuesten Empfehlungen von Google zur App-Leistung an und prüfen Sie, ob Sie alle aktuellen Ratschläge befolgen.“

Weitere Informationen zu R8 finden Sie unter https://d.android.com/r8.

Verfasst von:

Weiterlesen