আপনি Apigee Edge ডকুমেন্টেশন দেখছেন।
Apigee X ডকুমেন্টেশনে যান । তথ্য
উপসর্গ
ক্লায়েন্ট অ্যাপ্লিকেশনটি 404 এর একটি HTTP স্ট্যাটাস কোড পায় মেসেজটি Not Found এবং ত্রুটি বার্তাটি Unable to identify proxy for host: VIRTUAL_HOST and url: PATH API কলগুলির প্রতিক্রিয়া হিসাবে।
এই ত্রুটির মানে হল যে এজ নির্দিষ্ট ভার্চুয়াল হোস্ট এবং পাথের জন্য API প্রক্সি খুঁজে পায়নি।
ত্রুটি বার্তা
ক্লায়েন্ট অ্যাপ্লিকেশন নিম্নলিখিত প্রতিক্রিয়া কোড পায়:
HTTP/1.1 404 Not Found
উপরন্তু, আপনি নীচে দেখানো একটির মত একটি ত্রুটি বার্তা পর্যবেক্ষণ করতে পারেন:
{
"fault":{
"faultstring":"Unable to identify proxy for host: default and url: \/oauth2\/token",
"detail":{
"errorcode":"messaging.adaptors.http.flow.ApplicationNotFound"
}
}
}সম্ভাব্য কারণ
| কারণ | বর্ণনা | সমস্যা সমাধানের নির্দেশাবলী প্রযোজ্য |
|---|---|---|
| ডুপ্লিকেট হোস্ট উপনাম সহ ভার্চুয়াল হোস্ট | একাধিক ভার্চুয়াল হোস্টের একই হোস্ট উপনাম এবং পোর্ট নম্বর রয়েছে। | এজ পাবলিক এবং প্রাইভেট ক্লাউড ব্যবহারকারীরা |
সাধারণ রোগ নির্ণয়ের পদক্ষেপ
NGINX এবং মেসেজ প্রসেসর লগ 404 ত্রুটির সমস্যা সমাধানে সহায়ক হবে। লগ চেক করতে নিম্নলিখিত পদক্ষেপগুলি ব্যবহার করুন:
- নিম্নলিখিত কমান্ডটি ব্যবহার করে NGINX লগগুলি দেখুন:
/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_log
- লগ এন্ট্রিতে নিম্নলিখিত ক্ষেত্রগুলি পরীক্ষা করুন:
মাঠ মান Upstream_status, status404X-Apigee-fault-codemessaging.adaptors.http.flow.ApplicationNotFoundলগ থেকে বার্তা আইডি একটি নোট করুন.
- মেসেজ প্রসেসর লগগুলি (
/opt/apigee/var/log/edge-message-processor/logs/system.log)পরীক্ষা করে দেখুন আপনার কাছে নির্দিষ্ট API-এর জন্যmessaging.adaptors.http.flow.ApplicationNotFoundআছে কিনা বা আপনার কাছে আছে কিনা API অনুরোধের জন্য ধাপ 2 থেকে অনন্য বার্তা আইডি।বার্তা প্রসেসর লগ থেকে নমুনা ত্রুটি বার্তা
NIOThread@1 ERROR ADAPTORS.HTTP.FLOW - AbstractRequestListener.onException() : Request:POST, uri:/weather, message Id:null, exception:com.apigee.rest.framework.ResourceNotFoundException{ code = messaging.adaptors.http.flow.ApplicationNotFound, message = Unable to identify proxy for host: vh1 and url: /weather, associated contexts = []}, context:Context@342ea86b input=ClientInputChannel(SSLClientChannel[Accepted: Remote:10.123.123.123:8443 Local:10.135.33.68:62092]@1206954 useCount=1 bytesRead=0 bytesWritten=0 age=1ms lastIO=0ms isOpen=true)
উপরের লগটি ত্রুটি কোড দেখায় এবং ত্রুটি বার্তাটি নিম্নরূপ:
code = messaging.adaptors.http.flow.ApplicationNotFound, message = Unable to identify proxy for host: vh1 and url: /weather
কারণ: একই হোস্ট উপনাম এবং পোর্ট নম্বর সহ একাধিক ভার্চুয়াল হোস্ট
Apigee এজ রাউটার এবং মেসেজ প্রসেসর সঠিক API প্রক্সিতে ট্র্যাফিক রুট করতে হোস্ট হেডার, পোর্ট নম্বর এবং URI পাথ উভয়ই ব্যবহার করে। একই হোস্ট উপনাম এবং পোর্ট নম্বর সহ একাধিক ভার্চুয়াল হোস্টের মতো অস্পষ্ট সংজ্ঞা থাকা একটি নথিভুক্ত অ্যান্টি-প্যাটার্ন এবং এটি অপ্রত্যাশিত আচরণের দিকে নিয়ে যেতে পারে। আপনি যে সাধারণ ত্রুটিগুলি লক্ষ্য করবেন তার মধ্যে একটি হল হোস্টের জন্য প্রক্সি সনাক্ত করতে অক্ষম বার্তাটির সাথে একটি 404 ত্রুটি Unable to identify proxy for host: VIRTUAL_HOST and url: PATH ৷
সাধারণত যদি একই হোস্ট উপনাম সহ একাধিক ভার্চুয়াল হোস্ট বিদ্যমান থাকে, তাহলে আপনি মাঝে মাঝে 404 ত্রুটিগুলি পর্যবেক্ষণ করবেন। এর কারণ হল নির্দিষ্ট API প্রক্সি শুধুমাত্র ভার্চুয়াল হোস্টগুলির একটিতে অনুরোধগুলি গ্রহণ করার জন্য কনফিগার করা হতে পারে। যখন API অনুরোধগুলি API প্রক্সিতে কনফিগার করা নির্দিষ্ট ভার্চুয়াল হোস্টে রুট করা হয়, আপনি একটি সফল প্রতিক্রিয়া পাবেন। যাইহোক, যখন API অনুরোধগুলি অন্য ভার্চুয়াল হোস্টগুলিতে পাঠানো হয় যেখানে API প্রক্সি অনুরোধগুলি গ্রহণ করার জন্য কনফিগার করা হয়নি, তখন API গুলি এই 404 ত্রুটিগুলির সাথে ব্যর্থ হবে৷
404-এ প্রদত্ত নির্দেশাবলী অনুসরণ করুন হোস্টের জন্য প্রক্সি সনাক্ত করতে অক্ষম: <virtual host name> এবং url: <path> এবং এই ত্রুটির সমস্যা সমাধান করুন। যদি কোনও কারণই এই ত্রুটির দিকে পরিচালিত না করে, তাহলে ডুপ্লিকেট হোস্ট উপনাম সহ ভার্চুয়াল হোস্টগুলি 404 ত্রুটি ঘটাচ্ছে কিনা তা নির্ধারণ করতে নীচের পদক্ষেপগুলি ব্যবহার করুন৷
রোগ নির্ণয়
একই হোস্ট উপনাম/পোর্ট # 404 ত্রুটির দিকে পরিচালিত একাধিক ভার্চুয়াল হোস্ট আছে কিনা তা নির্ধারণ করতে নিম্নলিখিত পদ্ধতিগুলির মধ্যে একটি ব্যবহার করুন:
- এজ UI
- ব্যবস্থাপনা APIs
এজ UI
Edge UI ব্যবহার করে একই হোস্ট উপনাম/পোর্ট # থাকা একাধিক ভার্চুয়াল হোস্ট আছে কিনা তা নির্ধারণ করতে এই নির্দেশাবলী ব্যবহার করুন।
উদাহরণস্বরূপ, আপনি যদি 404 ত্রুটিটি url http://example.com:9001/proxy1 দেখে থাকেন, তাহলে আপনাকে খুঁজে বের করতে হবে কোন ভার্চুয়াল হোস্টে হোস্ট alias example.com এবং পোর্ট 9001 আছে।
- পাবলিক ক্লাউডে এবং প্রাইভেট ক্লাউডে নতুন এজ UI :
- অ্যাডমিন নির্বাচন করুন।
- ভার্চুয়াল হোস্ট নির্বাচন করুন।
- প্রতিটি পরিবেশের জন্য ভার্চুয়াল হোস্ট নির্ধারণ করতে অনুসন্ধান ফিল্টার ব্যবহার করুন যা নির্দিষ্ট হোস্ট উপনামের সাথে মেলে যার সাথে API অনুরোধগুলি আহ্বান করা হয়েছিল৷
- আপনি যদি একই হোস্ট উপনাম ব্যবহার করে একাধিক ভার্চুয়াল হোস্ট খুঁজে পান তবে এই সমস্যাটি সমাধান করতে রেজোলিউশনে যান।
যেমন:

- ব্যক্তিগত ক্লাউডে ক্লাসিক UI- তে:
- APIs ট্যাব নির্বাচন করুন।
- এনভায়রনমেন্ট কনফিগারেশন নির্বাচন করুন।
- ভার্চুয়াল হোস্ট নির্বাচন করুন।
- প্রতিটি পরিবেশের জন্য ভার্চুয়াল হোস্টের তালিকা দেখুন যে নির্দিষ্ট হোস্ট উপনামের সাথে API অনুরোধগুলি আহ্বান করা হয়েছিল তার সাথে মিল আছে কিনা।
- আপনি যদি একই হোস্ট আলিয়াসের সাথে মিলে যাওয়া একাধিক ভার্চুয়াল হোস্ট খুঁজে পান তবে এই সমস্যাটি সমাধান করতে রেজোলিউশনে যান।
উদাহরণ স্বরূপ:

ব্যবস্থাপনা APIs
ম্যানেজমেন্ট এপিআই ব্যবহার করে একই হোস্ট উপনাম/পোর্ট # থাকা একাধিক ভার্চুয়াল হোস্ট আছে কিনা তা নির্ধারণ করতে এই নির্দেশাবলী ব্যবহার করুন।
কোন ভার্চুয়াল হোস্টের একই হোস্ট উপনাম এবং পোর্ট নম্বর রয়েছে তা দেখতে আপনার প্রতিষ্ঠানের প্রতিটি পরিবেশে প্রতিটি ভার্চুয়াল হোস্টের সংজ্ঞা পান:
উদাহরণস্বরূপ, আপনি যদি
404ত্রুটিটি urlhttp://example.com:9001/proxy1দেখে থাকেন, তাহলে আপনাকে খুঁজে বের করতে হবে কোন ভার্চুয়াল হোস্টে হোস্ট aliasexample.comএবং পোর্ট9001আছে।পরিবেশের তালিকা পান
পাবলিক ক্লাউড ব্যবহারকারী:
curl -v -X GET https//api.enterprise.apigee.com/v1/organizations/ORGANIZATION_NAME/environments -u USERNAME
ব্যক্তিগত ক্লাউড ব্যবহারকারী:
curl -v -X GET http://MANAGEMENT_HOST:PORT#/v1/organizations/ORGANIZATION_NAME/environments -u USERNAME
কোথায়:
ORGANIZATION_NAME হল সংগঠনের নাম
উদাহরণ:
curl http://127.0.0.1:8080/v1/organizations/myorg/environments -u USERNAME
[ "prod", "test", "dev" ]
একটি পরিবেশে ভার্চুয়াল হোস্টের তালিকা পান
পাবলিক ক্লাউড ব্যবহারকারী:
curl -v -X GET https//api.enterprise.apigee.com/v1/organizations/ORGANIZATION_NAME/environments/ENVIRONMENT_NAME/virtualhosts -u USERNAME
ব্যক্তিগত ক্লাউড ব্যবহারকারী:
curl -v -X GET http://MANAGEMENT_HOST:PORT#/v1/organizations/ORGANIZATION_NAME/environments/ENVIRONMENT_NAME/virtualhosts -u USERNAME
কোথায়:
ORGANIZATION_NAME হল সংগঠনের নাম
ENVIRONMENT_NAME হল পরিবেশের নাম
উদাহরণ:
curl http://127.0.0.1:8080/v1/organizations/myorg/environments/test/virtualhosts -u USERNAME
[ "default" ]
পরিবেশের প্রতিটি ভার্চুয়াল হোস্টের সংজ্ঞা পান।
পাবলিক ক্লাউড ব্যবহারকারী:
curl -v -X GET https//api.enterprise.apigee.com/v1/organizations/ORGANIZATION_NAME/environments/ENVIRONMENT_NAME/virtualhosts/VIRTUAL_HOST_NAME -u USERNAME
ব্যক্তিগত ক্লাউড ব্যবহারকারী:
curl -v -X GET http://MANAGEMENT_HOST:PORT#/v1/organizations/ORGANIZATION_NAME/environments/ENVIRONMENT_NAME/virtualhosts/VIRTUAL_HOST_NAME -u USERNAME
কোথায়:
ORGANIZATION_NAME হল সংগঠনের নাম
ENVIRONMENT_NAME হল পরিবেশের নাম
VIRTUAL_HOST_NAME হল ভার্চুয়াল হোস্টের নাম
উদাহরণ:
curl http://127.0.0.1:8080/v1/organizations/myorg/environments/test/virtualhosts/default -u USERNAME
{ "hostAliases" : [ "example.com" ], "interfaces" : [ ], "listenOptions" : [ ], "name" : "default", "port" : "9001", "retryOptions" : [ ] }আপনার প্রতিষ্ঠানের অন্যান্য পরিবেশের জন্য উপরের দুটি ধাপ পুনরাবৃত্তি করুন।
এই উদাহরণে,
devপরিবেশের জন্য পদক্ষেপগুলি পুনরাবৃত্তি করুন:curl http://127.0.0.1:8080/v1/organizations/myorg/environments/dev/virtualhosts -u USERNAME
[ "default" ]
curl http://127.0.0.1:8080/v1/organizations/myorg/environments/dev/virtualhosts/default -u USERNAME
{ "hostAliases" : [ "example.com" ], "interfaces" : [ ], "listenOptions" : [ ], "name" : "default", "port" : "9001", "retryOptions" : [ ] }এই উদাহরণে আপনি দেখতে পাচ্ছেন যে দুটি ভার্চুয়াল হোস্ট দুটি ভিন্ন পরিবেশে
default,testএবংdev, উভয়েই একই হোস্ট ওরফেexample.comএবং পোর্ট নম্বর9001রয়েছে। এটি404ত্রুটির কারণ।- আপনি যদি একই হোস্ট আলিয়াসের সাথে মিলে যাওয়া একাধিক ভার্চুয়াল হোস্ট খুঁজে পান তবে এই সমস্যাটি সমাধান করতে রেজোলিউশনে যান।
রেজোলিউশন
- নিশ্চিত করুন যে প্রতিটি ভার্চুয়াল হোস্টে শুধুমাত্র অনন্য হোস্ট উপনাম এবং পোর্ট সমন্বয় রয়েছে।
- আপনি যদি একই হোস্ট উপনাম এবং পোর্ট সংমিশ্রণ সহ একাধিক ভার্চুয়াল হোস্ট সনাক্ত করে থাকেন তবে আপনাকে অবশ্যই একটি অনন্য হোস্ট উপনাম দিয়ে আপডেট করতে হবে।
- আপনি এজ ইউআই বা ম্যানেজমেন্ট এপিআই ব্যবহার করে এগুলি আপডেট করতে পারেন, একটি ভার্চুয়াল হোস্ট পরিবর্তন করার অধীনে নির্দেশাবলী পাওয়া যাবে।
- নিশ্চিত করুন যে প্রতিটি হোস্ট উপনামের একটি সঠিক DNS এন্ট্রি আছে।
- উপরে আলোচিত উদাহরণে যদি আমাদের কনফিগারেশনটি এরকম দেখায়:
curl -X GET http://localhost:8080/v1/organizations/myorg/environments -u user
[ "prod", "test", "dev" ]
curl -X GET http://localhost:8080/v1/organizations/myorg/environments/test/virtualhosts/default -u user
{ "hostAliases" : [ "example.com" ], "interfaces" : [ ], "listenOptions" : [ ], "name" : "default", "port" : "9001", "retryOptions" : [ ] }curl -X GET http://localhost:8080/v1/organizations/myorg/environments/dev/virtualhosts/default -u user
{ "hostAliases" : [ "example.com" ], "interfaces" : [ ], "listenOptions" : [ ], "name" : "default", "port" : "9001", "retryOptions" : [ ] }- আপনি ভুল ভার্চুয়াল হোস্ট আপডেট করতে পারেন যাতে তারা ওভারল্যাপ না হয়।
- এটি হল
example2.comহিসাবে হোস্ট উপনাম আপডেট করুন। - নিশ্চিত করুন যে নতুন হোস্ট উপনামের পূর্ববর্তী হোস্ট উপনামের মতো একই DNS এন্ট্রি রয়েছে।
curl -X GET http://localhost:8080/v1/organizations/myorg/environments/dev/virtualhosts/default -u user -H 'Content-Type: application/json' -d '{ "hostAliases" : [ "example2.com" ], "interfaces" : [ ], "listenOptions" : [ ], "name" : "default", "port" : "9001", "retryOptions" : [ ] }' -iHTTP/1.1 200 OK Date: Tue, 02 Feb 2021 20:54:29 GMT Content-Type: application/json X-Apigee.user: user X-Apigee.organization: myorg X-Apigee.environment: dev X-Apigee.backends: management-server Date: Tue, 02 Feb 2021 20:54:29 GMT Content-Length: 152 { "hostAliases" : [ "example2.com" ], "interfaces" : [ ], "listenOptions" : [ ], "name" : "default", "port" : "9001", "retryOptions" : [ ] }
- প্রক্সিতে আবার API কল করুন এবং যাচাই করুন যে আপনি ধারাবাহিকভাবে সফল প্রতিক্রিয়া পাচ্ছেন:
curl http://example.com:9001/proxy1
{ "slideshow": { "author": "Yours Truly", "date": "date of publication", "slides": [ { "title": "Wake up to WonderWidgets!", "type:": "all" }, { "items": [ "Why WonderWidgets are great", "Who buys WonderWidgets" ], "title": "Overview", "type": "all" } ], "title": "Sample Slide Show" } }
- যদি সমস্যা এখনও থেকে যায়, তাহলে ডায়াগনস্টিক তথ্য সংগ্রহ করতে হবে ।
ডায়াগনস্টিক তথ্য সংগ্রহ করতে হবে
উপরের নির্দেশাবলী অনুসরণ করার পরেও যদি সমস্যাটি থেকে যায়, তাহলে নিম্নলিখিত ডায়াগনস্টিক তথ্য সংগ্রহ করুন এবং তারপর Apigee Edge সাপোর্টের সাথে যোগাযোগ করুন:
আপনি যদি একজন পাবলিক ক্লাউড ব্যবহারকারী হন, তাহলে নিম্নলিখিত তথ্য প্রদান করুন:
- প্রতিষ্ঠানের নাম
- পরিবেশের নাম
- API প্রক্সি নাম
-
404ত্রুটি পুনরুত্পাদন করতেcurlকমান্ডটি সম্পূর্ণ করুন - যদি
404ত্রুটি বর্তমানে ঘটছে না, অতীতে যখন404ত্রুটি ঘটেছে টাইমজোন তথ্য সহ সময়কাল প্রদান করুন।
আপনি যদি একজন ব্যক্তিগত ক্লাউড ব্যবহারকারী হন, তাহলে নিম্নলিখিত তথ্য প্রদান করুন:
- ব্যর্থ অনুরোধের জন্য পরিলক্ষিত সম্পূর্ণ ত্রুটি বার্তা
- প্রতিষ্ঠান, পরিবেশের নাম এবং API প্রক্সি নাম যার জন্য আপনি
404ত্রুটি পর্যবেক্ষণ করছেন - API প্রক্সি বান্ডেল
- NGINX অ্যাক্সেস লগ
/opt/apigee/var/log/edge-router/nginx/ ORGANIZATION_NAME ~ ENVIRONMENT_NAME . PORT# _access_log - বার্তা প্রসেসর লগ
/opt/apigee/var/log/edge-message-processor/logs/system.log - টাইমজোন তথ্য সহ সময়কাল যখন
404ত্রুটি ঘটেছে