Cách Disney+ Hotstar tăng 100% lượt xem thẻ hằng tuần trên các thiết bị trong phòng khách nhờ giảm INP xuống 61%

Việc cải thiện Khả năng tương tác với Next Paint (INP) trên TV thông minh và các thiết bị hộp giải mã tín hiệu số có nhiều thách thức hơn nhiều so với trình duyệt dành cho máy tính, do các hạn chế về hỗ trợ API còn hạn chế và thông số kỹ thuật hệ thống khiêm tốn. Trong nghiên cứu điển hình này, bạn sẽ tìm hiểu cách Disney+ Hotstar giải quyết thành công những trở ngại này và nhờ đó thu được những lợi ích kinh doanh đáng kể.

Bhuvaneswaran Mohan
Bhuvaneswaran Mohan
Saurabh Rajpal
Saurabh Rajpal

Khi ngày càng có nhiều thiết bị dành cho phòng khách được sử dụng, Disney+ Hotstar nhận thấy rằng việc cung cấp trải nghiệm duyệt web liền mạch trong ứng dụng dành cho TV thông minh và hộp giải mã tín hiệu số là một yêu cầu quan trọng của doanh nghiệp. Tuy nhiên, điều khiến việc khắc phục INP khó hơn cho các thiết bị như vậy là bất kỳ mẫu TV nào cũng có thể sử dụng các phiên bản trình duyệt rất cũ. Ví dụ: TV LG năm 2020 sử dụng Chrome 68 ra mắt năm 2018. Một số thiết bị trong số này cũng có thể được phân loại là thiết bị cấp thấp, nghĩa là chúng không thể phản hồi các tương tác nhanh như máy tính bảng và máy tính xách tay hàng đầu.

Hình sau đây so sánh thời gian tải một trang, giữa máy tính xách tay và CPU bị chậm lại 6 lần áp dụng trong Công cụ của Chrome cho nhà phát triển và TV thông minh. Có thể thấy, máy tính xách tay vẫn nhanh hơn nhiều so với TV thông minh được sản xuất gần đây.

Ảnh chụp màn hình trình phân tích hiệu suất trong Công cụ của Chrome cho nhà phát triển cho thấy hiệu suất tải của ứng dụng Disney+ HotStar trên máy tính xách tay. Chỉ số tùy chỉnh có tên PAGE_RENDER_TIME xuất hiện tại thời điểm 1,39 giây.
Phân tích tài nguyên (thời gian hiển thị trang 1,3 giây) trên máy tính xách tay có tốc độ giảm CPU gấp 6 lần để mô phỏng cấu hình trình duyệt TV. PAGE_RENDER_TIME là một chỉ số tuỳ chỉnh được dùng để nắm bắt khoảng thời gian từ khi hiển thị thành phần đầu tiên của trang đến khi hoàn tất quá trình phân tích cú pháp HTML.
Ảnh chụp màn hình trình phân tích hiệu suất trong Công cụ của Chrome cho nhà phát triển, phân tích hiệu suất tải của ứng dụng Disney+ HotStar trên một thiết bị TV thông minh thực tế. Chỉ số tuỳ chỉnh có tên PAGE_RENDER_TIME xuất hiện ở thời điểm 6,47 giây.
Phân tích tài nguyên (hiển thị trang 6,47 giây) từ TV thực tế bằng cách sử dụng tính năng gỡ lỗi từ xa bằng ứng dụng TV chạy trong Chrome.

Mặc dù các thử nghiệm này mang lại dữ liệu phòng thí nghiệm, nhưng Disney+ Hotstar đã bắt đầu thu thập dữ liệu thực tế về Lượt tương tác với Sơn tiếp theo (INP) qua người dùng thực tế của ứng dụng thông qua thư viện web-vitals và quan sát thấy 75% người dùng ứng dụng gặp phải INP là 675 mili giây trong thực tế. Đây được coi là trải nghiệm người dùng "kém" theo ngưỡng INP.

Nghiên cứu điển hình này đề cập đến cách Disney+ Hotstar cải thiện khả năng phản hồi trong các ứng dụng phát trực tuyến của họ, đặc biệt là trên các thiết bị cấp thấp. Cải thiện 61% nhờ giảm giá trị INP xuống còn 272 mili giây – vẫn cao hơn ngưỡng "tốt" được đề xuất là 200 mili giây, nhưng là có sự cải thiện đáng kể.

Phát hiện

Disney+ Hotstar đã đo lường ứng dụng bằng phương thức onINP trong bản dựng phân bổ của thư viện web-vitals. Trong giai đoạn đầu, họ gặp phải nhiều thách thức, đặc biệt là trong việc xác định chính xác yếu tố mục tiêu. Vấn đề này phát sinh vì mọi tệp tham chiếu đều trỏ đến phần nội dung do sử dụng thư viện điều hướng không gian của bên thứ ba. Thư viện này được sử dụng cùng với một số tuỳ chỉnh trong ứng dụng Disney+ Hotstar. Thư viện này chỉ theo dõi các sự kiện trên nội dung tài liệu, sau đó xác định phần tử được lấy tiêu điểm thực sự và dự đoán tiêu điểm tiếp theo dựa trên các thao tác nhấn phím từ xa.

Trước tiên, Disney+ Hotstar sẽ giải quyết vấn đề phân bổ để xác định chính xác các hoạt động tương tác gây ra giá trị INP cao. Do đó, Disney+ Hotstar đã ghi lại thuộc tính focusKey đã có trong thư viện điều hướng không gian cho phần tử đang được lấy làm tâm điểm, cũng như bản đồ của tất cả các thành phần có thể làm tâm điểm trên trang, tương tự như mục tiêu tương tác có trong bản dựng phân bổ web- vitals.

Ảnh chụp màn hình danh sách các thành phần (theo thuộc tính focusKey) của các thành phần đó, cùng với độ trễ tương tác của từng thành phần.
Chụp focusKey, cùng với đường dẫn đến thành phần kích hoạt thành phần đó.

Hiện tại, khi đã áp dụng phương pháp đo lường và phân bổ thích hợp, các phát hiện từ dữ liệu thực địa đã báo cáo các hoạt động tương tác sau đây là vấn đề nhiều nhất đối với INP:

  1. Điều hướng khay băng chuyền theo chiều ngang.
  2. Điều hướng khay băng chuyền dọc.
  3. Hoạt động tương tác trong lần tải trang đầu tiên.
Ảnh chụp màn hình phần tử chịu trách nhiệm điều hướng băng chuyền khay bằng phím tiêu điểm.
Mục trên trang tổng quan cho thấy mức đóng góp cho INP bằng cách thao tác trên băng chuyền khay.

Sau khi lập hồ sơ các tương tác này với bảng điều khiển hiệu suất trong Công cụ dành cho nhà phát triển Chrome, tôi nhận thấy rằng thư viện điều hướng không gian đọc vị trí của tất cả các thành phần có thể làm tâm điểm và xây dựng một cây mới. Đây là một thao tác tốn kém kích hoạt tính năng đậm bố cục trên mỗi lần tương tác, chẳng hạn như di chuyển từ phần tử này sang phần tử khác.

Đối với trang chủ, thư viện điều hướng không gian đã tạo một cây như sau:

Một cây ví dụ do thư viện điều hướng không gian tạo. Bên dưới thư mục gốc là các nút Navbar và Tray Container. Cụ thể, nút Vùng chứa Khay chứa ba nút thẻ, mỗi nút có nhiều nút phụ góp phần tạo ra kích thước DOM lớn.
Cây điều hướng không gian trước đó cho trang chủ.

Điều này có nghĩa là, nếu ứng dụng hiển thị 10 khay và mỗi khay có 7 thẻ, thì sẽ có 70 phần tử có thể làm tâm điểm cho vùng chứa khay, bao gồm cả các mục điều hướng. Đây là số lượng lớn các phần tử tương tác. Thư viện băng chuyền của bên thứ ba cũng được sử dụng để đọc kích thước của từng thẻ trong khi điều hướng ngang để dịch vùng chứa, làm tăng độ trễ tương tác.

Khắc phục sự cố

Có một số vấn đề khác nhau mà tất cả đều phải được giải quyết riêng biệt để giải quyết các vấn đề về khả năng phản hồi của ứng dụng nói chung.

Cải tiến điều hướng khay ngang

Disney+ Hotstar đã tạo thư viện băng chuyền nội bộ của riêng mình mà không kích hoạt tình trạng đơ bố cục bằng cách sử dụng ảnh động kết hợp và đọc kích thước một lần trên mỗi khay, thay vì một lần cho mỗi thẻ.

Điều hướng không gian chỉ tập trung vào gốc của băng chuyền và để điều hướng theo chiều ngang hơn nữa, băng chuyền tùy chỉnh của chúng tôi sẽ xuất hiện trong hình ảnh. Với cách tiếp cận này, Disney+ Hotstar đã loại bỏ phần phụ thuộc của điều hướng không gian và thư viện băng chuyền cũ dùng để đọc kích thước trên mọi thành phần điều hướng.

Đây là giao diện cây điều hướng không gian sau khi thực hiện những tối ưu hoá này.

Một ví dụ về cây được tối ưu hoá do thư viện điều hướng không gian tạo ra, được tối ưu hoá đáng kể so với phiên bản trước, chứa ít nút hơn nhiều.
Cây điều hướng không gian sau khi tối ưu hoá.

Các hình ảnh sau đây là dữ liệu so sánh hiệu suất được đo lường trong bảng hiệu suất của Công cụ của Chrome cho nhà phát triển trước và sau khi chúng tôi triển khai băng chuyền.

Ảnh chụp màn hình bảng hiệu suất trong Công cụ của Chrome cho nhà phát triển cho các tác vụ mà băng chuyền của bên thứ ba bắt đầu. Có nhiều tác vụ mất nhiều thời gian làm chậm trễ khả năng tương tác.
Băng chuyền của bên thứ ba.
Ảnh chụp màn hình về bảng hiệu suất trong Công cụ của Chrome cho nhà phát triển cho các nhiệm vụ mà băng chuyền nội bộ bắt đầu. So với băng chuyền của bên thứ ba, có ít nhiệm vụ dài hơn nhiều, cho phép tương tác diễn ra nhanh hơn.
Băng chuyền nội bộ.

Kết quả của công việc này là Disney+ Hotstar nhận thấy sự sụt giảm đáng kể về INP của ứng dụng trong lĩnh vực này. Họ cũng tiết kiệm được khoảng 35 KB (nén) bằng cách xoá thư viện của bên thứ ba. Ngoài ra, những điểm cải tiến này cũng cho phép Disney+ Hotstar giảm thời lượng của chỉ số tuỳ chỉnh mà họ sử dụng để đo tổng thời gian hiển thị cho trang chủ, vì các bố cục được kích hoạt ít thường xuyên hơn do các nút điều hướng không gian bị giảm.

Một chuỗi thời gian của chỉ số tùy chỉnh thời gian hiển thị trang cho cả tizentv và webos, với mức giảm lần lượt là 31% và 25,2%, bắt đầu từ khung thời gian ngày 13 tháng 3 đến ngày 19 tháng 3.
Xu hướng giảm về thời gian hiển thị trang tính theo hệ điều hành TV (Samsung-Tizen và WebOS-LG).

Cải tiến điều hướng khay dọc

Disney+ Hotstar cũng cải thiện hiệu suất điều hướng khay dọc bằng cách tải từng phần các khay thay vì tải tất cả các khay lên trước. Vì vậy, khi tải trang, thay vì tải 10 phiên bản của khay (bên trong, mỗi khay có một thành phần băng chuyền và một loạt hình ảnh), ứng dụng chỉ tải hai khay hiển thị trong khung nhìn, cùng với một khay bổ sung ở phía trên và phía dưới. Quá trình kết xuất cũng được chia thành nhiều tác vụ bằng cách sử dụng chiến lược lợi nhuận setTimeout() để luồng chính có nhiều cơ hội xử lý tương tác của người dùng hơn.

Hình ảnh cách điệu về các tác vụ để chạy trình xử lý sự kiện và hiển thị nội dung cập nhật. Quá trình cập nhật kết xuất bị trì hoãn sau một tác vụ dài.
Một tác vụ chạy trong thời gian dài, sau đó kết xuất trước khi cải tiến khay dọc.
Một hình ảnh khác về cùng một hoạt động như hình trước, nhưng các tác vụ bị chia nhỏ do hiệu suất, cho phép quá trình kết xuất diễn ra sớm hơn.
Nhiều tác vụ chia tách sau khi cải tiến khay dọc, với cơ hội kết xuất giữa các tác vụ chia tách.

Tương tác trong khi tải trang ban đầu

INP sẽ cao đối với những ứng dụng xử lý một số lượng lớn tập lệnh trong khi khởi chạy ứng dụng. Điều này là do trình duyệt phải tải xuống, phân tích cú pháp và đánh giá các tập lệnh đó. Mặc dù tất cả điều này xảy ra, nhưng luồng chính sẽ có thể bị chiếm một thời gian dài và không thể phản hồi nhanh các tương tác của người dùng.

Disney+ Hotstar nhận thấy rằng họ đang xử lý nhiều tập lệnh hơn mức thực sự cần thiết trong quá trình khởi động ứng dụng (thời gian màn hình chờ) để giúp các trang sau này tải nhanh hơn. Việc này phát sinh thêm các tác vụ đánh giá tập lệnh và có khả năng ảnh hưởng tiêu cực đến INP.

Để khắc phục vấn đề này, Disney+ Hotstar cân nhắc việc tải động hầu hết các thành phần để tiết kiệm thời gian trong quá trình khởi động ứng dụng. Tuy nhiên, làm như vậy sẽ làm tăng thời gian tải cho các thao tác điều hướng tới các trang trong tương lai, vì JavaScript đó sẽ không còn được tải trước cùng với thay đổi này nữa. Để giải quyết vấn đề này, Disney+ Hotstar đã phát triển một thư viện trình tải trước thành phần nội bộ để xác định trang nào có thể xuất hiện tiếp theo trong hành trình của người dùng và sẽ tải trước các thành phần cho trang đó. Ví dụ:

  • Khi người dùng ở trên trang đăng nhập, thư viện trình tải trước thành phần sẽ tải trước các thành phần cho trang chọn hồ sơ.
  • Trên trang chọn hồ sơ, các nội dung trang chủ sẽ được tải.
  • Trên trang chủ, nội dung của trang chi tiết sẽ được tải.
  • Cuối cùng, nội dung của trang xem được tải trên trang chi tiết.

Việc tối ưu hoá việc tải thành phần đã giúp Disney+ Hotstar thực hiện hai điều: giảm INP của ứng dụng (vì luồng chính hiện tương đối tự do để thực thi tương tác của người dùng) và cũng giảm mức sử dụng bộ nhớ trên các thiết bị cấp thấp.

Những thay đổi này đã giúp giảm 32% số INP được báo cáo từ trường như trong ảnh chụp màn hình dưới đây.

Chuỗi thời gian của giá trị INP bắt đầu từ ngày 13 tháng 8 đến ngày 11 tháng 9. Trong khoảng thời gian này, INP giảm 32%.
Giảm INP để cải tiến khay.

Các cải tiến khác:

Disney+ Hotstar cũng nhận thấy có nhiều tác vụ dài đối với một số sự kiện người dùng, có thể được chia tách bằng cách thường xuyên chuyển sang chuỗi chính. Do vậy, họ tiến thêm một bước bằng cách tạo ra một tiện ích trình tạo tác vụ cho phép người dùng huỷ tác vụ đó giữa quá trình thực thi.

Ví dụ: khi người dùng điều hướng qua nhiều thẻ trên khay, những điều sau đây sẽ xảy ra:

  • Thẻ tiếp theo được lấy tiêu điểm.
  • Thẻ được dịch nếu cần.
  • Tiêu điểm đã được cập nhật.
  • Hệ thống sẽ tìm nạp đoạn giới thiệu (nếu có) và bắt đầu phát.
  • Sự kiện Analytics được kích hoạt cho hành động đó.

Nếu trong quá trình này, người dùng tập trung vào thẻ tiếp theo, thì các bước còn lại sẽ không cần được thực thi. Ví dụ: việc tìm nạp đoạn giới thiệu và khởi chạy trình phát cho một bộ phim/chương trình cụ thể sẽ không cần thiết nữa nếu người dùng đã chuyển sang thẻ tiếp theo. Do đó, bạn có thể huỷ những tác vụ đó để giải phóng luồng chính.

Tiện ích trình tạo tác vụ của Disney+ Hotstar chấp nhận một hàm là một tác vụ. Khi một tác vụ khác xuất hiện ở giữa, tác vụ trước đó sẽ bị huỷ để giúp chúng ta thực thi tác vụ không cần thiết và nhanh chóng thực hiện tác vụ cần thiết.

Kết quả

Nhìn chung, INP của ứng dụng Disney+ Hotstar giảm từ 675 mili giây xuống còn 272 mili giây, cải thiện gần 60%! Ngoài ra, độ trễ tương tác khay cụ thể giảm từ khoảng 400 mili giây xuống còn khoảng 100 mili giây.

Giá trị INP theo chuỗi thời gian bắt đầu từ ngày 23 tháng 8 đến ngày 21 tháng 9. Giảm 61% INP trong khung thời gian này.

Tác động đối với hoạt động kinh doanh: số lượt xem thẻ hàng tuần đã tăng từ 111 lên 226 trên mỗi người dùng! Tăng 100%, cho thấy giao diện nhanh hơn và thích ứng hơn có nhiều khả năng thu hút người dùng hơn trong khoảng thời gian dài hơn.

Ảnh chụp màn hình một chuỗi thời gian cho thấy số lượt xem thẻ hằng tuần trên ứng dụng Disney+ HotStar tăng 100% cho cả tizentv và webos. Mức tăng này xảy ra rất mạnh sau ngày 4/4/2004.

Đây mới chỉ là khởi đầu và Disney+ Hotstar chỉ mới xây dựng được bề mặt trong việc cải thiện hiệu suất kết xuất và tương tác dựa trên chỉ số INP. Ngoài ra, nhóm của họ rất háo hức muốn biến Disney+ Hotstar trở thành trải nghiệm mượt mà cho khách hàng trong tương lai gần.

Nhờ những nỗ lực của Ayush, Ajay, Kiran, Milan và Richa từ Disney+ Hotstar vì những nỗ lực của họ đã lật ngược tình thế.

Xin đặc biệt cảm ơn Ankeet Maini, Trưởng bộ phận kỹ thuật Disney+ Hotstar và Rahul Krishnan P, Trưởng bộ phận Trải nghiệm khách hàng Disney+ Hotstar, nhằm hỗ trợ cho công việc đổi mới này, cũng như cảm ơn Jeremy Wagner, Gilberto, Barry Pollard và Brendan Kenny của Google vì đã xem xét và giúp xuất bản nghiên cứu điển hình này.