Anda sedang melihat dokumentasi Apigee Edge.
Buka
dokumentasi Apigee X. info
Gejala
Aplikasi klien mendapatkan kode status HTTP 502 Bad Gateway
dengan
kode error protocol.http.TooBigHeaders
sebagai respons untuk panggilan
API.
Pesan error
Aplikasi klien mendapatkan kode respons berikut:
HTTP/1.1 502 Bad Gateway
Selain itu, Anda mungkin melihat pesan error berikut:
{ "fault":{ "faultstring":"response headers size exceeding 25,600", "detail":{ "errorcode":"protocol.http.TooBigHeaders" } } }
Kemungkinan penyebab
Error ini terjadi jika ukuran total header yang dikirim oleh server target/backend ke Apigee Edge sebagai bagian dari respons HTTP lebih besar dari batas yang diizinkan di Apigee Edge.
Berikut kemungkinan penyebab error ini:
Penyebab | Deskripsi | Petunjuk pemecahan masalah yang berlaku untuk |
---|---|---|
Ukuran header dalam respons lebih besar dari batas yang diizinkan | Ukuran header header tertentu atau jumlah ukuran header dari semua header yang dikirim oleh server target/backend sebagai bagian dari respons HTTP terhadap Apigee Edge melebihi batas yang diizinkan di Apigee Edge. | Pengguna Edge Publik dan Private Cloud |
Langkah-langkah diagnosis umum
Gunakan salah satu alat/teknik berikut untuk mendiagnosis error ini:
Pemantauan API
Untuk mendiagnosis error menggunakan API Monitoring:
- Login ke UI Apigee Edge sebagai pengguna dengan peran yang sesuai.
Beralihlah ke organisasi tempat Anda ingin menyelidiki masalah.
- Buka halaman Analyze > API Monitoring > Menyelidiki.
- Pilih jangka waktu spesifik saat Anda melihat error.
- Anda dapat memilih filter Proxy untuk mempersempit kode kesalahan.
- Tempatkan Kode Kesalahan terhadap Waktu.
Pilih sel yang memiliki kode kesalahan
protocol.http.TooBigHeaders
seperti yang ditunjukkan di bawah ini:Anda akan melihat informasi tentang kode kesalahan
protocol.http.TooBigHeaders
seperti yang ditunjukkan di bawah:Klik Lihat log dan luaskan baris untuk permintaan yang gagal.
- Dari jendela Logs, perhatikan detail berikut:
- Kode Status:
502
- Sumber Kesalahan:
target
- Kode Kesalahan:
protocol.http.TooBigHeaders
.
- Kode Status:
- Jika Fault Source memiliki nilai
target
dan Fault Code memiliki nilaiprotocol.http.TooBigHeaders
, maka hal tersebut menunjukkan bahwa respons HTTP dari server target/ backend memiliki header yang ukurannya lebih besar dari batas yang diizinkan di Apigee Edge.
Alat pelacak
- Aktifkan sesi perekaman aktivitas
dan:
- Tunggu hingga error
502 Bad Gateway
terjadi, atau - Jika Anda dapat merekonstruksi masalah, buat panggilan API dan rekonstruksi error
502 Bad Gateway
.
- Tunggu hingga error
- Pilih salah satu permintaan yang gagal dan periksa rekaman aktivitas.
- Jelajahi berbagai fase rekaman aktivitas dan temukan lokasi terjadinya kegagalan.
Biasanya Anda akan melihat error ini dalam flow bernama Error tepat setelah fase Request sent to target server seperti yang ditunjukkan di bawah ini:
( lihat gambar yang lebih besar)
Catat nilai error dari rekaman aktivitas:
- error:
response headers size exceeding 25,600
- error.class:
com.apigee.errors.http.server.BadGateway
Hal ini menunjukkan bahwa Apigee Edge (komponen Message Processor) menampilkan error segera setelah menerima respons dari server backend karena ukuran header melebihi batas yang diizinkan.
- error:
Anda akan melihat kegagalan dalam respons error Response Sent to Client yang dikirim oleh Apigee Edge seperti yang ditunjukkan di bawah ini:
- Catat nilai error dari rekaman aktivitas. Contoh rekaman aktivitas di atas menunjukkan:
- Error:
502 Bad Gateway
. - Konten Error:
{"fault":{"faultstring":"response headers size exceeding 25,600","detail":{"errorcode":"protocol.http.TooBigHeaders"}}}
- Error:
Buka fase AX (Data Analytics Dicatat) dalam trace, lalu klik untuk melihat detail terkait.
( lihat gambar yang lebih besar)
Perhatikan nilai berikut:
Header error Nilai X-Apigee-fault-code protocol.http.TooBigHeaders
X-Apigee-fault-source target
Konten Error: Isi {"fault":{"faultstring":"response headers size exceeding 25,600","detail":{"errorcode":"protocol.http.TooBigHeaders"}}}
NGINX
Untuk mendiagnosis error menggunakan log akses NGINX:
- Jika Anda adalah pengguna Private Cloud, Anda dapat menggunakan log akses NGINX untuk menentukan informasi kunci tentang HTTP
502 Bad Gateway
. Periksa log akses NGINX:
/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_log
Tempat: ORG, ENV, dan PORT# diganti dengan nilai sebenarnya.
- Telusuri untuk melihat apakah ada error
502
dengan kode errorprotocol.http.TooBigHeaders
selama durasi tertentu (jika masalah terjadi sebelumnya) atau apakah ada permintaan yang masih gagal dengan502
. Jika Anda menemukan error
502
dengan X-Apigee-fault-code yang cocok dengan nilaiprotocol.http.TooBigHeaders
, tentukan nilai dari X-Apigee-fault-source.Contoh error 502 dari log akses NGINX:
Contoh entri di atas dari log akses NGINX memiliki nilai berikut untuk X-Apigee-fault-code dan X-Apigee-fault-source:
Header error Nilai X-Apigee-fault-code protocol.http.TooBigHeaders
X-Apigee-fault-source target
Penyebab: Ukuran header dalam respons melebihi batas yang diizinkan
Diagnosis
- Tentukan Fault Code, Fault Source, dan Response Payload Size untuk error yang diamati menggunakan API Monitoring, alat Trace, atau log Access NGINX seperti yang dijelaskan dalam Langkah-langkah diagnosis umum.
- Jika Fault Source memiliki nilai
target
, hal ini menunjukkan bahwa respons yang dikirim oleh server target/backend ke Apigee memiliki header yang ukurannya lebih besar dari batas yang diizinkan di Apigee Edge. - Anda dapat memvalidasi bahwa respons dari target/backend memiliki header yang ukurannya
lebih besar dari batas yang diizinkan menggunakan salah satu metode berikut:
Pesan error
Untuk memvalidasi menggunakan pesan error:
Jika Anda memiliki akses ke pesan error lengkap yang diterima dari Apigee Edge, lihat
faultstring
.faultstring
menunjukkan bahwa ukuran header respons telah melampaui batas yang diizinkan.Contoh pesan error:
"faultstring":"response headers size exceeding 25,600"
Pada pesan error di atas, perhatikan di
faultstring
bahwa respons memiliki header yang ukuran totalnya melebihi batas yang diizinkan.Permintaan sebenarnya
Untuk memvalidasi menggunakan permintaan yang sebenarnya:
Jika Anda memiliki akses ke permintaan sebenarnya yang dibuat ke server target/backend, lakukan langkah-langkah berikut:
- Jika Anda adalah pengguna Cloud Publik/Private Cloud, buat permintaan langsung ke server backend dari server backend itu sendiri atau mesin lain tempat Anda diizinkan untuk membuat permintaan ke server backend.
- Jika Anda adalah pengguna Private Cloud, Anda juga dapat membuat permintaan ke server backend dari salah satu Pemroses Pesan.
- Periksa respons yang diterima dari server backend dan secara khusus hitung dan verifikasi total ukuran header yang diteruskan dalam respons.
Jika Anda mendapati bahwa ukuran header dalam payload respons melebihi batas yang diizinkan di Apigee Edge, maka itulah penyebab masalahnya.
Contoh respons dari server target:
curl -v https://TARGET_SERVER_HOST/test
* About to connect() to 10.1.0.10 port 9000 (#0) * Trying 10.1.0.10... * Connected to 10.1.0.10 (10.1.0.10) port 9000 (#0) > GET /test HTTP/1.1 > User-Agent: curl/7.29.0 > Host: 10.1.0.10:9000 > Accept: */* < < HTTP/1.1 200 OK < Accept-Ranges: bytes < Content-Length: 0 < Content-Type: text/plain; charset=utf-8 < Last-Modified: Tue, 20 Jul 2021 09:23:56 GMT
< Testheader1: XVlBzgba—-<snipped>---THctcuAx < Testheader2: hxKQFDaFpLSj—-<snipped>---FbcXoEFfRsWxP
< Date: Fri, 23 Jul 2021 09:51:22 GMT < * Connection #0 to host 10.1.0.10 left intactPada contoh di atas,
Testheader1
danTestheader2
memiliki ukuran yang lebih tinggi, yang menjadi penyebab error ini karena melampaui batas yang diizinkan di Apigee Edge.
Log Pemroses Pesan
Untuk memvalidasi menggunakan log Pemroses Pesan:
Jika Anda adalah pengguna Private Cloud, Anda dapat menggunakan log Prosesor Pesan untuk memvalidasi apakah ukuran header Respons telah melampaui batas yang diizinkan di Apigee Edge.
Periksa log Message Processor:
/opt/apigee/var/log/edge-message-processor/logs/system.log
- Telusuri untuk mengetahui apakah ada error
502
selama durasi tertentu (jika masalah terjadi di masa lalu) atau apakah ada permintaan yang masih gagal dengan502
. Anda dapat menggunakan string penelusuran berikut:grep -ri "response headers size exceeding"
- Anda akan menemukan baris dari
system.log
yang mirip dengan yang berikut ini. Ukuran header respons dapat bervariasi dalam kasus Anda:2021-07-23 08:25:12,307 org:myorg env:prod api:bigheadertest rev:1 messageid:r23ijb1b-1 NIOThread@1 ERROR HTTP.CLIENT - HTTPClient$Context$3.onException() : ClientChannel[Connected: Remote:3.7.1.1:9000 Local:192.168.2.1:56098]@8414 useCount=1 bytesRead=0 bytesWritten=207 age=640ms lastIO=0ms isOpen=true.onExceptionRead exception: {} com.apigee.errors.http.server.BadGateway: response headers size exceeding 25,600 2021-07-23 08:25:12,307 org:myorg env:prod api:bigheadertest rev:1 messageid:r23ijb1b-1 NIOThread@1 ERROR ADAPTORS.HTTP.FLOW - AbstractResponseListener.onException() : AbstractResponseListener.onError (HTTPResponse@31f3ef88, response headers size exceeding 25,600)
-
Segera setelah Pemroses Pesan menerima respons dari server backend/target dan menemukan bahwa ukuran total header lebih besar dari 25 KB, Pemroses Pesan akan berhenti dan menampilkan error:
response headers size exceeding 25,600
Ini menyiratkan bahwa Total Header Size lebih dari 25 KB dan Apigee akan menampilkan error ketika ukuran mulai melebihi batas 25 KB dengan kode kesalahan sebagai
protocol.http.TooBigHeaders
Resolusi
Ukuran tetap
Opsi #1 [Direkomendasikan]: Memperbaiki aplikasi server target agar tidak mengirim ukuran header yang melebihi batas Apigee
- Analisis alasan server target tertentu mengirim ukuran header respons melebihi batas yang diizinkan seperti yang ditentukan dalam Batas.
- Jika tidak diinginkan, ubah aplikasi server backend Anda agar mengirimkan header Respons yang ukurannya kurang dari batas yang diizinkan di Apigee Edge.
- Periksa apakah informasi header dapat dikirim sebagai bagian dari isi respons.
- Jika memungkinkan, kirim informasi berukuran besar yang ingin Anda kirim sebagai bagian dari header dalam isi respons. Dengan begitu, Anda tidak akan melebihi batas header respons.
CwC
Opsi no. 2 : Gunakan properti CwC untuk meningkatkan batas ukuran header respons
Apigee menyediakan properti CwC yang memungkinkannya meningkatkan batas ukuran header Respons. Untuk mengetahui detailnya, lihat Mengonfigurasi batas untuk Pemroses Pesan
Batas
Apigee memperkirakan bahwa aplikasi klien dan server backend tidak akan mengirim ukuran header lebih besar dari batas yang diizinkan seperti yang didokumentasikan untuk Ukuran Header Permintaan/Respons di Apigee Edge Limits.
- Jika Anda adalah pengguna Cloud Publik, batas maksimum untuk ukuran header Permintaan dan Respons adalah seperti yang didokumentasikan untuk Ukuran Header Permintaan/Respons di Batas Apigee Edge.
- Jika Anda adalah pengguna Private Cloud, Anda mungkin telah mengubah batas maksimum default untuk ukuran header Permintaan dan Respons (meskipun bukan praktik yang direkomendasikan). Anda dapat menentukan batas ukuran Header Respons maksimum dengan mengikuti petunjuk dalam Cara memeriksa batas saat ini.
Bagaimana cara memeriksa batas saat ini?
Bagian ini menjelaskan cara memverifikasi bahwa properti HTTPResponse.headers.limit
telah diperbarui dengan nilai baru di Pemroses Pesan.
- Pada mesin Message Processor, telusuri properti
HTTPResponse.headers.limit
dalam direktori/opt/apigee/edge-message-processor/conf
, lalu periksa untuk melihat nilai apa yang telah ditetapkan seperti yang ditunjukkan di bawah:grep -ri "HTTPResponse.headers.limit" /opt/apigee/edge-message-processor/conf
- Contoh hasil dari perintah di atas adalah sebagai berikut:
/opt/apigee/edge-message-processor/conf/http.properties:HTTPResponse.headers.limit=25k
Pada contoh output di atas, perhatikan bahwa properti
HTTPResponse.headers.limit
telah ditetapkan dengan nilai25k
dihttp.properties
.Hal ini menunjukkan bahwa batas ukuran payload Respons yang dikonfigurasi di Apigee untuk Private Cloud adalah 25 KB.
Jika Anda masih memerlukan bantuan dari Dukungan Apigee, buka Harus mengumpulkan informasi diagnostik.
Harus mengumpulkan informasi diagnostik
Kumpulkan informasi diagnostik berikut, lalu hubungi Dukungan Apigee Edge:
Jika Anda adalah pengguna Cloud Publik, berikan informasi berikut:
- Nama organisasi
- Nama lingkungan
- Nama Proxy API
- Selesaikan perintah
curl
yang digunakan untuk mereproduksi error502
- File rekaman aktivitas untuk permintaan API
- Lengkapi output respons dari server target/backend beserta ukuran headernya
Jika Anda adalah pengguna Private Cloud, berikan informasi berikut:
- Pesan error lengkap yang diamati untuk permintaan yang gagal
- Nama organisasi
- Nama lingkungan
- Paket Proxy API
- File rekaman aktivitas untuk permintaan API yang gagal
- Selesaikan perintah
curl
yang digunakan untuk mereproduksi error502
- Lengkapi output respons dari server target/backend beserta ukuran headernya
Log akses NGINX
/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_log
Tempat: ORG, ENV, dan PORT# diganti dengan nilai sebenarnya.
- Log sistem Pemroses Pesan
/opt/apigee/var/log/edge-message-processor/logs/system.log