Mengaktifkan kompresi dinamis

Kompresi dinamis otomatis mengompresi respons yang disajikan oleh Media CDN. Ukuran data yang dikirim melalui jaringan berkurang sebesar 60% hingga 85% dalam kasus umum.

Pengurangan ukuran mempercepat download aset penting, seperti stylesheet (CSS), skrip (JavaScript), dan manifes video (HLS/DASH), yang dapat mengurangi waktu pemuatan halaman dan waktu mulai video secara signifikan.

Playlist video live (manifest) berukuran besar memiliki sejumlah besar data dan pengambilan berulang, termasuk awalan host dan jalur tiap segmen, serta metadata playlist HLS atau DASH. Makin cepat muatan atau update playlist dapat didownload, makin sedikit waktu yang dibutuhkan klien untuk mengurai dan mulai mendownload segmen video yang dirujuk. Playlist HLS dan DASH sering kali mengalami pengurangan ukuran total lebih dari 90%.

Untuk mengetahui informasi selengkapnya tentang manfaat mengompresi respons, lihat panduan Dasar-Dasar Web.

Cara kerja kompresi dinamis

Jika kompresi dinamis diaktifkan, konten yang dapat dikompresi yang disajikan dari origin dapat dikompresi sebelum dikirimkan jika klien menerima salah satu algoritma kompresi yang didukung (br atau gzip).

Media CDN menambahkan header Vary: Accept-Encoding ke semua respons yang memenuhi syarat untuk dikompresi. Untuk informasi terkait, lihat Konten yang tidak dapat dikompresi.

Selain itu, jika header Accept-Encoding permintaan menunjukkan preferensi untuk konten terkompresi dengan menentukan br atau gzip (dan secara opsional menyertakan parameter q yang tidak nol), Media CDN akan melakukan hal berikut:

  • Menghapus header Content-Length dari respons. Hal ini diperlukan agar respons dapat disajikan secepat mungkin karena panjang konten lengkap tidak akan diketahui hingga seluruh respons dikompresi. Untuk HTTP/1.1 dan yang lebih lama, Media CDN menggunakan Transfer-Encoding: chunked dalam respons jika tidak menggunakan Content-Length.

    Setelah respons dikompresi dan di-cache, Media CDN dapat menyertakan header Content-Length dalam respons berikutnya dan menetapkan nilai ke panjang konten isi yang dikompresi.

  • Menetapkan Accept-Ranges ke none. Header ini memberi tahu klien bahwa permintaan rentang untuk resource ini diabaikan.

  • Melemahkan header respons ETag yang kuat, sebagaimana diwajibkan oleh RFC 9110 bagian 8.8.3. Misalnya, ETag: "xyzzy" diganti dengan ETag: W/"xyzzy".

  • Menetapkan header Content-Encoding ke br atau gzip, yang menandakan algoritma kompresi yang dipilih.

    Media CDN memilih algoritma kompresi terbaik berdasarkan rasio kompresi yang diantisipasi dari respons dan kecepatan atau throughput kompresi.

    • Kompresi Brotli digunakan jika klien mendukungnya, meskipun algoritma kompresi lainnya memiliki nilai q yang lebih tinggi di header Accept-Encoding.

    • Manifes HLS dikompresi hanya menggunakan gzip.

    Media CDN menentukan tingkat kompresi untuk menyeimbangkan total ukuran download dan biaya CPU di klien. Tingkat kompresi yang lebih tinggi tidak selalu meningkatkan performa, terutama pada perangkat seluler dengan daya yang lebih rendah.

Mengonfigurasi kompresi dinamis

Anda dapat mengaktifkan kompresi dinamis pada rute yang melayani permintaan.

Sebelum memulai

Lakukan tindakan berikut:

Mengaktifkan kompresi dinamis untuk aturan rute

Secara default, mode kompresi untuk aturan rute dinonaktifkan.

Menyetel mode ke otomatis akan mengaktifkan kompresi dinamis untuk setiap respons yang memenuhi syarat. Selain itu, perintah ini menginstruksikan Media CDN untuk memilih algoritma kompresi terbaik secara otomatis.

Untuk mengaktifkan kompresi dinamis, lakukan hal berikut:

Konsol

  1. Di Konsol Google Cloud , buka halaman Media CDN.

    Buka Media CDN

  2. Untuk membuka halaman Detail layanan yang ingin Anda konfigurasi aturan rutenya, klik nama layanan.

  3. Untuk beralih ke mode edit, klik tombol Edit.

  4. Untuk membuka bagian Routing, klik Next.

  5. Untuk mengedit aturan host, klik panah untuk meluaskannya.

  6. Untuk mengedit aturan rute, klik Edit di baris yang sesuai.

  7. Di panel Edit aturan rute, klik Konfigurasi lanjutan.

  8. Opsional: Untuk Route action, tambahkan item CDN policy.

    Kebijakan CDN memungkinkan Media CDN mengompresi konten satu kali dan menayangkannya beberapa kali, sehingga menghemat bandwidth dan mempercepat penayangan.

  9. Di bagian Dynamic compression, pilih Enable compression.

  10. Untuk menyimpan aturan rute, klik Simpan.

  11. Untuk menyimpan perubahan pada layanan, klik Perbarui layanan.

gcloud dan YAML

  1. Ekspor konfigurasi Media CDN ke dalam file YAML. Gunakan perintah gcloud edge-cache services export.

    gcloud edge-cache services export SERVICE_NAME \
        --destination=FILENAME.yaml
    

    Ganti kode berikut:

    • SERVICE_NAME: Nama layanan Anda.
    • FILENAME : nama file YAML Anda
  2. Dalam definisi rute di file YAML, di bagian routeAction, tetapkan compressionMode ke AUTOMATIC, seperti yang ditunjukkan dalam contoh berikut:

    routing:
    hostRules:
    - hosts:
      - media.example.com
      pathMatcher: routes
    pathMatchers:
    - name: routes
      routeRules:
        - priority: 2
    origin: origin1
    matchRules:
    - pathTemplateMatch: "/**.m3u8" # HLS playlists
    - pathTemplateMatch: "/**.mpd" # DASH manifests
    routeAction:
      cdnPolicy:
        defaultTtl: 5s
      compressionMode: AUTOMATIC
    
  3. Untuk memperbarui layanan, impor konfigurasi Media CDN Anda dari file YAML. Gunakan perintah gcloud edge-cache services import.

    gcloud edge-cache services import SERVICE_NAME \
        --source=FILENAME.yaml
    

Terraform

Cuplikan Terraform berikut menunjukkan aturan rute dengan kompresi dinamis yang diaktifkan.

route_rule {
  description = "a route rule with dynamic compression, priority=2 (high)"
  priority    = 2
  match_rule {
    path_template_match = "/**.m3u8" # HLS playlists
  }
  match_rule {
    path_template_match = "/**.mpd" # DASH manifests
  }
  origin = google_network_services_edge_cache_origin.default.name
  route_action {
    cdn_policy {
      cache_mode = "FORCE_CACHE_ALL"
      client_ttl = "300s"
    }
    compression_mode = "AUTOMATIC"
  }
  header_action {
    response_header_to_add {
      header_name  = "x-cache-status"
      header_value = "{cdn_cache_status}"
    }
  }
}

Konfigurasi Anda akan segera diterapkan ke semua lokasi edge.

Saat kompresi dinamis diaktifkan untuk rute dan konfigurasi baru diterapkan di mesin produksi, Media CDN mulai mengompresi respons yang memenuhi syarat, meskipun ada versi yang di-cache dan tidak dikompresi. Saat Media CDN mengambil dan memadatkan konten baru, mungkin terjadi lonjakan sementara traffic ke asal Anda.

Menonaktifkan kompresi dinamis untuk aturan rute

Untuk menonaktifkan kompresi dinamis, lakukan hal berikut:

Konsol

  1. Di Konsol Google Cloud , buka halaman Media CDN.

    Buka Media CDN

  2. Untuk membuka halaman Detail layanan yang ingin Anda konfigurasi aturan rutenya, klik nama layanan.

  3. Untuk beralih ke mode edit, klik tombol Edit.

  4. Untuk membuka bagian Routing, klik Next.

  5. Untuk mengedit aturan host, klik panah untuk meluaskannya.

  6. Untuk mengedit aturan rute, klik Edit di baris yang sesuai.

  7. Di panel Edit aturan rute, klik Konfigurasi lanjutan.

  8. Di bagian Kompresi dinamis, hapus centang pada Aktifkan kompresi.

  9. Untuk menyimpan aturan rute, klik Simpan.

  10. Untuk menyimpan perubahan pada layanan, klik Perbarui layanan.

gcloud dan YAML

  1. Ekspor konfigurasi Media CDN ke dalam file YAML. Gunakan perintah gcloud edge-cache services export.

    gcloud edge-cache services export SERVICE_NAME \
        --destination=FILENAME.yaml
    

    Ganti kode berikut:

    • SERVICE_NAME: Nama layanan Anda.
    • FILENAME : nama file YAML Anda
  2. Dalam definisi rute di file YAML, tetapkan compressionMode ke DISABLED.

  3. Untuk memperbarui layanan, impor konfigurasi Media CDN Anda dari file YAML. Gunakan perintah gcloud edge-cache services import.

    gcloud edge-cache services import SERVICE_NAME \
        --source=FILENAME.yaml
    

Jika Anda mengalami masalah dengan kompresi dinamis untuk rute tertentu, seperti masalah kompatibilitas dengan klien tertentu (misalnya, smart TV atau perangkat streaming), nonaktifkan kompresi dinamis untuk mencegah Media CDN menayangkan konten terkompresi di rute tersebut.

Menonaktifkan kompresi dinamis untuk rute akan menyebabkan Media CDN berhenti menyajikan konten terkompresi dari cache. Semua respons terkompresi yang di-cache sebelumnya menjadi tidak valid, dan CDN mengambil versi yang tidak dikompresi dari server asal Anda.

Jenis konten yang dapat dikompresi

Kompresi dinamis berlaku untuk jenis MIME berikut, berdasarkan header respons HTTP Content-Type. Respons yang tidak memiliki header Content-Type tidak akan dikompresi.

Jenis konten umum dan jenis MIME-nya mencakup:

  • Konten HTML: text/html
  • Stylesheet: text/css
  • JavaScript: application/javascript
  • JSON: application/json
  • Playlist HLS: application/x-mpegURL atau application/vnd.apple.mpegURL
  • Manifes DASH: application/dash+xml

Tabel berikut merangkum pengaruh jenis MIME terhadap kompresibilitas.

  Jenis MIME yang dapat dikompresi
Pencocokan persis application/csv
application/javascript
application/json
application/json+protobuf
application/signed-exchange
application/wasm
application/x-javascript
application/x-nacl
application/x-plist
application/x-pnacl
application/x-protobuf
application/x-protobuffer
application/x-sdch-dictionary
application/xml
audio/mpegURL
font/eot
font/otf
font/ttf
image/pwg-raster
image/svg+xml
image/vnd.microsoft.icon
image/x-icon
video/vnd.mpeg.dash.mpd
Pencocokan pola application/*+json
application/*+xml
application/*mpegURL
text/*

Format gambar dan video (seperti image/jpeg, image/png, dan video/mpeg4) hampir selalu sudah dikompresi. Jadi, Media CDN tidak mengompresinya. Mengompresi ulang respons yang sudah dikompresi biasanya tidak akan mengurangi ukuran file, dan klien mungkin akan menunjukkan perilaku yang tidak terduga saat menerima respons semacam ini.

Respons yang tidak dapat dikompresi

Media CDN tidak akan mengompresi respons yang memiliki satu atau beberapa karakteristik berikut:

  • Respons tidak memiliki header Content-Type yang cocok dengan jenis konten yang dapat dikompresi.
  • Respons tidak memiliki header Content-Length.
  • Respons memiliki header Content-Encoding. Hal ini menunjukkan bahwa origin telah memadatkan respons. Jadi, Media CDN tidak boleh melakukan kompresi dinamis tambahan.
  • Respons berukuran kurang dari 1 KiB.

    Waktu yang dihabiskan untuk mengompresi dan mendekompresi sering kali tidak sebanding dengan manfaat apa pun yang diperoleh. Selain itu, konten yang dikompresi juga lebih sedikit, sehingga dapat mengurangi efektivitas kompresi dan menghasilkan rasio kompresi yang lebih rendah.

  • Respons lebih besar dari 1 MiB.

    Media CDN memadatkan respons hingga ukuran yang diizinkan untuk objek yang di-cache tanpa byte-range caching.

  • Respons memiliki header Cache-Control: no-transform.

Logging dan pemantauan

Jika kompresi diaktifkan, metrik https/response_bytes_count yang ada di bagian edgecache.googleapis.com/EdgeCacheRouteRule akan melaporkan ukuran respons yang dikompresi. Anda dapat mengalami penurunan total byte respons dan throughput transfer data keluar untuk konten yang dapat dikompresi.

Log Media CDN menyertakan kolom compressionAlgorithmApplied di jsonPayload, yang menunjukkan apakah respons dikompresi oleh load balancer serta jenis kompresinya atau tidak.

{
  insertId: "1c02hw9g3gjay67"
  jsonPayload: {
    @type: "type.googleapis.com/google.cloud.edgecache.v1.EdgeCacheLogEntry",
    cacheId: "IAD-862d661f",
    cacheStatus": "hit,stale",
    compressionAlgorithmApplied: "br"
  },
}

Penagihan

Jika respons dikompresi oleh Media CDN, biaya transfer data cache atau internet keluar yang relevan didasarkan pada byte terkompresi akhir yang dikirim ke klien.

Jika Anda menyajikan respons yang dapat dikompresi dalam jumlah besar, hal ini dapat mengurangi biaya transfer data keluar bulanan Anda, serta meningkatkan performa bagi pengguna akhir.

Langkah berikutnya