<ph type="x-smartling-placeholder"></ph>
현재 Apigee Edge 문서를 보고 있습니다.
Apigee X 문서. 정보
증상
클라이언트 애플리케이션이 HTTP 상태 코드 500 Internal Server Error
를 가져옵니다.
API 호출에 대한 응답으로 오류 코드 protocol.http.EmptyPath
오류 메시지
클라이언트 애플리케이션은 다음과 같은 응답 코드를 받습니다.
HTTP/1.1 500 Internal Server Error
또한 다음과 같은 오류 메시지가 표시될 수 있습니다.
{ "fault":{ "faultstring":"Request path cannot be empty", "detail":{ "errorcode":"protocol.http.EmptyPath" } } }
가능한 원인
이 오류는 백엔드 서버의 요청 URL이 흐름 변수로 표현되는 경우 발생합니다.
<ph type="x-smartling-placeholder"></ph>
target.url
에는 빈 경로가 포함되어 있습니다.
사양에 따라 <ph type="x-smartling-placeholder"></ph> RFC 3986, 섹션 3: 구문 구성요소 및 <ph type="x-smartling-placeholder"></ph> RFC 3986, 섹션 3.3: 경로:
URI 구문 에는 다음과 같은 구성요소가 있습니다.
foo://example.com:8042/over/there?name=ferret#nose \_/ \______________/\_________/ \_________/ \__/ | | | | | scheme authority path query fragment
path
구성요소는 필수이며 항상 슬래시를 포함해야 합니다(MUST). (/
)(경로의 일부인 다른 문자가 없더라도)
따라서 백엔드 서버의 요청 URL에 path
즉, 슬래시 (/
)가 없는 경우 Apigee
Edge에서 500 Internal Server Error
및 오류 코드로 응답
protocol.http.EmptyPath
입니다.
예를 들어 target.url
에 값이 있는 경우
https://www.mocktarget.apigee.net
로 설정된 경우 이 오류는
path
구성요소가 비어 있거나 누락되었습니다.
원인 | 설명 | 다음에 관한 문제 해결 안내 |
---|---|---|
백엔드 서버 URL (target.url)의 경로가 비어 있습니다. | 흐름 변수 target.url 으로 표시되는 백엔드 서버 URL의 경로가 비어 있습니다. |
에지 퍼블릭 및 프라이빗 클라우드 사용자 |
일반적인 진단 단계
다음 도구/기술 중 하나를 사용하여 이 오류를 진단합니다.
API 모니터링
절차 #1: API 모니터링 사용
<ph type="x-smartling-placeholder">API 모니터링을 사용하여 오류를 진단하려면 다음 안내를 따르세요.
- <ph type="x-smartling-placeholder"></ph> 다음 권한이 있는 사용자로 Apigee Edge UI에 로그인 적절한 역할을 해야 합니다.
문제를 조사하려는 조직으로 전환합니다.
- 분석 > API 모니터링 > 조사 페이지를 엽니다.
- 오류가 관찰된 특정 기간을 선택합니다.
시간을 기준으로 결함 코드를 표시합니다.
<ph type="x-smartling-placeholder">아래와 같이 오류 코드가
protocol.http.EmptyPath
인 셀을 선택합니다.결함 코드
protocol.http.EmptyPath
에 대한 정보는 다음과 같이 표시됩니다. 다음과 같습니다.로그 보기 를 클릭하여 실패한 요청의 행을 펼칩니다.
- 로그 창에서 다음 세부정보를 확인합니다.
<ph type="x-smartling-placeholder">
- </ph>
- 상태 코드:
500
- 오류 소스:
target
- 오류 코드:
protocol.http.EmptyPath
- 상태 코드:
- 결함 소스가
target
이고 결함 코드가 다음과 같은 경우protocol.http.EmptyPath
이면 백엔드 서버 URL에 빈 경로.
Trace
절차 #2: Trace 도구 사용
<ph type="x-smartling-placeholder">Trace 도구를 사용하여 오류를 진단하는 방법은 다음과 같습니다.
- 추적 세션을 사용 설정하고 다음 중 하나를 수행합니다.
<ph type="x-smartling-placeholder">
- </ph>
500 Internal Server Error
오류가 발생할 때까지 기다립니다.- 문제를 재현할 수 있는 경우 API를 호출하여 문제를 재현합니다.
500 Internal Server Error
모든 FlowInfos 표시가 사용 설정되어 있는지 확인합니다.
- 실패한 요청 중 하나를 선택하고 trace를 검토합니다.
- 추적의 여러 단계를 살펴보고 오류가 발생한 위치를 찾습니다.
이 오류는 일반적으로 Target Request Flow Started(대상 요청 흐름 시작됨) 이후의 흐름에서 찾을 수 있습니다. 단계를 실행할 수 있습니다.
트레이스에서 오류 값을 확인합니다.
오류: 요청 경로는 비워 둘 수 없음
대상 요청 흐름 시작됨 단계 이후에 Apigee Edge에서 오류가 발생하므로 백엔드 서버 URL의
path
가 비어 있음을 나타냅니다. 이렇게 하면 흐름 변수target.url
( 백엔드 서버)가 요청 흐름에 따라 달라집니다- 다음에서 역방향으로 각 흐름에서 읽고 할당된 변수 섹션을 검토합니다. Target Request Flow Started(목표 요청 흐름 시작됨) 단계에 대한 오류 지점을 표시합니다.
흐름 변수
target.url
가 업데이트되는 정책을 결정합니다.JavaScript 정책에서 흐름 변수
target.url
를 업데이트한 것을 보여주는 샘플 트레이스입니다.위에 표시된 샘플 trace에서 흐름 변수 변수의 값을 확인합니다.
target.url
는 SetTargetURL이라는 JavaScript 정책에서 다음과 같이 업데이트됩니다. 다음과 같습니다.target.url : https://mocktarget.apigee.net
target.url
의 구성요소는 다음과 같습니다. <ph type="x-smartling-placeholder">- </ph>
- 스키마:
https://mocktarget.apigee.net
- path: 비어 있음
- 스키마:
- 따라서
Request path cannot be empty
오류가 발생합니다. - 트레이스의 AX (애널리틱스 데이터 기록됨) 단계로 이동하여 클릭합니다.
아래로 스크롤하여 단계 세부정보 - 오류 헤더 섹션으로 이동한 후 X-Apigee-fault-code 및 X-Apigee-fault-source 값이 아래와 같이 표시됩니다.
- X-Apigee-fault-code와 X-Apigee-fault-source의 값이 다음과 같이 표시됩니다.
각각
protocol.http.EmptyPath
및target
를 나타냅니다. 이 오류는 백엔드 서버 URL의 경로가 비어 있기 때문에 발생합니다.응답 헤더 값 X-Apigee-fault-code protocol.http.EmptyPath
X-Apigee-fault-source target
NGINX
절차 #3: NGINX 액세스 로그 사용
<ph type="x-smartling-placeholder">NGINX 액세스 로그를 사용하여 오류를 진단하려면 다음 안내를 따르세요.
- Private Cloud 사용자인 경우 NGINX 액세스 로그를 사용하여
HTTP
500 Internal Server Error
에 대한 주요 정보입니다. NGINX 액세스 로그를 확인합니다.
<ph type="x-smartling-placeholder">/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_log
- 오류 코드와 함께
500
오류가 있는지 검색하여 확인합니다. 특정 기간 동안protocol.http.EmptyPath
(문제가 발생한 기간500
로 여전히 실패하는 요청이 있는지 확인합니다. 일치하는 X-Apigee-fault-code 에
500
오류가 있는 경우protocol.http.EmptyPath
의 값을 사용하고 X-Apigee-fault-source.NGINX 액세스 로그의 샘플 500 오류:
NGINX 액세스 로그의 위 샘플 항목에는 X- Apigee-fault-code 및 X-Apigee-fault-source:
헤더 값 X-Apigee-fault-code protocol.http.EmptyPath
X-Apigee-fault-source target
X-Apigee-fault-code와 X-Apigee-fault-source의 값은 다음과 같습니다. 각각
protocol.http.EmptyPath
및target
를 나타냅니다. 이 오류는 백엔드 서버 URL의 빈 경로가 있기 때문에 발생합니다.
원인: 백엔드 서버 URL (target.url)의 경로가 비어 있습니다.
진단
- 다음에 설명된 대로 API 모니터링, Trace Tool 또는 NGINX 액세스 로그를 사용하여
500 Internal Server Error
의 결함 코드와 오류 소스를 확인합니다. 일반적인 진단 단계. - 오류 코드가
protocol.http.EmptyPath
이고 오류 소스가 다음과 같은 경우 값이target
이면 백엔드 서버 URL에 비어 있는 상태임을 나타냅니다. 경로와 같은 '경로'를 통해 지정할 수 있습니다. 백엔드 서버 URL은 Apigee에서 흐름 변수
<ph type="x-smartling-placeholder">target.url
로 표시됩니다. Edge. 이 오류는 일반적으로 백엔드 서버 URL, 즉 정책 중 하나를 사용하여 동적으로target.url
프록시/공유 흐름)를 사용하여 빈 경로를 갖도록 합니다.- 흐름 변수
target.url
에 실제로 빈 경로가 있는지, 다음 단계 중 하나를 사용하여 값의 소스를 생성합니다.Trace
Trace 도구 사용
이 오류의 트레이스를 캡처한 경우 다음에 설명된 단계를 따르세요. Trace 도구 사용 및 다음 작업 수행
target.url
의 경로가 비어 있는지 확인합니다.답이 '예'인 경우 어떤 정책이
target.url
는 빈 경로를 포함합니다.JavaScript 정책에서 흐름 변수를 업데이트한 것을 보여주는 샘플 트레이스
target.url:
- 위의 샘플 trace에서는 JavaScript 정책이
빈 경로를 포함하도록
target.url
값을 업데이트했습니다. target.url
에는 다음과 같은 구성요소가 있습니다. <ph type="x-smartling-placeholder">- </ph>
- 스키마:
https://mocktarget.apigee.net
- path: 비어 있음
- 스키마:
로그
로그 서버에서 로그 사용
- 이 오류 (간헐적인 문제)에 대한 trace가 없는 경우 다음을 확인하세요.
흐름 변수의 값에 대한 정보를
target.url
: <ph type="x-smartling-placeholder"></ph> MessageLogging 또는 <ph type="x-smartling-placeholder"></ph> Service콜아웃을 로그 서버에 추가합니다. - 로그가 있는 경우 로그를 검토하고 다음을 수행합니다.
<ph type="x-smartling-placeholder">
- </ph>
target.url
의 경로가 비어 있는지 확인합니다.target.url
에 어떤 정책이 수정되었는지 확인할 수 있는지 확인하세요. 빈 경로를 포함하기 위해
API 프록시
실패한 API 프록시 검토
이 오류에 대한 추적이나 로그가 없는 경우 실패한 API를 검토하세요. 프록시에서
target.url
흐름 변수를 수정하거나 업데이트한 항목을 확인합니다. 잘못된 경로를 포함할 수 있습니다. 다음을 확인하세요.- API 프록시 내의 정책
- 프록시에서 호출된 모든 공유 흐름
정책을 수정하거나 흐름 변수
target.url
를 신중하게 업데이트하고 업데이트 원인을 결정합니다.target.url
는 빈 경로를 포함합니다.다음은 흐름 변수
target.url
을 업데이트하는 정책의 몇 가지 예시입니다. 이 오류를 일으키는 빈 경로를 잘못 포함할 수 있습니다.샘플 #1
샘플 #1:
target.url
변수를 업데이트하는 JavaScript 정책var url = "https://mocktarget.apigee.net" context.setVariable("target.url", url);
위 샘플에서 흐름 변수
target.url
가 업데이트된 것을 볼 수 있습니다. 다른 변수에 포함된https://mocktarget.apigee.net
값url
입니다.target.url
에는 다음과 같은 구성요소가 있습니다.- 스키마:
https://mocktarget.apigee.net
- path: 비어 있음
경로가 비어 있으므로 Apigee Edge는 다음과 함께
500 Internal Server Error
를 반환합니다. 오류 코드protocol.http.EmptyPath
입니다.샘플 #2
샘플 #2:
target.url
변수를 업데이트하는 JavaScript 정책var path = context.getVariable("request.header.Path"); var url = "https://mocktarget.apigee.net" + path context.setVariable("target.url", url);
위 샘플에서 흐름 변수
target.url
는 변수에 포함된https://mocktarget.apigee.net
값 연결url
와 다른 변수path
의 값request.header.Path.
에서 값을 가져옴실제 요청이나 trace에 액세스할 수 있으면 실제 값을 확인할 수 있습니다.
request.header.Path
에 전달되었습니다.사용자의 샘플 요청은 다음과 같습니다.
curl -v https://HOST_ALIAS/v1/myproxy -H "Authorization: Bearer <token>
이 예에서 헤더 경로는 요청의 일부로 전송되지 않습니다. 따라서 JavaScript 정책의 변수 경로는
null
입니다.따라서 다음과 같은 전략을 구사하세요.
url = https://mocktarget.apigee.net + path
url = https://mocktarget.apigee.net + null
target.url = https://mocktarget.apigee.netnull
target.url
의 구성요소는 다음과 같습니다.- 스키마:
https://mocktarget.apigee.netnull
- path: 비어 있음
샘플 #3
샘플 #3: 다음을 통해
target.url
변수를 업데이트하는 AssignMessage 정책 다른 변수<AssignMessage async="false" continueOnError="false" enabled="true" name=">AM-SetTargetURL"> <DisplayName>AM-SetTargetURL</DisplayName> <AssignVariable> <Name>target.url</Name> <Value>https://mocktarget.apigee.net</Value> </AssignVariable> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="request"/> </AssignMessage>
target.url
의 구성요소는 다음과 같습니다.- 스키마:
https://mocktarget.apigee.net
- path: 비어 있음
위의 모든 예에서
target.url
가 비어 있으므로 Apigee Edge가 반환됩니다.500 Internal Server Error
(오류 코드:protocol.http.EmptyPath
)- 스키마:
해상도
사양에 따라
<ph type="x-smartling-placeholder"></ph>
RFC 3986, 섹션 2: 구문 구성요소의 경우 path
구성요소는 다음과 같습니다.
필수이며
다른 문자를 path
의 일부로 사용합니다. 다음 단계를 따르세요.
다음 단계를 따르세요.
- 흐름 변수로 표시되는 백엔드 서버 URL이
target.url
에는 항상 비어 있지 않은 경로가 있습니다.- 경우에 따라 경로에 리소스 이름이 없을 수도 있습니다. 그런 다음 경로가
적어도 슬래시 (
/
)가 있어야 합니다. - 다른 변수를 사용하여 흐름 변수의 값을 결정하는 경우
target.url
로 설정한 다음 다른 변수의 경로가 비어 있지 않은지 확인합니다. - 흐름 변수의 값을 결정하기 위해 문자열 작업을 수행하는 경우
target.url
를 반환한 다음 문자열의 결과 또는 결과가 작업의 빈 경로가 없습니다.
- 경우에 따라 경로에 리소스 이름이 없을 수도 있습니다. 그런 다음 경로가
적어도 슬래시 (
- 진단에서 설명한 샘플에서 이 문제를 다음과 같이 해결할 수 있습니다.
아래에 설명되어 있습니다.
샘플 #1
샘플 #1:
target.url
변수를 업데이트하는 JavaScript 정책url
변수에 슬래시 (/
)를 추가하여 이 문제를 해결합니다. 문제를 해결할 수 있습니다.var url = "https://mocktarget.apigee.net/" context.setVariable("target.url", url);
샘플 #2
샘플 #2:
target.url
변수를 업데이트하는 JavaScript 정책var path = context.getVariable("request.header.Path"); var url = "https://mocktarget.apigee.net" + path context.setVariable("target.url", url);
유효한 경로(예:
/iloveapis
)를 이 문제를 해결하려면 요청 헤더Path
을 사용하세요.샘플 요청:
curl -v https://HOST_ALIAS/v1/myproxy -H "Authorization: Bearer <token> -H "Path: /iloveapis"
샘플 #3
샘플 #3: 다음을 통해
target.url
변수를 업데이트하는 AssignMessage 정책 다른 변수VerifyMessage 정책의
<Value>
요소에 유효한 경로를 추가합니다. 대상 예를 들어/json
를 MockTarget API 즉,<Value>
요소를 다음과 같이 수정합니다.https://mocktarget.apigee.net/json
:<AssignMessage async="false" continueOnError="false" enabled="true" name="AM-SetTargetURL"> <DisplayName>AM-SetTargetURL</DisplayName> <AssignVariable> <Name>target.url</Name> <Value>https://mocktarget.apigee.net/json</Value> </AssignVariable> <IgnoreUnresolvedVariables>true</IgnoreUnresolvedVariables> <AssignTo createNew="false" transport="http" type="request"/> </AssignMessage>
사양
Apigee Edge는 다음 사양을 충족해야 합니다.
사양 |
---|
<ph type="x-smartling-placeholder"></ph> RFC 3986, 섹션 3: 구문 구성요소 |
<ph type="x-smartling-placeholder"></ph> RFC 3986, 섹션 3.3: 경로 |
Apigee 지원팀의 도움이 더 필요하면 다음 페이지로 이동하세요. 진단 정보를 수집해야 합니다.
진단 정보를 수집해야 함
위의 안내를 따른 후에도 문제가 지속되면 다음을 수집합니다. Apigee Edge 지원팀에 문의하세요.
퍼블릭 클라우드 사용자인 경우 다음 정보를 입력합니다.
- 조직 이름
- 환경 이름
- API 프록시 이름
- 오류 코드
protocol.http.EmptyPath
을 사용하여500 Internal Server Error
를 재현하는 데 사용된curl
명령어를 완료합니다. - API 요청에 대한 추적 파일
Private Cloud 사용자인 경우 다음 정보를 입력합니다.
- 실패한 요청에 대해 발견된 전체 오류 메시지
- 환경 이름
- API 프록시 번들
- API 요청에 대한 추적 파일
NGINX 액세스 로그:
/opt/apigee/var/log/edge-router/nginx/ORG~ENV.PORT#_access_log
위치: ORG, ENV, PORT#가 다음으로 대체됩니다. 실제값입니다.
- 메시지 프로세서 시스템 로그
/opt/apigee/var/log/edge-message- processor/logs/system.log