Tối ưu hoá LCP bằng cơ chế trao đổi có chữ ký

Cách đo lường và tối ưu hoá cơ chế trao đổi có chữ ký để cải thiện tối đa cơ chế trao đổi có chữ ký

Devin Mullins
Devin Mullins

Cơ chế trao đổi có chữ ký (SXG) là một phương thức giúp cải thiện tốc độ trang, chủ yếu là Nội dung lớn nhất hiển thị (LCP). Khi tham chiếu các trang web (hiện là Google Tìm kiếm) liên kết đến một trang, chúng có thể tìm nạp trước liên kết đó vào bộ nhớ đệm của trình duyệt trước khi người dùng nhấp vào liên kết.

Bạn có thể làm cho các trang web mà khi được tìm nạp trước sẽ không yêu cầu mạng trên đường dẫn quan trọng để hiển thị trang! Trên kết nối 4G, quá trình tải trang này mất từ 2,8 giây đến 0,9 giây (0,9 giây còn lại chủ yếu là theo mức sử dụng CPU):

Hầu hết những người phát hành SXG hiện nay đều sử dụng tính năng Tự động trao đổi có chữ ký (ASX) dễ sử dụng của Cloudflare (mặc dù có các tuỳ chọn nguồn mở):

Bảng điều khiển cài đặt Cloudflare có hộp đánh dấu để bật tính năng Trao đổi có chữ ký tự động

Trong nhiều trường hợp, việc chọn hộp bật tính năng này là đủ để nhận được loại cải thiện đáng kể nêu trên. Đôi khi, có thêm một vài bước để đảm bảo các SXG này hoạt động như dự kiến ở mỗi giai đoạn của quy trình và tối ưu hoá các trang để khai thác tối đa chức năng tìm nạp trước.

Trong vài tháng qua kể từ khi Cloudflare ra mắt, tôi đã đọc và trả lời câu hỏi trên nhiều diễn đàn, đồng thời tìm hiểu cách tư vấn cho các trang web về cách đảm bảo rằng họ khai thác tối đa việc triển khai SXG. Bài đăng này là tuyển tập lời khuyên của tôi. Tôi sẽ hướng dẫn bạn các bước để:

Giới thiệu

SXG là một tệp chứa URL, một nhóm tiêu đề phản hồi HTTP và nội dung phản hồi – tất cả đều được ký mã hoá bằng một chứng chỉ PKI trên web. Khi tải một SXG, trình duyệt sẽ xác minh tất cả những yếu tố sau:

  • SXG chưa hết hạn.
  • Chữ ký này khớp với URL, tiêu đề, nội dung và chứng chỉ.
  • Chứng chỉ hợp lệ và khớp với URL.

Nếu quá trình xác minh không thành công, trình duyệt sẽ bỏ qua SXG và thay vào đó sẽ tìm nạp URL đã ký. Nếu xác minh thành công thì trình duyệt sẽ tải phản hồi đã ký, coi như phản hồi đó đến trực tiếp từ URL đã ký. Cơ chế này cho phép lưu trữ lại SXG trên bất kỳ máy chủ nào, miễn là SXG chưa hết hạn hoặc bị sửa đổi kể từ khi được ký.

Đối với Google Tìm kiếm, SXG cho phép tìm nạp trước các trang trong kết quả tìm kiếm. Đối với các trang hỗ trợ SXG, Google Tìm kiếm có thể tìm nạp trước bản sao của trang được lưu trong bộ nhớ đệm, được lưu trữ trên webpkgcache.com. Các URL webpkgcache.com này không ảnh hưởng đến việc hiển thị hoặc hoạt động của trang vì trình duyệt tuân theo URL gốc, đã được ký. Tìm nạp trước có thể cho phép trang của bạn tải nhanh hơn nhiều.

Phân tích

Để thấy được lợi ích của SXG, hãy bắt đầu bằng cách dùng một công cụ trong phòng thí nghiệm để phân tích hiệu suất của SXG trong các điều kiện lặp lại. Bạn có thể sử dụng WebPageTest để so sánh thác nước (và LCP) khi có và không có tính năng tìm nạp trước SXG.

Tạo một kiểm thử mà không cần SXG như sau:

  • Chuyển đến WebPageTest rồi đăng nhập. Việc đăng nhập sẽ lưu nhật ký kiểm tra của bạn để dễ dàng so sánh sau này.
  • Nhập URL mà bạn muốn kiểm tra.
  • Chuyển đến phần Cấu hình nâng cao. (Bạn sẽ cần có Cấu hình nâng cao để kiểm thử SXG. Vì vậy, việc sử dụng cấu hình này tại đây sẽ giúp đảm bảo các lựa chọn kiểm thử là giống nhau.)
  • Trong thẻ Test Settings (Cài đặt kiểm thử), bạn nên đặt kết nối thành 4G và tăng "Số lượt kiểm thử cần chạy" đến 7.
  • Nhấp vào Bắt đầu kiểm tra.

Tạo một bản kiểm thử bằng SXG bằng cách làm theo các bước trên. Tuy nhiên, trước khi nhấp vào Start Test, hãy chuyển đến thẻ Script (Tập lệnh), dán vào tập lệnh WebPageTest sau đây rồi sửa đổi 2 URL navigate theo hướng dẫn:

// Disable log collection for the first step. We only want the waterfall for the target navigation.
logData 0

// Visit a search result page that includes your page.
navigate https://google.com/search?q=site%3Asigned-exchange-testing.dev+image

// Wait for the prefetch to succeed.
sleep 10

// Re-enable log collection.
logData 1

// Navigate to the prefetched SXG on the Google SXG Cache.
navigate https://signed--exchange--testing-dev.webpkgcache.com/doc/-/s/signed-exchange-testing.dev/sxgs/valid-image-subresource.html

Đối với URL navigate đầu tiên, nếu trang của bạn chưa xuất hiện trong kết quả nào trên Google Tìm kiếm thì bạn có thể sử dụng trang tìm nạp trước này để tạo một trang kết quả tìm kiếm giả cho mục đích này.

Để xác định URL navigate thứ hai, hãy truy cập vào trang của bạn bằng tiện ích Trình xác thực SXG của Chrome, rồi nhấp vào biểu tượng tiện ích để xem URL bộ nhớ đệm:

Trình xác thực SXG hiển thị thông tin bộ nhớ đệm, bao gồm cả URL

Sau khi các bài kiểm thử này hoàn tất, hãy chuyển đến phần Nhật ký kiểm thử, chọn hai bài kiểm thử rồi nhấp vào So sánh:

Nhật ký kiểm tra, trong đó có 2 bài kiểm thử được đánh dấu và nút So sánh được làm nổi bật

Thêm &medianMetric=LCP vào URL so sánh để WebPageTest chọn chạy với LCP trung bình cho mỗi bên của phép so sánh. (Giá trị mặc định là trung vị theo Chỉ số tốc độ.)

Để so sánh các thác nước, hãy mở rộng phần Độ mờ của thác nước rồi kéo thanh trượt. Để xem video, hãy nhấp vào Điều chỉnh chế độ cài đặt Cuộn phim, di chuyển xuống bên trong hộp thoại đó rồi nhấp vào Xem video.

Nếu quá trình tìm nạp trước SXG thành công, bạn sẽ thấy lượt "có SXG" thác nước không bao gồm một hàng cho HTML và quá trình tìm nạp cho các tài nguyên phụ sẽ bắt đầu sớm hơn. Ví dụ: so sánh "Trước" và "Sau" tại đây:

Thác nước trên mạng mà không tìm nạp trước SXG; hàng đầu tiên là tìm nạp HTML mất 1050 mili giây Thác nước trên mạng có tìm nạp trước SXG; HTML đã được tìm nạp trước, cho phép tất cả các tài nguyên phụ bắt đầu tìm nạp sớm hơn 1050 mili giây

Gỡ lỗi

Nếu WebPageTest cho thấy SXG đang được tìm nạp trước, thì tức là công cụ này đã thành công ở tất cả các bước của quy trình; bạn có thể bỏ qua phần Tối ưu hoá để tìm hiểu cách cải thiện thêm LCP. Nếu không, bạn sẽ cần tìm hiểu xem lỗi ở đâu trong quy trình và tại sao; hãy đọc tiếp để tìm hiểu cách thực hiện.

Xuất bản

Đảm bảo các trang của bạn đang được tạo dưới dạng SXG. Để thực hiện việc này, bạn cần phải giả mạo trình thu thập dữ liệu. Cách dễ nhất là sử dụng tiện ích Trình xác thực SXG của Chrome:

Trình xác thực SXG hiển thị một dấu kiểm (✅) và Content Type of application/signed-Exchange;v=b3

Tiện ích này sẽ tìm nạp URL hiện tại bằng tiêu đề yêu cầu Accept cho biết tiện ích này ưu tiên phiên bản SXG. Nếu bạn thấy dấu kiểm (✅) bên cạnh nguồn gốc, tức là ứng dụng đã trả về một SXG; bạn có thể chuyển đến phần Lập chỉ mục.

Nếu bạn thấy dấu chéo (❌), điều đó có nghĩa là SXG không được trả về:

Trình xác thực SXG hiển thị một dấu chéo (❌) và Loại nội dung là văn bản/html

Nếu Cloudflare ASX được bật, thì lý do có thể nhất dẫn đến dấu chéo (❌) là do tiêu đề phản hồi kiểm soát bộ nhớ đệm ngăn chặn điều này. ASX xem xét các tiêu đề có tên sau:

  • Cache-Control
  • CDN-Cache-Control
  • Surrogate-Control
  • Cloudflare-CDN-Cache-Control

Nếu bất kỳ tiêu đề nào trong số này chứa các giá trị tiêu đề sau đây, thì tiêu đề đó sẽ ngăn việc tạo SXG:

  • private
  • no-store
  • no-cache
  • max-age nhỏ hơn 120, trừ phi bị s-maxage ghi đè lớn hơn hoặc bằng 120

ASX không tạo SXG trong những trường hợp này vì SXG có thể được lưu vào bộ nhớ đệm và sử dụng lại cho nhiều lượt truy cập và nhiều khách truy cập.

Một lý do khác có thể gây ra dấu chéo (❌) là sự hiện diện của một trong các tiêu đề phản hồi có trạng thái này, ngoại trừ Set-Cookie. ASX xoá tiêu đề Set-Cookie để tuân thủ thông số kỹ thuật của SXG.

Một lý do khác có thể là sự có mặt của tiêu đề phản hồi Vary: Cookie. Googlebot tìm nạp các SXG mà không cần thông tin xác thực của người dùng và có thể phân phát các phiên bản này cho nhiều khách truy cập. Nếu bạn phân phát HTML khác nhau cho những người dùng khác nhau dựa trên cookie của họ, thì họ có thể thấy trải nghiệm không chính xác, chẳng hạn như chế độ xem đã đăng xuất.

Ngoài tiện ích của Chrome, bạn có thể dùng một công cụ như curl:

curl -siH "Accept: application/signed-exchange;v=b3" $URL | less

hoặc dump-signedexchange:

dump-signedexchange -verify -uri $URL

Nếu SXG được cung cấp và hợp lệ, bạn sẽ thấy một bản in mà con người có thể đọc được của SXG. Nếu không, bạn sẽ thấy một thông báo lỗi.

Lập chỉ mục

Đảm bảo rằng Google Tìm kiếm đã lập chỉ mục thành công SXG của bạn. Mở Công cụ của Chrome cho nhà phát triển, sau đó tìm kiếm trang của bạn trên Google. Nếu trang đó đã được lập chỉ mục là một SXG, thì đường liên kết của Google tới trang của bạn sẽ bao gồm data-sxg-url trỏ đến bản sao của webpkgcache.com:

Kết quả tìm kiếm trên Google với Công cụ cho nhà phát triển hiển thị một thẻ liên kết trỏ đến webpkgcache.com

Nếu cho rằng người dùng có thể sẽ nhấp vào kết quả đó, Google Tìm kiếm sẽ tìm nạp trước kết quả đó:

Kết quả tìm kiếm trên Google trong Công cụ cho nhà phát triển hiển thị đường liên kết có rel=Lượt tìm nạp trước cho webpkgcache.com

Phần tử <link> hướng dẫn trình duyệt tải SXG xuống vào bộ nhớ đệm tìm nạp trước. Khi người dùng nhấp vào phần tử <a>, trình duyệt sẽ sử dụng tiện ích SXG đã lưu vào bộ nhớ đệm để kết xuất trang.

Bạn cũng có thể xem bằng chứng về quá trình tìm nạp trước bằng cách chuyển đến thẻ Mạng trong Công cụ cho nhà phát triển rồi tìm các URL có chứa webpkgcache.

Nếu <a> trỏ đến webpkgcache.com, thì tức là hệ thống lập chỉ mục của Google Tìm kiếm cho giao thức trao đổi có chữ ký này đang hoạt động. Bạn có thể chuyển tới phần Truyền dẫn.

Nếu không, có thể là Google chưa thu thập lại dữ liệu trên trang của bạn kể từ khi bạn bật SXG. Dùng thử Công cụ kiểm tra URL của Google Search Console:

Công cụ kiểm tra URL của Search Console, nhấp vào Xem trang đã thu thập thông tin rồi nhấp vào Thông tin khác

Việc có tiêu đề digest: mi-sha256-03=... cho biết rằng Google đã thu thập dữ liệu thành công phiên bản SXG.

Nếu không có tiêu đề digest, thì đây có thể là dấu hiệu cho thấy SXG không được phân phát cho Googlebot hoặc chỉ mục chưa được cập nhật kể từ khi bạn bật SXG.

Nếu một SXG được thu thập dữ liệu thành công nhưng vẫn không được liên kết với SXG nào đó có thể là do không đáp ứng được các yêu cầu về bộ nhớ đệm của SXG. Những điều này được đề cập trong phần tiếp theo.

Nhập

Khi lập chỉ mục một SXG nào đó, Google Tìm kiếm sẽ gửi bản sao của nó đến bộ nhớ đệm SXG của Google. Bộ nhớ đệm này sẽ xác thực SXG theo các yêu cầu về bộ nhớ đệm. Tiện ích của Chrome hiển thị kết quả:

Trình xác thực SXG hiển thị một dấu kiểm (✅) và không có thông báo cảnh báo

Nếu thấy dấu kiểm (✅), thì bạn có thể bỏ qua để chuyển đến mục Tối ưu hóa.

Nếu ứng dụng không đáp ứng yêu cầu, bạn sẽ thấy một dấu x (❌) và một thông báo cảnh báo cho biết lý do:

Trình xác thực SXG hiển thị một dấu chéo (❌) và một thông báo cảnh báo cho biết

Trong trường hợp này, trang sẽ hoạt động như trước khi bật SXG. Google sẽ liên kết đến trang đó trên máy chủ lưu trữ ban đầu mà không cần tìm nạp trước SXG.

Trong trường hợp bản sao được lưu vào bộ nhớ đệm đã hết hạn và đang được tìm nạp lại trong nền, bạn sẽ thấy biểu tượng đồng hồ cát (⌛):

Trình xác thực SXG hiển thị đồng hồ cát (⌛) và không có thông báo cảnh báo

Tài liệu dành cho nhà phát triển của Google trên SXG cũng có hướng dẫn truy vấn bộ nhớ đệm theo cách thủ công.

Tối ưu hoá

Nếu tiện ích SXG của Chrome hiển thị tất cả dấu kiểm (✅), thì tức là bạn có một SXG có thể phân phát cho người dùng! Hãy đọc tiếp để tìm hiểu cách tối ưu hoá trang web nhằm giúp bạn cải thiện LCP nhất nhờ SXG.

độ tuổi tối đa

Khi SXG hết hạn, bộ nhớ đệm SXG của Google sẽ tìm nạp một bản sao mới ở chế độ nền. Trong khi chờ lần tìm nạp đó, người dùng sẽ được chuyển hướng đến trang trên máy chủ lưu trữ ban đầu. Trang này chưa được tìm nạp trước. Bạn đặt Cache-Control: max-age càng lâu thì quá trình tìm nạp trong nền này càng ít xảy ra và do đó, LCP càng thường xuyên bị giảm bởi quá trình tìm nạp trước.

Đây là sự cân bằng giữa hiệu suất và độ mới. Bộ nhớ đệm cho phép chủ sở hữu trang web cung cấp SXG tối đa ở bất cứ đâu trong khoảng từ 2 phút đến 7 ngày, để phù hợp với nhu cầu cụ thể của từng trang. Chúng tôi nhận thấy rằng:

  • max-age=86400 (1 ngày) trở lên mang lại hiệu suất tốt
  • max-age=120 (2 phút) không

Chúng tôi hy vọng có thể tìm hiểu thêm về các giá trị giữa hai chỉ số này trong quá trình nghiên cứu dữ liệu nhiều hơn.

user-agent

Có lần tôi thấy LCP tăng khi dùng một SXG được tìm nạp trước. Tôi đã chạy công cụ WebPageTest, so sánh kết quả trung vị mà không sử dụng và với tính năng tìm nạp trước SXG. Nhấp vào Sau bên dưới:

Thác nước trên mạng không có tìm nạp trước SXG; LCP là 2 giây Thác nước trên mạng có tìm nạp trước SXG; HTML đã được tìm nạp trước, cho phép tất cả các tài nguyên phụ bắt đầu tìm nạp sớm hơn 800 mili giây, nhưng LCP là 2,1 giây

Tôi thấy quá trình tìm nạp trước đang hoạt động. HTML bị xoá khỏi đường dẫn quan trọng, do đó, tất cả các tài nguyên phụ đều có thể tải sớm hơn. Tuy nhiên, LCP (đường nét đứt màu xanh lục) tăng từ 2 giây lên 2,1 giây.

Để chẩn đoán vấn đề này, tôi đã xem xét các cuộn phim. Tôi nhận thấy trang hiển thị theo cách khác trong SXG. Trong HTML thuần tuý, Chrome đã xác định rằng "phần tử lớn nhất" đối với LCP là dòng tiêu đề. Tuy nhiên, trong phiên bản SXG, trang này đã thêm một biểu ngữ tải từng phần, đẩy dòng tiêu đề xuống dưới màn hình đầu tiên và khiến thành phần mới lớn nhất trở thành hộp thoại đồng ý sử dụng cookie được tải từng phần. Mọi thứ hiển thị nhanh hơn trước, nhưng thay đổi về bố cục khiến chỉ số báo cáo là chậm hơn.

Tôi đã đào sâu hơn và phát hiện nguyên nhân dẫn đến sự khác biệt về bố cục là do trang thay đổi theo User-Agent và đã xảy ra lỗi trong logic. Chiến dịch này phân phát một trang dành cho máy tính, mặc dù tiêu đề thu thập dữ liệu SXG cho biết thiết bị di động. Sau khi vấn đề này được khắc phục, trình duyệt đã xác định chính xác dòng tiêu đề của trang là phần tử lớn nhất của nó.

Bây giờ, khi nhấp vào "Sau", tôi thấy rằng LCP được tìm nạp trước giảm xuống còn 1,3 giây:

Thác nước trên mạng không có tìm nạp trước SXG; LCP là 2 giây Thác nước trên mạng có tìm nạp trước SXG; LCP là 1,3 giây

Cơ chế SXG được hỗ trợ cho mọi kiểu dáng thiết bị. Để chuẩn bị cho việc đó, hãy đảm bảo bạn đáp ứng một trong các yêu cầu sau:

Tài nguyên phụ

Có thể sử dụng SXG để tìm nạp trước các tài nguyên phụ (bao gồm cả hình ảnh) cùng với HTML. Cloudflare ASX sẽ quét HTML để tìm các phần tử <link rel=preload> có cùng nguồn gốc (bên thứ nhất) và chuyển đổi chúng thành các tiêu đề của Đường liên kết tương thích với SXG. Thông tin chi tiết trong mã nguồn tại đâytại đây.

Nếu mã này hoạt động, bạn sẽ thấy các lượt tìm nạp trước khác từ Google Tìm kiếm:

Kết quả tìm kiếm trên Google có thẻ Mạng Công cụ cho nhà phát triển, cho thấy quá trình tìm nạp trước /sub/.../image.jpg

Để tối ưu hoá LCP, hãy xem xét kỹ thác nước của bạn và xác định những tài nguyên nào trên lộ trình quan trọng để hiển thị phần tử lớn nhất. Nếu không thể tìm nạp trước các giá trị này, hãy cân nhắc xem có thể gỡ bỏ các giá trị này khỏi đường dẫn quan trọng hay không. Chú ý các tập lệnh ẩn trang cho đến khi tải xong.

Bộ nhớ đệm SXG của Google cho phép tải trước tối đa 20 tài nguyên phụ, và ASX đảm bảo rằng giới hạn này không vượt quá. Tuy nhiên, bạn sẽ gặp rủi ro khi thêm quá nhiều lượt tải trước tài nguyên phụ. Trình duyệt sẽ chỉ sử dụng các tài nguyên phụ được tải trước nếu tất cả các tài nguyên đó đã tìm nạp xong, để ngăn chặn hoạt động theo dõi trên nhiều trang web. Càng có nhiều tài nguyên phụ thì càng có ít khả năng tất cả các nguồn phụ đó đã hoàn tất quá trình tìm nạp trước trước khi người dùng nhấp vào để đến trang của bạn.

Trình xác thực SXG hiện không kiểm tra các tài nguyên phụ; để gỡ lỗi, hãy sử dụng curl hoặc dump-signedexchange trong thời gian chờ đợi.

Đo

Sau khi tối ưu hoá việc cải thiện LCP qua WebPageTest, bạn nên đo lường tác động của việc tìm nạp trước SXG đối với hiệu suất tổng thể của trang web.

Các chỉ số phía máy chủ

Khi đo lường các chỉ số phía máy chủ, chẳng hạn như Time to First Byte (TTFB), bạn cần lưu ý rằng trang web của bạn chỉ phân phát SXG cho những trình thu thập dữ liệu chấp nhận định dạng này. Chỉ đo lường TTFB ở các yêu cầu đến từ người dùng thực chứ không phải bot. Bạn có thể thấy rằng việc tạo SXG sẽ làm tăng TTFB cho các yêu cầu trình thu thập thông tin, nhưng điều này không ảnh hưởng đến lượt yêu cầu của khách truy cập của bạn.

Các chỉ số phía máy khách

SXG mang lại lợi ích lớn nhất về tốc độ cho các chỉ số phía máy khách, đặc biệt là LCP. Khi đo lường tác động của chúng, bạn chỉ cần bật Cloudflare ASX, chờ Googlebot thu thập lại dữ liệu, đợi thêm 28 ngày để tổng hợp Chỉ số quan trọng chính của trang web (CWV), rồi xem chỉ số CWV mới của bạn. Tuy nhiên, bạn có thể khó nhận ra sự thay đổi này khi kết hợp với tất cả những thay đổi khác trong khung thời gian này.

Thay vào đó, tôi thấy tính năng "Phóng to" sẽ hữu ích trên lượt tải trang có khả năng bị ảnh hưởng và cho rằng "SXG ảnh hưởng đến X% số lượt xem trang, cải thiện LCP thêm Y mili giây ở phân vị thứ 75".

Hiện tại, việc tìm nạp trước SXG chỉ diễn ra trong một số điều kiện nhất định:

  • Trình duyệt Chromium (ví dụ: Chrome hoặc Edge, ngoại trừ trên iOS), phiên bản M98 trở lên
  • Referer: google.com hoặc các miền tìm kiếm khác của Google. (Xin lưu ý rằng trong Google Analytics, thẻ giới thiệu áp dụng cho tất cả lượt xem trang trong phiên, trong khi tìm nạp trước SXG chỉ áp dụng cho lượt xem trang đầu tiên và được liên kết trực tiếp từ Google Tìm kiếm.)

Đọc mục Nghiên cứu đương thời để biết cách đo lường "X% lượt xem trang" và "cải thiện LCP thêm Y mili giây".

Nghiên cứu đương đại

Khi xem dữ liệu theo dõi người dùng thực (RUM), bạn nên chia lượt tải trang thành SXG và không phải SXG. Khi làm như vậy, bạn cần hạn chế tập hợp các lượt tải trang mà bạn xem xét, vì vậy, nhóm không phải SXG sẽ khớp với điều kiện tham gia SXG nhằm tránh thiên lệch lựa chọn. Nếu không, tất cả nội dung sau đây sẽ chỉ tồn tại trong nhóm lượt tải trang không phải SXG, vốn có thể có LCP khác nhau bẩm sinh:

  • Thiết bị iOS: do sự khác biệt về tốc độ phần cứng hoặc mạng giữa những người dùng sử dụng các thiết bị này.
  • Các trình duyệt Chromium cũ: vì lý do tương tự.
  • Thiết bị máy tính: vì cùng một lý do hoặc vì bố cục trang gây ra một "phần tử lớn nhất" khác để được chọn.
  • Các thao tác điều hướng trên cùng một trang web (khách truy cập đi theo các đường liên kết bên trong trang web): vì họ có thể sử dụng lại các tài nguyên phụ đã lưu vào bộ nhớ đệm của lần tải trang trước đó.

Trong Google Analytics (UA), hãy tạo 2 phương diện tuỳ chỉnh có phạm vi "Lượt truy cập", trong đó phương diện có tên là "isSXG" và một đường liên kết có tên là "đường liên kết giới thiệu". (Phương diện "Nguồn" tích hợp có phạm vi phiên hoạt động, nên không loại trừ các thao tác điều hướng trên cùng một trang web.)

Trình chỉnh sửa phương diện của Google Analytics với các chế độ cài đặt được đề xuất

Tạo một phân khúc tuỳ chỉnh có tên là "Phản thực của SXG" bằng các bộ lọc sau AND được kết hợp với nhau:

  • referrer bắt đầu bằng https://www.google.
  • Browser khớp chính xác với Chrome
  • Browser Phiên bản khớp với biểu thức chính quy ^(9[8-9]|[0-9]{3})
  • isSXG khớp chính xác với false
Trình chỉnh sửa phân đoạn của Google Analytics với các bộ lọc được đề xuất

Tạo một bản sao của phân khúc này, đặt tên là "SXG", ngoại trừ trường hợp isSXG khớp chính xác với true.

Trong mẫu trang web, hãy thêm đoạn mã sau vào phía trên đoạn mã Google Analytics. Đây là cú pháp đặc biệt mà ASX sẽ thay đổi false thành true khi tạo SXG:

<script data-issxg-var>window.isSXG=false</script>

Tuỳ chỉnh tập lệnh báo cáo Google Analytics theo đề xuất để ghi lại LCP. Nếu bạn đang sử dụng gtag.js, hãy sửa đổi lệnh 'config' để đặt phương diện tuỳ chỉnh (thay thế 'dimension1''dimension2' bằng tên mà Google Analytics sẽ sử dụng):

gtag('config', 'YOUR_TRACKING_ID', {
  'dimension1': String(isSXG),
  'dimension2': document.referrer,
});

Nếu bạn đang sử dụng analytics.js, hãy sửa đổi lệnh 'create' như được ghi tại đây.

Sau khi đợi vài ngày để thu thập một số dữ liệu, hãy chuyển đến báo cáo Sự kiện Google Analytics rồi thêm thông tin chi tiết cho phân khúc SXG. Mã này cần được điền vào X cho "SXG ảnh hưởng đến X% lượt xem trang":

Báo cáo Sự kiện Google Analytics có phân đoạn SXG, cho thấy tỷ lệ Số sự kiện riêng biệt là 12,5%

Cuối cùng, hãy chuyển đến Báo cáo chỉ số quan trọng về trang web, chọn "Chọn phân khúc" rồi chọn "Phản thực tế SXG" và "SXG".

Báo cáo các chỉ số quan trọng về trang web, trong đó có các lựa chọn cho nội dung phản thực tế và SXG của SXG

Nhấp vào "Gửi" và bạn sẽ thấy mức phân phối LCP cho hai phân đoạn. Thông tin này sẽ điền vào Y để "cải thiện LCP thêm Y mili giây ở phân vị thứ 75":

Báo cáo Chỉ số quan trọng của trang web cho thấy hoạt động phân phối LCP cho SXG phản thực tế và SXG

Chú ý

Sau khi bạn áp dụng tất cả các bộ lọc trên, lượt tải trang đối chứng SXG phải bao gồm những nội dung sau:

  • Thiếu bộ nhớ đệm: Nếu bộ nhớ đệm của Google SXG không có bản sao mới của SXG cho một URL nhất định, thì phiên bản này sẽ chuyển hướng đến URL gốc tại trang web của bạn.
  • Các loại kết quả khác: Hiện tại, Google Tìm kiếm chỉ hỗ trợ SXG cho kết quả tiêu chuẩn trên web và một vài loại khác. Một số loại khác, như Đoạn trích nổi bật và băng chuyền Tin bài hàng đầu, sẽ liên kết đến URL gốc trên trang web của bạn.
  • URL không đủ điều kiện: Nếu một số trang trên trang web của bạn không đủ điều kiện dùng SXG (chẳng hạn như không thể lưu vào bộ nhớ đệm), thì chúng có thể xuất hiện trong nhóm này.

Có thể còn tồn tại sai lệch giữa lượt tải trang SXG và lượt tải trang không dùng SXG ở trên. Tuy nhiên, độ sai lệch này phải nhỏ hơn mức độ sai lệch được đề cập ở đầu phần Nghiên cứu tạm thời. Ví dụ: có thể các trang không thể lưu vào bộ nhớ đệm chậm hơn hoặc nhanh hơn các trang có thể lưu vào bộ nhớ đệm. Nếu bạn nghi ngờ đây có thể là vấn đề, hãy cân nhắc xem xét dữ liệu chỉ dành cho một URL cụ thể đủ điều kiện sử dụng SXG để xem kết quả có khớp với nghiên cứu tổng thể hay không.

Nếu trang web của bạn có một số trang AMP, thì có thể trang web của bạn sẽ không thấy được những điểm cải thiện về hiệu suất khi bật SXG, vì chúng có thể đã được tìm nạp trước từ Google Tìm kiếm. Hãy cân nhắc thêm một bộ lọc để loại trừ những trang như vậy, để "phóng to" thêm về những thay đổi có liên quan.

Cuối cùng, ngay cả khi giải quyết mọi sai lệch lựa chọn, thì vẫn có nguy cơ thiên lệch sinh tồn khiến việc cải thiện LCP trông giống như sự suy giảm trong số liệu thống kê RUM. Bài viết này làm rất tốt việc giải thích rủi ro đó và đề xuất xem xét một số dạng chỉ số về tỷ lệ bỏ qua để phát hiện xem điều này có xảy ra hay không.

Trước/sau khi nghiên cứu

Để chứng thực kết quả của nghiên cứu hiện đại, bạn nên so sánh LCP trước và sau khi bật SXG. Đừng giới hạn ở lượt xem trang SXG, để loại bỏ những thiên kiến tiềm ẩn nêu trên. Thay vào đó, hãy xem các kết quả đủ điều kiện cho SXG. Bạn có thể xem các định nghĩa về phân khúc nêu trên nhưng không có quy tắc ràng buộc đối với isSXG.

Xin lưu ý rằng Google Tìm kiếm có thể mất đến vài tuần để thu thập lại dữ liệu của tất cả các trang trên trang web của bạn, nhằm xác định rằng bạn đã bật SXG. Trong vài tuần đó, có những thiên kiến tiềm ẩn khác có thể xảy ra:

  • Bản phát hành trình duyệt mới hoặc các điểm cải tiến về mặt người dùng có thể tăng tốc độ tải trang.
  • Một sự kiện quan trọng như ngày lễ có thể làm sai lệch lưu lượng truy cập so với bình thường.

Để xác nhận các nghiên cứu ở trên, bạn cũng nên xem xét tổng thể LCP thuộc phân vị thứ 75 trước và sau khi thay đổi. Việc tìm hiểu về một tập hợp con tổng thể không nhất thiết cho chúng ta biết về tổng dân số. Ví dụ: giả sử SXG cải thiện 10% số lượt tải trang thêm 800 mili giây.

  • Nếu đây là những lượt tải trang nhanh nhất đạt 10%, thì nó hoàn toàn không ảnh hưởng đến phân vị thứ 75.
  • Nếu đó là 10% thời gian tải trang chậm nhất, nhưng chúng chậm hơn LCP ở phân vị thứ 75 hơn 800 mili giây để bắt đầu, thì hoàn toàn không ảnh hưởng đến phân vị thứ 75.

Đây là những ví dụ mang tính cực đoan, có thể không phản ánh được thực tế, nhưng hy vọng có thể minh hoạ cho vấn đề này. Trong thực tế, có khả năng SXG sẽ ảnh hưởng đến phân vị thứ 75 đối với hầu hết các trang web. Tốc độ điều hướng trên nhiều trang web thường là một trong những quá trình chậm nhất và những điểm cải tiến đáng kể từ việc tìm nạp trước có xu hướng được cải thiện đáng kể.

Chọn không tham gia một số URL

Cuối cùng, có một cách để so sánh hiệu suất của SXG là vô hiệu hoá SXG đối với một số URL trên trang web của bạn. Ví dụ: bạn có thể đặt tiêu đề CDN-Cache-Control: no-store để ngăn Cloudflare ASX tạo một SXG. Tôi khuyên bạn không nên làm như vậy.

Phương pháp này có nguy cơ sai số do lựa chọn nhiều hơn so với các phương pháp nghiên cứu khác. Ví dụ: điều này có thể tạo ra sự khác biệt lớn cho dù trang chủ của trang web hoặc một URL phổ biến tương tự được chọn vào nhóm đối chứng hay nhóm thử nghiệm.

Nghiên cứu cách ly

Phương pháp lý tưởng để đo lường tác động là tiến hành nghiên cứu cách ly. Rất tiếc, hiện tại bạn không thể thực hiện loại thử nghiệm này. Chúng tôi dự định trong tương lai sẽ hỗ trợ thử nghiệm như vậy.

Nghiên cứu giữ lại có các đặc điểm sau:

  • Trong nhóm thử nghiệm, một số tỷ lệ ngẫu nhiên số lượt xem trang có thể là SXG được "giữ lại" và được phân phát ở dạng không phải SXG. Điều này cho phép "tương lai" so sánh giữa số người dùng, thiết bị, tình huống và trang tương đương.
  • Những lượt xem trang được giữ lại (còn gọi là phản thực tế) được gắn nhãn như vậy trong số liệu phân tích. Tính năng này cho phép "phóng to" dữ liệu, trong đó chúng tôi có thể so sánh số lượt tải trang SXG trong đối chứng với nội dung phản thực tế của SXG trong thử nghiệm. Nhờ đó, tính năng này sẽ làm giảm hiện tượng tải trang khác mà không bị ảnh hưởng bởi hoạt động tìm nạp trước SXG.

Điều này sẽ loại bỏ các nguồn sai lệch lựa chọn nói trên, mặc dù sẽ không loại bỏ được nguy cơ thiên kiến về khả năng tồn tại của LCP. Cả hai thuộc tính này đều yêu cầu trình duyệt hoặc đường liên kết giới thiệu phải bật.

Kết luận

Chà! Nhiều lắm. Chúng tôi hy vọng dự án này sẽ phác thảo bức tranh toàn diện hơn về cách kiểm thử hiệu suất của SXG trong một thử nghiệm trong phòng thí nghiệm, cách tối ưu hoá hiệu suất trong một vòng hồi tiếp chặt chẽ với thử nghiệm trong phòng thí nghiệm và cuối cùng là cách đo lường hiệu suất trong thực tế. Kết hợp tất cả những yếu tố này lại với nhau sẽ giúp bạn tận dụng tối đa SXG và đảm bảo chúng mang lại lợi ích cho trang web và người dùng của bạn.

Nếu bạn có lời khuyên khác về cách đạt được hiệu suất SXG, vui lòng cho chúng tôi biết! Báo cáo lỗi dựa trên developer.chrome.com cùng với các điểm cải tiến mà bạn đề xuất.

Để biết thêm thông tin về cơ chế trao đổi có chữ ký, hãy tham khảo tài liệu trên web.devtài liệu của Google Tìm kiếm.