กรณีศึกษา

Monzo เพิ่มเมตริกประสิทธิภาพได้สูงสุด 35% ด้วยการอัปเดต R8 อย่างง่าย

ใช้เวลาอ่าน 2 นาที
Ben Weiss
วิศวกรนักพัฒนาซอฟต์แวร์สัมพันธ์

Monzo เป็นธนาคารดิจิทัลในสหราชอาณาจักรที่มีลูกค้า 15 ล้านรายและมีแนวโน้มเพิ่มขึ้น เมื่อแอปขยายขนาด ทีมวิศวกรรมพบว่าเวลาเริ่มต้นของแอปเป็นส่วนสำคัญที่ต้องปรับปรุง แต่กังวลว่าการปรับปรุงดังกล่าวจะต้องมีการเปลี่ยนแปลงโค้ดเบสอย่างมาก

Monzo เปิดใช้การเพิ่มประสิทธิภาพ R8 อย่างเต็มรูปแบบ จึงลดอัตราแอปพลิเคชันไม่ตอบสนอง (ANR) ได้ถึง 35% การเปลี่ยนแปลงอย่างง่ายนี้พิสูจน์ให้เห็นว่าการเพิ่มประสิทธิภาพที่ส่งผลลัพธ์สูงไม่จำเป็นต้องใช้ความพยายามด้านวิศวกรรมที่ซับซ้อนเสมอไป

ปลดล็อกประสิทธิภาพที่ครอบคลุมด้วยโหมดเต็มรูปแบบของ R8

Monzo พบว่าโหมดเต็มรูปแบบของ R8 เป็นวิธีแก้ไขที่ง่ายและคุ้มค่าที่จะลอง และได้ผลจริง โดยช่วยปรับปรุงประสิทธิภาพในทุกด้าน ดังนี้

  • ความน่าเชื่อถือในการเริ่มต้น: การเริ่มต้นแบบ Cold Start ดีขึ้น 30% การเริ่มต้นแบบ Warm Start ดีขึ้น 24% และการเริ่มต้นแบบ Hot Start ดีขึ้น 14%
  • ความเร็วในการเปิดแอป: เวลาเปิดแอป P50 ดีขึ้น 11% และเวลาเปิดแอป P90 ดีขึ้น 12%
  • ประสิทธิภาพ: ขนาดแอปโดยรวมลดลง 9%
  • ความเสถียร: ANR ลดลง 35%
AANDDM_Monzo_Quote-1.png
large_AANDDM_Monzo_Quote-2.png

เปิดใช้การเพิ่มประสิทธิภาพด้วยการเปลี่ยนแปลงเพียงครั้งเดียว

แอป Android จำนวนมากใช้ไฟล์การกำหนดค่าเริ่มต้นที่ล้าสมัย ซึ่งปิดใช้ฟังก์ชันการทำงานส่วนใหญ่ของตัวเพิ่มประสิทธิภาพ R8 การเปลี่ยนแปลงหลักที่ Monzo ทำเพื่อปลดล็อกการปรับปรุงประสิทธิภาพเหล่านี้คือการแทนที่ไฟล์เริ่มต้น proguard-android.txt ด้วย proguard-android-optimize.txt การเปลี่ยนแปลงนี้จะนำคำสั่ง -dontoptimize ออกและอนุญาตให้ R8 ทำงานได้อย่างถูกต้อง

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

หลังจากทำการเปลี่ยนแปลงนี้แล้ว คุณควรดูไฟล์การกำหนดค่า Keep ไฟล์เหล่านี้จะบอก R8 ว่าส่วนใดของโค้ดที่ควรปล่อยไว้ (โดยปกติจะเป็นเพราะมีการเรียกใช้แบบไดนามิกหรือโดยไลบรารีภายนอก) การจัดระเบียบกฎ Keep ที่ไม่จำเป็นหมายความว่า R8 จะทำงานได้มากขึ้น

ปรับปรุงประสิทธิภาพการเลื่อนด้วยโปรไฟล์พื้นฐาน

Monzo ใช้โปรไฟล์พื้นฐานเพื่อปรับปรุงประสบการณ์ของผู้ใช้ให้ดียิ่งขึ้น โดยมุ่งเน้นที่ประสิทธิภาพการเลื่อนและการแสดงผลในฟีดหลัก กลยุทธ์นี้ช่วยให้มั่นใจได้ว่าเส้นทางของผู้ใช้ที่พบบ่อยที่สุด เช่น การเปิดแอปและการเลื่อนฟีด ได้รับการเพิ่มประสิทธิภาพอย่างเต็มที่ ผลกระทบต่อการแสดงผลนั้นมีนัยสำคัญ โดยประสิทธิภาพการเลื่อน P90 เร็วขึ้น 71% และประสิทธิภาพการเลื่อน P95 ดีขึ้น 87% ตอนนี้การเลื่อนในแอปจึงราบรื่นกว่าเดิม

Monzo ได้รวมการปรับปรุงนี้ไว้ในกระบวนการเผยแพร่เพื่อรักษาการปรับปรุงเหล่านี้ไว้ในระยะยาว เราจะเริ่มสร้างโปรไฟล์พื้นฐานทุกวันธรรมดา (ก่อนที่จะเรียกใช้ไนท์ลีบิลด์) และคอมมิตการเปลี่ยนแปลงล่าสุดเมื่อเสร็จสิ้น" Neumayer อธิบาย

ติดตามการพัฒนา Android สมัยใหม่

ประสบการณ์ของ Monzo แสดงให้เห็นถึงสิ่งที่เป็นไปได้เมื่อคุณติดตามคำแนะนำเกี่ยวกับเครื่องมือสร้าง Android แม้ว่าแอปเก่ามักจะมีปัญหาในการใช้งานการสะท้อนที่ซับซ้อน แต่ Monzo พบว่าการเปลี่ยนผ่านเป็นเรื่องง่ายด้วยการจัดทำเอกสารกฎ Keep อย่างเหมาะสม "เราเพิ่มความคิดเห็นเพื่ออธิบายเหตุผลที่ใช้กฎ Keep เสมอ เพื่อให้ทราบว่าเมื่อใดที่สามารถนำกฎออกได้อย่างปลอดภัย" Neumayer กล่าว

คำแนะนำของ Neumayer สำหรับทีมอื่นๆ ตรวจสอบแนวทางปฏิบัติของคุณเทียบกับมาตรฐานปัจจุบันเป็นประจำ "ดูคำแนะนำล่าสุดจาก Google เกี่ยวกับประสิทธิภาพของแอป และตรวจสอบว่าคุณปฏิบัติตามคำแนะนำล่าสุดทั้งหมดหรือไม่"

หากต้องการเริ่มต้นใช้งานและดูข้อมูลเพิ่มเติมเกี่ยวกับ R8 โปรดไปที่ https://d.android.com/r8

เขียนโดย

อ่านต่อ