আপনি Apigee Edge ডকুমেন্টেশন দেখছেন।
Apigee X ডকুমেন্টেশনে যান । তথ্য
উপসর্গ
ক্লায়েন্ট অ্যাপ্লিকেশনটি API কলগুলির প্রতিক্রিয়া হিসাবে Bad Gateway বার্তা সহ 502 এর একটি HTTP স্ট্যাটাস কোড পায়।
এইচটিটিপি স্ট্যাটাস কোড 502 এর অর্থ হল ক্লায়েন্ট ব্যাকএন্ড সার্ভার থেকে একটি বৈধ প্রতিক্রিয়া পাচ্ছে না যা আসলে অনুরোধটি পূরণ করা উচিত।
ত্রুটি বার্তা
ক্লায়েন্ট অ্যাপ্লিকেশন নিম্নলিখিত প্রতিক্রিয়া কোড পায়:
HTTP/1.1 502 Bad Gateway
উপরন্তু, আপনি নিম্নলিখিত ত্রুটি বার্তা পর্যবেক্ষণ করতে পারেন:
{
"fault": {
"faultstring": "Unexpected EOF at target",
"detail": {
"errorcode": "messaging.adaptors.http.UnexpectedEOFAtTarget"
}
}
}সম্ভাব্য কারণ
502 Bad Gateway Error একটি সাধারণ কারণ হল Unexpected EOF ত্রুটি, যা নিম্নলিখিত কারণে হতে পারে:
| কারণ | বিস্তারিত | জন্য দেওয়া পদক্ষেপ |
|---|---|---|
| টার্গেট সার্ভারটি ভুলভাবে কনফিগার করা হয়েছে | TLS/SSL সংযোগ সমর্থন করার জন্য টার্গেট সার্ভার সঠিকভাবে কনফিগার করা হয়নি। | এজ পাবলিক এবং প্রাইভেট ক্লাউড ব্যবহারকারীরা |
| ব্যাকএন্ড সার্ভার থেকে EOFException | ব্যাকএন্ড সার্ভার হঠাৎ করে EOF পাঠাতে পারে। | এজ প্রাইভেট ক্লাউড ব্যবহারকারীরা শুধুমাত্র |
| ভুলভাবে কনফিগার করা জীবিত রাখা সময় শেষ | Apigee এবং ব্যাকএন্ড সার্ভারে ভুলভাবে কনফিগার করা জীবন্ত টাইমআউট রাখুন। | এজ পাবলিক এবং প্রাইভেট ক্লাউড ব্যবহারকারীরা |
সাধারণ রোগ নির্ণয়ের পদক্ষেপ
ত্রুটি নির্ণয় করতে, আপনি নিম্নলিখিত পদ্ধতিগুলির যে কোনও একটি ব্যবহার করতে পারেন:
API মনিটরিং
API মনিটরিং ব্যবহার করে ত্রুটি নির্ণয় করতে:
এপিআই মনিটরিং ব্যবহার করে আপনি ইনভেস্টিগেট ইস্যুতে বর্ণিত পদক্ষেপগুলি অনুসরণ করে 502 ত্রুটিগুলি তদন্ত করতে পারেন। অর্থাৎ:
- ইনভেস্টিগেট ড্যাশবোর্ডে যান।
- ড্রপ ডাউন মেনুতে স্ট্যাটাস কোড নির্বাচন করুন এবং নিশ্চিত করুন যে
502ত্রুটি ঘটেছে যখন সঠিক সময়কাল নির্বাচন করা হয়েছে। - ম্যাট্রিক্সের বাক্সে ক্লিক করুন যখন আপনি
502ত্রুটির উচ্চ সংখ্যা দেখতে পাচ্ছেন। - ডানদিকে,
502ত্রুটিগুলির জন্য লগ দেখুন ক্লিক করুন যা নিম্নলিখিতগুলির মতো দেখতে হবে: - ফল্ট উত্স
target - ফল্ট কোড হল
messaging.adaptors.http.UnexpectedEOFAtTarget

এখানে আমরা নিম্নলিখিত তথ্য দেখতে পারি:
এটি ইঙ্গিত করে যে 502 ত্রুটিটি অপ্রত্যাশিত EOF এর কারণে লক্ষ্য দ্বারা সৃষ্ট হয়েছে।
এছাড়াও, আরও তদন্তের জন্য 502 ত্রুটির জন্য Request Message ID একটি নোট করুন।
ট্রেস টুল
ট্রেস টুল ব্যবহার করে ত্রুটি নির্ণয় করতে:
- ট্রেস সেশন সক্রিয় করুন, এবং সমস্যাটি
502 Bad Gatewayপুনরুত্পাদন করতে API কল করুন। - ব্যর্থ অনুরোধগুলির একটি নির্বাচন করুন এবং ট্রেস পরীক্ষা করুন।
- ট্রেসের বিভিন্ন পর্যায়ে নেভিগেট করুন এবং কোথায় ব্যর্থতা ঘটেছে তা সনাক্ত করুন।
নীচে দেখানো হিসাবে লক্ষ্য সার্ভারে অনুরোধ পাঠানোর পরে আপনি ব্যর্থতা দেখতে পাবেন:


ট্রেসে AX (Analytics Data Recorded) পর্বে X-Apigee.fault-source এবং X-Apigee.fault-কোডের মান নির্ধারণ করুন।
যদি X-Apigee.fault-source এবং X-Apigee.fault-code- এর মানগুলি নিম্নলিখিত টেবিলে দেখানো মানগুলির সাথে মেলে, আপনি নিশ্চিত করতে পারেন যে
502ত্রুটি লক্ষ্য সার্ভার থেকে আসছে:প্রতিক্রিয়া শিরোনাম মান X-Apigee.fault-source targetX-Apigee.fault-code messaging.adaptors.http.flow.UnexpectedEOFAtTargetউপরন্তু, আরও তদন্তের জন্য
502ত্রুটির জন্যX-Apigee.Message-IDএর একটি নোট তৈরি করুন।
NGINX অ্যাক্সেস লগ
NGINX ব্যবহার করে ত্রুটি নির্ণয় করতে:
আপনি 502 স্ট্যাটাস কোডের কারণ নির্ধারণ করতে NGINX অ্যাক্সেস লগগুলিও উল্লেখ করতে পারেন। এটি বিশেষভাবে উপযোগী যদি সমস্যাটি অতীতে ঘটে থাকে বা সমস্যাটি মাঝে মাঝে হয় এবং আপনি UI-তে ট্রেস ক্যাপচার করতে অক্ষম হন। NGINX অ্যাক্সেস লগ থেকে এই তথ্য নির্ধারণ করতে নিম্নলিখিত পদক্ষেপগুলি ব্যবহার করুন:
- NGINX অ্যাক্সেস লগগুলি পরীক্ষা করুন৷
/opt/apigee/var/log/edge-router/nginx/ ORG ~ ENV . PORT# _access_log - একটি নির্দিষ্ট সময়কালের (যদি সমস্যাটি অতীতে ঘটে থাকে) বা
502এর সাথে এখনও ব্যর্থ হওয়া কোনও অনুরোধের জন্য নির্দিষ্ট API প্রক্সির জন্য যে কোনও502ত্রুটি অনুসন্ধান করুন। - যদি কোন
502ত্রুটি থাকে, তাহলে লক্ষ্য করুন একটিUnexpected EOFপাঠানোর কারণে ত্রুটিটি ঘটেছে কিনা তা পরীক্ষা করুন। যদি X-Apigee.fault-source এবং X-Apigee.fault-code- এর মান নীচের টেবিলে দেখানো মানগুলির সাথে মিলে যায়, তাহলে502ত্রুটিটি লক্ষ্য অপ্রত্যাশিতভাবে সংযোগ বন্ধ করার কারণে ঘটে:প্রতিক্রিয়া শিরোনাম মান X-Apigee.fault-source targetX-Apigee.fault-code messaging.adaptors.http.flow.UnexpectedEOFAtTargetএখানে একটি নমুনা এন্ট্রি টার্গেট সার্ভার দ্বারা সৃষ্ট
502ত্রুটি দেখাচ্ছে:
এছাড়াও, আরও তদন্তের জন্য 502 ত্রুটিগুলির জন্য বার্তা আইডিগুলির একটি নোট তৈরি করুন৷
কারণ: ভুলভাবে কনফিগার করা টার্গেট সার্ভার
TLS/SSL সংযোগ সমর্থন করার জন্য টার্গেট সার্ভার সঠিকভাবে কনফিগার করা হয়নি।
রোগ নির্ণয়
-
502ত্রুটির জন্য বার্তা আইডি, ফল্ট কোড এবং ফল্ট উত্স নির্ধারণ করতে API মনিটরিং , ট্রেস টুল বা NGINX অ্যাক্সেস লগ ব্যবহার করুন৷ - প্রভাবিত API-এর জন্য UI-তে ট্রেস সক্ষম করুন।
- যদি ব্যর্থ API অনুরোধের ট্রেস নিম্নলিখিত দেখায়:
- লক্ষ্য প্রবাহের অনুরোধ শুরু হওয়ার সাথে সাথে
502 Bad Gatewayত্রুটি দেখা যায়। -
error.classmessaging.adaptors.http.UnexpectedEOF.তাহলে খুব সম্ভবত এই সমস্যাটি একটি ভুল টার্গেট সার্ভার কনফিগারেশনের কারণে হয়েছে।
- লক্ষ্য প্রবাহের অনুরোধ শুরু হওয়ার সাথে সাথে
- এজ ম্যানেজমেন্ট API কল ব্যবহার করে লক্ষ্য সার্ভারের সংজ্ঞা পান:
- আপনি যদি একজন পাবলিক ক্লাউড ব্যবহারকারী হন, তাহলে এই API ব্যবহার করুন:
curl -v https://api.enterprise.apigee.com/v1/organizations/<orgname>/environments/<envname>/targetservers/<targetservername> -u <username>
- আপনি যদি ব্যক্তিগত ক্লাউড ব্যবহারকারী হন তবে এই API ব্যবহার করুন:
curl -v http://<management-server-host>:<port #>/v1/organizations/<orgname>/environments/<envname>/targetservers/<targetservername> -u <username>
নমুনা ত্রুটিপূর্ণ
TargetServerসংজ্ঞা:<TargetServer name="target1"> <Host>mocktarget.apigee.net</Host> <Port>443</Port> <IsEnabled>true</IsEnabled> </TargetServer >
- আপনি যদি একজন পাবলিক ক্লাউড ব্যবহারকারী হন, তাহলে এই API ব্যবহার করুন:
সচিত্র
TargetServerসংজ্ঞা হল একটি সাধারণ ভুল কনফিগারেশনের একটি উদাহরণ যা নিম্নরূপ ব্যাখ্যা করা হয়েছে:ধরা যাক টার্গেট সার্ভার
mocktarget.apigee.netপোর্ট443এ সুরক্ষিত (HTTPS) সংযোগ গ্রহণ করার জন্য কনফিগার করা হয়েছে। যাইহোক, যদি আপনি টার্গেট সার্ভারের সংজ্ঞা দেখেন, অন্য কোন বৈশিষ্ট্য/পতাকা নেই যা নির্দেশ করে যে এটি সুরক্ষিত সংযোগের জন্য। এটি এজকে নির্দিষ্ট টার্গেট সার্ভারে যাওয়া API অনুরোধগুলিকে HTTP (অ-সুরক্ষিত) অনুরোধ হিসাবে বিবেচনা করে। তাই এজ এই টার্গেট সার্ভারের সাথে SSL হ্যান্ডশেক প্রক্রিয়া শুরু করবে না।যেহেতু টার্গেট সার্ভারটি
443এ শুধুমাত্র HTTPS (SSL) অনুরোধগুলি গ্রহণ করার জন্য কনফিগার করা হয়েছে, তাই এটি এজ থেকে অনুরোধ প্রত্যাখ্যান করবে বা সংযোগ বন্ধ করবে। ফলস্বরূপ, আপনি বার্তা প্রসেসরে একটিUnexpectedEOFAtTargetত্রুটি পাবেন। মেসেজ প্রসেসর ক্লায়েন্টের প্রতিক্রিয়া হিসাবে502 Bad Gatewayপাঠাবে।
রেজোলিউশন
সর্বদা নিশ্চিত করুন যে লক্ষ্য সার্ভার আপনার প্রয়োজনীয়তা অনুযায়ী সঠিকভাবে কনফিগার করা হয়েছে।
উপরের সচিত্র উদাহরণের জন্য, আপনি যদি একটি সুরক্ষিত (HTTPS/SSL) টার্গেট সার্ভারে অনুরোধ করতে চান, তাহলে আপনাকে SSLInfo বৈশিষ্ট্যগুলিকে অন্তর্ভুক্ত করতে হবে enabled পতাকা true সেট করে। টার্গেট এন্ডপয়েন্ট ডেফিনিশনে একটি টার্গেট সার্ভারের জন্য SSLInfo অ্যাট্রিবিউট যোগ করার অনুমতি দেওয়া হলেও, কোনো বিভ্রান্তি এড়াতে টার্গেট সার্ভারের সংজ্ঞার অংশ হিসেবে SSLInfo অ্যাট্রিবিউট যোগ করার পরামর্শ দেওয়া হয়।
- যদি ব্যাকএন্ড পরিষেবার একমুখী SSL যোগাযোগের প্রয়োজন হয়, তাহলে:
- আপনাকে
TargetServerসংজ্ঞাতে TLS/SSL সক্ষম করতে হবেSSLInfoবৈশিষ্ট্যগুলি অন্তর্ভুক্ত করে যেখানেenabledপতাকাটি সত্য হিসাবে সেট করা হয়েছে নীচে দেখানো হয়েছে:<TargetServer name="mocktarget"> <Host>mocktarget.apigee.net</Host> <Port>443</Port> <IsEnabled>true</IsEnabled> <SSLInfo> <Enabled>true</Enabled> </SSLInfo> </TargetServer> - আপনি যদি এজ-এ টার্গেট সার্ভারের সার্টিফিকেট যাচাই করতে চান, তাহলে নিচে দেখানো হিসাবে আমাদের ট্রাস্টস্টোর (টার্গেট সার্ভারের সার্টিফিকেট রয়েছে) অন্তর্ভুক্ত করতে হবে:
<TargetServer name="mocktarget"> <Host>mocktarget.apigee.net</Host> <Port>443</Port> <IsEnabled>true</IsEnabled> <SSLInfo> <Ciphers/> <ClientAuthEnabled>false</ClientAuthEnabled> <Enabled>true</Enabled> <IgnoreValidationErrors>false</IgnoreValidationErrors> <Protocols/> <TrustStore>mocktarget-truststore</TrustStore> </SSLInfo> </TargetServer>
- আপনাকে
- যদি ব্যাকএন্ড পরিষেবার জন্য দ্বিমুখী SSL যোগাযোগের প্রয়োজন হয়, তাহলে:
- আপনার কাছে
ClientAuthEnabled,Keystore,KeyAlias, এবংTruststoreপতাকাগুলির সাথে যথাযথভাবে সেট করাSSLInfoবৈশিষ্ট্য থাকতে হবে, যেমনটি নীচে দেখানো হয়েছে:<TargetServer name="mocktarget"> <IsEnabled>true</IsEnabled> <Host>www.example.com</Host> <Port>443</Port> <SSLInfo> <Ciphers/> <ClientAuthEnabled>true</ClientAuthEnabled> <Enabled>true</Enabled> <IgnoreValidationErrors>false</IgnoreValidationErrors> <KeyAlias>keystore-alias</KeyAlias> <KeyStore>keystore-name</KeyStore> <Protocols/> <TrustStore>truststore-name</TrustStore> </SSLInfo> </TargetServer >
- আপনার কাছে
তথ্যসূত্র
ব্যাকএন্ড সার্ভার জুড়ে ভারসাম্য বজায় রাখা
কারণ: ব্যাকএন্ড সার্ভার থেকে EOFException
ব্যাকএন্ড সার্ভার হঠাৎ করে EOF (ফাইলের শেষ) পাঠাতে পারে।
রোগ নির্ণয়
-
502ত্রুটির জন্য বার্তা আইডি, ফল্ট কোড এবং ফল্ট উত্স নির্ধারণ করতে API মনিটরিং , ট্রেস টুল বা NGINX অ্যাক্সেস লগ ব্যবহার করুন৷ - মেসেজ প্রসেসরের লগগুলি (
/opt/apigee/var/log/edge-message-processor/logs/system.log) পরীক্ষা করুন এবং নির্দিষ্ট API এর জন্য আপনার কাছেeof unexpectedআছে কিনা বা আপনার কাছে API এর জন্য অনন্যmessageidআছে কিনা তা দেখতে অনুসন্ধান করুন অনুরোধ, তারপর আপনি এটি অনুসন্ধান করতে পারেন.বার্তা প্রসেসর লগ থেকে নমুনা ব্যতিক্রম স্ট্যাক ট্রেস
"message": "org:myorg env:test api:api-v1 rev:10 messageid:rrt-1-14707-63403485-19 NIOThread@0 ERROR HTTP.CLIENT - HTTPClient$Context$3.onException() : SSLClientChannel[C:193.35.250.192:8443 Remote host:0.0.0.0:50100]@459069 useCount=6 bytesRead=0 bytesWritten=755 age=40107ms lastIO=12832ms .onExceptionRead exception: {} java.io.EOFException: eof unexpected at com.apigee.nio.channels.PatternInputChannel.doRead(PatternInputChannel.java:45) ~[nio-1.0.0.jar:na] at com.apigee.nio.channels.InputChannel.read(InputChannel.java:103) ~[nio-1.0.0.jar:na] at com.apigee.protocol.http.io.MessageReader.onRead(MessageReader.java:79) ~[http-1.0.0.jar:na] at com.apigee.nio.channels.DefaultNIOSupport$DefaultIOChannelHandler.onIO(NIOSupport.java:51) [nio-1.0.0.jar:na] at com.apigee.nio.handlers.NIOThread.run(NIOThread.java:123) [nio-1.0.0.jar:na]"
উপরের উদাহরণে, আপনি দেখতে পাচ্ছেন যে
java.io.EOFException: eof unexpectedত্রুটি ঘটেছে যখন মেসেজ প্রসেসর ব্যাকএন্ড সার্ভার থেকে একটি প্রতিক্রিয়া পড়ার চেষ্টা করছে। এই ব্যতিক্রমটি ফাইলের শেষ (EOF) নির্দেশ করে, বা স্ট্রিমের শেষ অপ্রত্যাশিতভাবে পৌঁছে গেছে।অর্থাৎ, মেসেজ প্রসেসর ব্যাকএন্ড সার্ভারে এপিআই রিকোয়েস্ট পাঠিয়েছে এবং প্রতিক্রিয়ার জন্য অপেক্ষা করছে বা পড়ছে। যাইহোক, ব্যাকএন্ড সার্ভার মেসেজ প্রসেসরের প্রতিক্রিয়া পাওয়ার আগে বা সম্পূর্ণ প্রতিক্রিয়া পড়তে পারার আগেই হঠাৎ সংযোগটি বন্ধ করে দেয়।
- আপনার ব্যাকএন্ড সার্ভার লগগুলি পরীক্ষা করুন এবং দেখুন যে কোনও ত্রুটি বা তথ্য আছে যা ব্যাকএন্ড সার্ভারকে হঠাৎ সংযোগটি বন্ধ করতে পরিচালিত করতে পারে। আপনি যদি কোনো ত্রুটি/তথ্য খুঁজে পান, তাহলে রেজোলিউশনে যান এবং আপনার ব্যাকএন্ড সার্ভারে সমস্যাটি যথাযথভাবে ঠিক করুন।
- আপনি যদি আপনার ব্যাকএন্ড সার্ভারে কোনো ত্রুটি বা তথ্য না পান, তাহলে বার্তা প্রসেসরে
tcpdumpআউটপুট সংগ্রহ করুন:- যদি আপনার ব্যাকএন্ড সার্ভার হোস্টের একটি একক আইপি ঠিকানা থাকে তবে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
tcpdump -i any -s 0 host IP_ADDRESS -w FILE_NAME
- যদি আপনার ব্যাকএন্ড সার্ভার হোস্টের একাধিক আইপি ঠিকানা থাকে, তাহলে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
tcpdump -i any -s 0 host HOSTNAME -w FILE_NAME
সাধারণত, এই ত্রুটিটি ঘটে কারণ বার্তা প্রসেসর ব্যাকএন্ড সার্ভারে অনুরোধ পাঠানোর সাথে সাথে ব্যাকএন্ড সার্ভার
[FIN,ACK]এর সাথে উত্তর দেয়।
- যদি আপনার ব্যাকএন্ড সার্ভার হোস্টের একটি একক আইপি ঠিকানা থাকে তবে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
নিম্নলিখিত
tcpdumpউদাহরণ বিবেচনা করুন।502 Bad Gateway Error(UnexpectedEOFAtTarget) ঘটলেtcpdumpনমুনা নেওয়া হয়
- TCPDump আউটপুট থেকে, আপনি ইভেন্টের নিম্নলিখিত ক্রম লক্ষ্য করেন:
- প্যাকেট
985এ, মেসেজ প্রসেসর ব্যাকএন্ড সার্ভারে API অনুরোধ পাঠায়। - প্যাকেট
986এ, ব্যাকএন্ড সার্ভার অবিলম্বে[FIN,ACK]দিয়ে প্রতিক্রিয়া জানায়। - প্যাকেট
987এ, মেসেজ প্রসেসর ব্যাকএন্ড সার্ভারে[FIN,ACK]দিয়ে সাড়া দেয়। - অবশেষে উভয় দিক থেকে
[ACK]এবং[RST]দিয়ে সংযোগ বন্ধ করা হয়। - যেহেতু ব্যাকএন্ড সার্ভার
[FIN,ACK]পাঠায়, আপনিjava.io.EOFException: eof unexpectedব্যতিক্রম পাবেন।
- প্যাকেট
- ব্যাকএন্ড সার্ভারে নেটওয়ার্ক সমস্যা হলে এটি ঘটতে পারে। এই সমস্যাটি আরও তদন্ত করতে আপনার নেটওয়ার্ক অপারেশন টিমকে নিযুক্ত করুন৷
রেজোলিউশন
ব্যাকএন্ড সার্ভারে সমস্যাটি যথাযথভাবে ঠিক করুন।
যদি সমস্যাটি অব্যাহত থাকে এবং আপনার 502 Bad Gateway Error সমস্যা সমাধানে সহায়তার প্রয়োজন হয় বা আপনি সন্দেহ করেন যে এটি এজের মধ্যে একটি সমস্যা, Apigee Edge সহায়তার সাথে যোগাযোগ করুন।
কারণ: ভুলভাবে কনফিগার করা জীবিত রাখা সময় শেষ
এটি 502 ত্রুটির কারণ কিনা তা নির্ণয় করার আগে, অনুগ্রহ করে নিম্নলিখিত ধারণাগুলি পড়ুন।
Apigee মধ্যে অবিরাম সংযোগ
Apigee ডিফল্টরূপে (এবং HTTP/1.1 স্ট্যান্ডার্ড অনুসরণ করে) লক্ষ্য ব্যাকএন্ড সার্ভারের সাথে যোগাযোগ করার সময় স্থায়ী সংযোগ ব্যবহার করে। স্থায়ী সংযোগগুলি ইতিমধ্যে প্রতিষ্ঠিত একটি TCP এবং (যদি প্রযোজ্য হয়) TLS/SSL সংযোগকে পুনরায় ব্যবহার করার অনুমতি দিয়ে কর্মক্ষমতা বাড়াতে পারে, যা লেটেন্সি ওভারহেডগুলিকে হ্রাস করে। যে সময়কালের জন্য একটি সংযোগ অব্যাহত রাখা প্রয়োজন তা একটি সম্পত্তির মাধ্যমে নিয়ন্ত্রিত হয় জীবিত টাইমআউট ( keepalive.timeout.millis )।
ব্যাকএন্ড সার্ভার এবং Apigee মেসেজ প্রসেসর উভয়ই একে অপরের সাথে সংযোগগুলি খোলা রাখার জন্য জীবন্ত টাইমআউট ব্যবহার করে। একবার জীবিত রাখার সময়সীমার মধ্যে কোনও ডেটা না পাওয়া গেলে, ব্যাকএন্ড সার্ভার বা মেসেজ প্রসেসর অন্যটির সাথে সংযোগ বন্ধ করতে পারে।
Apigee-তে একটি মেসেজ প্রসেসরে মোতায়েন করা API প্রক্সিগুলি, ডিফল্টরূপে, ওভাররাইড না করা পর্যন্ত একটি লাইভ টাইমআউট 60s এ সেট করা থাকে। একবার 60s জন্য কোনো ডেটা না পাওয়া গেলে, Apigee ব্যাকএন্ড সার্ভারের সাথে সংযোগ বন্ধ করে দেবে। ব্যাকএন্ড সার্ভারটি কিপ অ্যালাইভ টাইমআউটও বজায় রাখবে এবং একবার মেয়াদ শেষ হয়ে গেলে ব্যাকএন্ড সার্ভারটি মেসেজ প্রসেসরের সাথে সংযোগ বন্ধ করে দেবে।
টাইমআউট কনফিগারেশনকে জীবিত রাখা ভুলের অন্তর্নিহিততা
যদি Apigee বা ব্যাকএন্ড সার্ভার ভুল রাখা টাইমআউটের সাথে কনফিগার করা হয়, তাহলে এটি একটি রেস কন্ডিশনে পরিণত হয় যার ফলে ব্যাকএন্ড সার্ভার একটি রিসোর্সের অনুরোধের প্রতিক্রিয়ায় একটি অপ্রত্যাশিত End Of File (FIN) পাঠাতে পারে।
উদাহরণস্বরূপ, যদি আপস্ট্রিম ব্যাকএন্ড সার্ভারের টাইমআউটের চেয়ে বেশি বা সমান মান সহ API প্রক্সি বা মেসেজ প্রসেসরের মধ্যে Keep alive টাইমআউট কনফিগার করা হয়, তাহলে নিম্নলিখিত রেস অবস্থা ঘটতে পারে। অর্থাৎ, যদি বার্তা প্রসেসর ব্যাকএন্ড সার্ভারের থ্রেশহোল্ডের খুব কাছাকাছি না আসা পর্যন্ত কোনো ডেটা না পায়, তাহলে একটি অনুরোধ আসে এবং বিদ্যমান সংযোগ ব্যবহার করে ব্যাকএন্ড সার্ভারে পাঠানো হয়। নীচে ব্যাখ্যা করা অপ্রত্যাশিত EOF ত্রুটির কারণে এটি 502 Bad Gateway হতে পারে:
- ধরা যাক মেসেজ প্রসেসর এবং ব্যাকএন্ড সার্ভার উভয়ের জন্যই কিপ অ্যালাইভ টাইমআউট সেট করা হয়েছে 60 সেকেন্ড এবং নির্দিষ্ট মেসেজ প্রসেসর দ্বারা পূর্ববর্তী অনুরোধটি পরিবেশন করার 59 সেকেন্ড পর্যন্ত কোনো নতুন অনুরোধ আসেনি।
- বার্তা প্রসেসর এগিয়ে যায় এবং বিদ্যমান সংযোগ ব্যবহার করে 59তম সেকেন্ডে আসা অনুরোধটি প্রক্রিয়া করে (যেহেতু জীবিত রাখার সময়সীমা শেষ হয়নি) এবং অনুরোধটি ব্যাকএন্ড সার্ভারে পাঠায়।
- যাইহোক, ব্যাকএন্ড সার্ভারে অনুরোধ আসার আগে ব্যাকএন্ড সার্ভারে কিপ অ্যালাইভ টাইমআউট থ্রেশহোল্ড অতিক্রম করা হয়েছে।
- রিসোর্সের জন্য মেসেজ প্রসেসরের অনুরোধ ইন-ফ্লাইট, কিন্তু ব্যাকএন্ড সার্ভার মেসেজ প্রসেসরে একটি
FINপ্যাকেট পাঠিয়ে সংযোগ বন্ধ করার চেষ্টা করে। - যখন মেসেজ প্রসেসর ডেটা পাওয়ার জন্য অপেক্ষা করছে, এটি পরিবর্তে অপ্রত্যাশিত
FINপায়, এবং সংযোগটি বন্ধ হয়ে যায়। - এর ফলে একটি
Unexpected EOFহয় এবং পরবর্তীতে মেসেজ প্রসেসর দ্বারা ক্লায়েন্টকে502ফেরত দেওয়া হয়।
এই ক্ষেত্রে, আমরা লক্ষ্য করেছি যে 502 ত্রুটি ঘটেছে কারণ 60 সেকেন্ডের একই কিপ অ্যালাইভ টাইমআউট মান মেসেজ প্রসেসর এবং ব্যাকএন্ড সার্ভার উভয়েই কনফিগার করা হয়েছিল। একইভাবে, এই সমস্যাটিও ঘটতে পারে যদি ব্যাকএন্ড সার্ভারের তুলনায় মেসেজ প্রসেসরে জীবিত টাইমআউট রাখার জন্য উচ্চতর মান কনফিগার করা হয়।
রোগ নির্ণয়
- আপনি যদি একজন পাবলিক ক্লাউড ব্যবহারকারী হন:
- API মনিটরিং বা ট্রেস টুল ব্যবহার করুন ( সাধারণ নির্ণয়ের ধাপে ব্যাখ্যা করা হয়েছে) এবং যাচাই করুন যে আপনার কাছে নিম্নলিখিত উভয় সেটিংস রয়েছে:
- ফল্ট কোড:
messaging.adaptors.http.flow.UnexpectedEOFAtTarget - ফল্ট উত্স:
target
- ফল্ট কোড:
- আরও তদন্তের জন্য tcpdump ব্যবহারে যান।
- API মনিটরিং বা ট্রেস টুল ব্যবহার করুন ( সাধারণ নির্ণয়ের ধাপে ব্যাখ্যা করা হয়েছে) এবং যাচাই করুন যে আপনার কাছে নিম্নলিখিত উভয় সেটিংস রয়েছে:
- আপনি যদি ব্যক্তিগত ক্লাউড ব্যবহারকারী হন:
-
502ত্রুটির জন্য বার্তা আইডি, ফল্ট কোড এবং ফল্ট উৎস নির্ধারণ করতে ট্রেস টুল বা NGINX অ্যাক্সেস লগ ব্যবহার করুন। - মেসেজ প্রসেসর লগে মেসেজ আইডি খুঁজুন
(/opt/apigee/var/log/edge-message-processor/logs/system.log)। - আপনি
java.io.EOFEXception: eof unexpectedনীচে দেখানো হয়েছে:2020-11-22 14:42:39,917 org:myorg env:prod api:myproxy rev:1 messageid:myorg-opdk-dc1-node2-17812-56001-1 NIOThread@1 ERROR HTTP.CLIENT - HTTPClient$Context$3.onException() : ClientChannel[Connected: Remote:51.254.225.9:80 Local:10.154.0.61:35326]@12972 useCount=7 bytesRead=0 bytesWritten=159 age=7872ms lastIO=479ms isOpen=true.onExceptionRead exception: {} java.io.EOFException: eof unexpected at com.apigee.nio.channels.PatternInputChannel.doRead(PatternInputChannel.java:45) at com.apigee.nio.channels.InputChannel.read(InputChannel.java:103) at com.apigee.protocol.http.io.MessageReader.onRead(MessageReader.java:80) at com.apigee.nio.channels.DefaultNIOSupport$DefaultIOChannelHandler.onIO(NIOSupport.java:51) at com.apigee.nio.handlers.NIOThread.run(NIOThread.java:220)
- ত্রুটি
java.io.EOFException: eof unexpectedনির্দেশ করে যে বার্তা প্রসেসর একটিEOFপেয়েছে যখন এটি এখনও ব্যাকএন্ড সার্ভার থেকে প্রতিক্রিয়া পড়ার অপেক্ষায় ছিল। - উপরের ত্রুটি বার্তায়
useCount=7বৈশিষ্ট্যটি নির্দেশ করে যে মেসেজ প্রসেসর এই সংযোগটি প্রায় সাত বার পুনরায় ব্যবহার করেছে এবং অ্যাট্রিবিউটbytesWritten=159নির্দেশ করে যে মেসেজ প্রসেসর ব্যাকএন্ড সার্ভারে159বাইটের অনুরোধ পেলোড পাঠিয়েছে। যদিও অপ্রত্যাশিতEOFঘটলে এটি শূন্য বাইট ফিরে পেয়েছে। এটি দেখায় যে মেসেজ প্রসেসর একই সংযোগ একাধিকবার পুনঃব্যবহার করেছে এবং এই উপলক্ষ্যে এটি ডেটা পাঠিয়েছে কিন্তু কিছুক্ষণ পরেই কোনও ডেটা প্রাপ্তির আগে একটি
EOFপেয়েছে। এর মানে হল যে ব্যাকএন্ড সার্ভারের কিপ অ্যালাইভ টাইমআউট এপিআই প্রক্সিতে সেটের তুলনায় ছোট বা সমান হওয়ার সম্ভাবনা রয়েছে।আপনি নীচে ব্যাখ্যা অনুযায়ী
tcpdumpএর সাহায্যে আরও তদন্ত করতে পারেন।
-
tcpdump ব্যবহার করে
- নিম্নলিখিত কমান্ড দিয়ে ব্যাকএন্ড সার্ভারে একটি
tcpdumpক্যাপচার করুন:tcpdump -i any -s 0 host MP_IP_Address -w File_Name
- ক্যাপচার করা
tcpdumpবিশ্লেষণ করুন:এখানে একটি নমুনা tcpdump আউটপুট:

উপরের নমুনা
tcpdump, আপনি নিম্নলিখিত দেখতে পারেন:- প্যাকেট
5992,ব্যাকএন্ড সার্ভার একটিGETঅনুরোধ পেয়েছে। - প্যাকেটে
6064, এটি200 OK. - প্যাকেট
6084এ, ব্যাকএন্ড সার্ভার আরেকটিGETঅনুরোধ পেয়েছে। - প্যাকেটে
6154, এটি200 OKদিয়ে সাড়া দেয়। - প্যাকেট
6228এ, ব্যাকএন্ড সার্ভার একটি তৃতীয়GETঅনুরোধ পেয়েছে। - এইবার, ব্যাকএন্ড সার্ভার একটি
FIN, ACKফেরত দেয় মেসেজ প্রসেসরে (প্যাকেট6285) সংযোগ বন্ধ করার শুরু করে।
এই উদাহরণে একই সংযোগটি দুবার সফলভাবে পুনরায় ব্যবহার করা হয়েছে, কিন্তু তৃতীয় অনুরোধে, ব্যাকএন্ড সার্ভার সংযোগটি বন্ধ করার সূচনা করে, যখন বার্তা প্রসেসর ব্যাকএন্ড সার্ভার থেকে ডেটার জন্য অপেক্ষা করছে। এটি পরামর্শ দেয় যে ব্যাকএন্ড সার্ভারের কিপ অ্যালাইভ টাইমআউট সম্ভবত API প্রক্সিতে সেট করা মানের থেকে ছোট বা সমান। এটি যাচাই করার জন্য, Apigee এবং ব্যাকএন্ড সার্ভারে তুলনা করুন জীবিত সময় শেষ দেখুন।
- প্যাকেট
Apigee এবং ব্যাকএন্ড সার্ভারে লাইভ টাইমআউট রাখার তুলনা করুন
- ডিফল্টরূপে, Apigee লাইভ টাইমআউট বৈশিষ্ট্যের জন্য 60 সেকেন্ডের মান ব্যবহার করে।
যাইহোক, এটা সম্ভব যে আপনি API প্রক্সিতে ডিফল্ট মানটিকে ওভাররাইড করেছেন। আপনি ব্যর্থ API প্রক্সিতে নির্দিষ্ট
TargetEndpointসংজ্ঞা পরীক্ষা করে এটি যাচাই করতে পারেন যা502ত্রুটি দিচ্ছে।নমুনা TargetEndpoint কনফিগারেশন:
<TargetEndpoint name="default"> <HTTPTargetConnection> <URL>https://mocktarget.apigee.net/json</URL> <Properties> <Property name="keepalive.timeout.millis">30000</Property> </Properties> </HTTPTargetConnection> </TargetEndpoint>উপরের উদাহরণে, 30 সেকেন্ড (
30000মিলিসেকেন্ড) মান দিয়ে কিপ অ্যালাইভ টাইমআউট প্রপার্টি ওভাররাইড করা হয়েছে।- এর পরে, আপনার ব্যাকএন্ড সার্ভারে কনফিগার করা জীবিত টাইমআউট সম্পত্তি চেক করুন। ধরা যাক আপনার ব্যাকএন্ড সার্ভার
25 secondsমান দিয়ে কনফিগার করা হয়েছে। - আপনি যদি নির্ধারণ করেন যে Apigee-এ কিপ অ্যালাইভ টাইমআউট প্রপার্টির মান উপরের উদাহরণের মতো ব্যাকএন্ড সার্ভারে কিপ অ্যালাইভ টাইমআউট প্রপার্টির মান থেকে বেশি, তাহলে এটি
502ত্রুটির কারণ।
রেজোলিউশন
ব্যাকএন্ড সার্ভারের তুলনায় অ্যাপিজিতে (এপিআই প্রক্সি এবং মেসেজ প্রসেসর উপাদানে) জীবিত টাইমআউট বৈশিষ্ট্য সবসময় কম থাকে তা নিশ্চিত করুন।
- ব্যাকএন্ড সার্ভারে কিপ অ্যালাইভ টাইমআউটের জন্য সেট করা মান নির্ধারণ করুন।
- API প্রক্সি বা মেসেজ প্রসেসরে কিপ অ্যালাইভ টাইমআউট প্রপার্টির জন্য একটি উপযুক্ত মান কনফিগার করুন, যেমন বার্তা প্রসেসরে লাইভ টাইমআউট কনফিগার করা কনফিগারিং- এ বর্ণিত ধাপগুলি ব্যবহার করে ব্যাকএন্ড সার্ভারে সেট করা মানের থেকে কম রাখুন।
যদি সমস্যা এখনও থেকে যায়, তাহলে ডায়াগনস্টিক তথ্য সংগ্রহ করতে হবে ।
সর্বোত্তম অনুশীলন
এটি দৃঢ়ভাবে পরামর্শ দেওয়া হয় যে ডাউনস্ট্রিম উপাদানগুলির সর্বদা এই ধরণের রেস পরিস্থিতি এবং 502 ত্রুটিগুলি এড়াতে আপস্ট্রিম সার্ভারগুলিতে কনফিগার করা থেকে কম জীবিত টাইমআউট থ্রেশহোল্ড থাকে৷ প্রতিটি ডাউনস্ট্রিম হপ প্রতিটি আপস্ট্রিম হপের চেয়ে কম হওয়া উচিত। Apigee Edge এ, নিম্নলিখিত নির্দেশিকাগুলি ব্যবহার করা ভাল অনুশীলন:
- ক্লায়েন্ট কিপ অ্যালাইভ টাইমআউট এজ রাউটার কিপ অ্যালাইভ টাইমআউটের চেয়ে কম হওয়া উচিত।
- এজ রাউটার কিপ লাইভ টাইমআউট মেসেজ প্রসেসরের লাইভ টাইমআউটের চেয়ে কম হওয়া উচিত।
- মেসেজ প্রসেসর কিপ অ্যালাইভ টাইমআউট টার্গেট সার্ভারের থেকে কম হওয়া উচিত।
- যদি আপনার Apigee এর সামনে বা পিছনে অন্য কোন হপ থাকে, একই নিয়ম প্রয়োগ করা উচিত। আপস্ট্রিমের সাথে সংযোগ বন্ধ করার জন্য আপনাকে সর্বদা ডাউনস্ট্রিম ক্লায়েন্টের দায়িত্ব হিসাবে ছেড়ে দেওয়া উচিত।
ডায়াগনস্টিক তথ্য সংগ্রহ করতে হবে
উপরের নির্দেশাবলী অনুসরণ করার পরেও যদি সমস্যাটি থেকে যায়, তাহলে নিম্নলিখিত ডায়াগনস্টিক তথ্য সংগ্রহ করুন এবং তারপর Apigee Edge সাপোর্টের সাথে যোগাযোগ করুন।
আপনি যদি একজন পাবলিক ক্লাউড ব্যবহারকারী হন, তাহলে নিম্নলিখিত তথ্য প্রদান করুন:
- প্রতিষ্ঠানের নাম
- পরিবেশের নাম
- API প্রক্সি নাম
-
502ত্রুটি পুনরুত্পাদন করতেcurlকমান্ডটি সম্পূর্ণ করুন -
502 Bad Gateway - Unexpected EOFত্রুটি৷ - যদি
502ত্রুটি বর্তমানে ঘটছে না, অতীতে যখন502ত্রুটি ঘটেছে সময় অঞ্চলের তথ্য সহ সময়কাল প্রদান করুন।
আপনি যদি একজন ব্যক্তিগত ক্লাউড ব্যবহারকারী হন, তাহলে নিম্নলিখিত তথ্য প্রদান করুন:
- ব্যর্থ অনুরোধের জন্য পরিলক্ষিত সম্পূর্ণ ত্রুটি বার্তা
- প্রতিষ্ঠান, পরিবেশের নাম এবং API প্রক্সি নাম যার জন্য আপনি
502ত্রুটি পর্যবেক্ষণ করছেন - API প্রক্সি বান্ডেল
-
502 Bad Gateway - Unexpected EOFত্রুটি৷ - NGINX অ্যাক্সেস লগ
/opt/apigee/var/log/edge-router/nginx/ ORG ~ ENV . PORT# _access_log - বার্তা প্রসেসর লগ
/opt/apigee/var/log/edge-message-processor/logs/system.log - টাইমজোন তথ্য সহ সময়কাল যখন
502ত্রুটি ঘটেছে -
Tcpdumpsমেসেজ প্রসেসর বা ব্যাকএন্ড সার্ভারে বা উভয়েই যখন ত্রুটি ঘটেছে