문제 해결

오류

오류가 발생하면 표준 형식 오류 응답 본문이 반환되고 HTTP 상태 코드가 오류 상태로 설정됩니다.

대답에는 다음 키가 있는 단일 error 객체가 포함된 객체가 포함됩니다.

  • code: 응답의 HTTP 상태와 동일합니다.
  • message: 오류에 대한 간단한 설명입니다.
  • status: 오류의 성격을 나타내는 상태 코드입니다.

예를 들어 잘못된 placeId 매개변수를 전송하면 다음 오류가 반환됩니다.

{
  "error": {
    "code": 400,
    "message": "\"placeId\" value is malformed: \"aChIJqaknMTeuEmsRUYCD5Wd9ARM\"",
    "status": "INVALID_ARGUMENT"
  }
}

가능한 오류는 다음과 같습니다.

코드 상태 메시지 문제 해결
400 INVALID_ARGUMENT 제공한 키가 잘못되었습니다. API 키가 유효하지 않거나 요청에 포함되지 않았습니다. 전체 키를 포함하고 이 키에 대해 API를 사용 설정했는지 확인하세요.
400 INVALID_ARGUMENT '\"path\" 매개변수에 잘못된 값이 포함되어 있습니다: ☃' 요청에 잘못된 인수가 포함되어 있습니다. 이 오류가 발생할 가능성이 가장 높은 원인은 다음과 같습니다.
  • path 매개변수에 문제가 있습니다.
    포인트가 1개 이상 100개 미만이어야 합니다. 각 점은 쉼표로 구분된 숫자 쌍이어야 합니다(예: 48.409114,-123.369158). 포인트는 파이프('|')로 구분해야 합니다.
  • 요청에 잘못된 placeId이 포함되어 있습니다.
  • 요청에 placeIdpath가 모두 포함되어 있습니다. 각 요청에 대해 이러한 매개변수 중 하나만 지정할 수 있습니다.

더 이상 존재하지 않는 도로 또는 도로가 아닌 장소에 placeId가 전달되면 이 오류가 반환되지 않습니다.

403 PERMISSION_DENIED 등록되지 않은 요청이 차단되었습니다. Google Developers Console을 사용하여 가입하세요. 다음 중 하나 이상의 이유로 요청이 거부되었습니다.
  • API 키가 누락되었거나 잘못되었습니다.
  • 계정에 결제가 사용 설정되어 있지 않습니다.
  • 자체 적용되는 사용량 한도를 초과했습니다.
  • 제공된 결제 수단이 더 이상 유효하지 않습니다 (예: 신용카드가 만료됨).

Google Maps Platform 제품을 사용하려면 계정에서 결제를 사용 설정해야 하고 모든 요청에 유효한 API 키를 포함해야 합니다. 이 문제를 해결하려면 다음 단계를 따르세요.

404 NOT_FOUND 이 서비스에는 HTTPS가 필요합니다. http://roads.googleapis.com/이 아닌 https://roads.googleapis.com/에 요청을 보내고 있는지 확인합니다.
429 RESOURCE_EXHAUSTED 프로젝트 요청 한도에 도달하여 요청이 제한되었습니다. Google Cloud Platform Console에서 구성한 요청 한도를 초과했습니다. 이 한도는 일반적으로 일일 요청 수, 100초당 요청 수, 사용자별 100초당 요청 수로 설정됩니다. 이 한도는 소수의 사용자가 일일 할당량을 소진하지 못하도록 하면서도 모든 사용자가 적절하게 액세스할 수 있도록 구성해야 합니다. 이러한 한도를 구성하려면 API 사용량 상한 설정을 참고하세요.

지수 백오프

요청이 실패하면 지수 백오프로 요청을 다시 시도해야 합니다. 예를 들어 요청이 한 번 실패하면 1초 후에 재시도하고, 다시 실패하면 2초 후에 재시도하고, 다시 실패하면 4초 후에 재시도하는 식으로 대기 시간을 점차 늘립니다. 이렇게 하면 많은 클라이언트가 매우 빠르게 요청을 재시도하므로 잘못된 요청이나 대규모 장애가 Google 서버를 범람하지 않습니다.

문제 해결 FAQ

구현 문제

어떤 빈도로 차량 위치를 샘플링해야 하나요?
고품질 도로 스냅 결과를 얻으려면 1~10초마다 스냅하는 것이 좋습니다.
질문당 보낼 수 있는 포인트 수에 제한이 있나요?
예, 쿼리에는 최대 100개의 포인트가 포함될 수 있습니다.
스냅된 위도/경도 쌍을 저장할 때 어떤 수준의 정밀도를 사용해야 하나요?
스냅된 경로가 최대 확대/축소 수준에서도 모든 확대/축소 수준에서 도로를 따르도록 하려면 스냅된 위도/경도 쌍을 소수점 이하 7자리 정밀도로 저장해야 합니다.
인코딩된 다중선을 사용하여 스냅된 경로를 표시할 수 있나요?
인코딩된 폴리라인은 소수점 이하 5자리까지만 지정되므로 약 2미터의 오류가 발생합니다. 따라서 스냅된 경로가 높은 확대/축소 수준에서 도로를 따르도록 하려면 인코딩된 폴리라인이 적합하지 않습니다.

일반적인 문제

일부 포인트가 스냅되지 않거나 스냅된 경로에 간격이 있습니다. 이 문제를 수정하려면 어떻게 해야 하나요?
  • 일정 간격으로 포인트를 샘플링하는 경우 더 짧은 간격 (1~10초마다)으로 포인트를 샘플링해야 합니다. 더 긴 간격(예: 60초)을 사용하는 경우 도로에 맞추기 알고리즘이 이동한 도로를 충분히 정확하게 파악하지 못할 수 있습니다.
  • 지도를 수동으로 클릭하여 포인트를 만드는 경우 스냅 알고리즘에서 제대로 처리하지 않는 포인트가 적거나 포인트가 드문 경로를 쉽게 만들 수 있습니다. 스냅 알고리즘은 서로 가까운 점에 가장 적합합니다. 도로에 맞추기 데모를 사용해 보거나 도로 인스펙터를 사용하여 경로를 테스트하세요.
확대하면 스냅된 경로가 들쭉날쭉하거나 도로에서 약간 벗어나는 이유는 무엇인가요?
  • 표시하기 전에 스냅된 위도/경도 쌍의 정밀도를 자르나요? 스냅된 위도/경도 쌍을 소수점 이하 7자리 미만의 정밀도로 저장하면 스냅된 경로가 지도에 표시될 때 정밀도 오류가 발생합니다.
  • 인코딩된 폴리라인을 사용하고 있나요? 인코딩된 폴리라인은 위도/경도 쌍을 소수점 이하 5자리로 자르므로 수 미터의 오류가 발생하여 높은 확대/축소 수준에서 선이 들쭉날쭉하거나 도로에서 약간 벗어납니다.

위의 두 경우 모두 해당하지 않으면 지도 타일이 최근에 업데이트되어 스냅에 사용되는 도로 색인과 동기화되지 않았을 수 있습니다. 몇 개의 검색어만 영향을 받는다면 이 문제가 원인일 가능성이 높습니다. Google 지도는 정기적으로 업데이트되므로 이 문제가 가끔 발생할 수 있으며, 지도에서 오래된 경로 (예: 몇 주 전에 스냅된 경로)를 정기적으로 살펴보는 경우 더 자주 발생할 수 있습니다. 최적의 시각화를 위해 스냅에 사용된 지도 타일과 도로 색인 간의 불일치를 최소화하려면 지도를 표시하기 직전에 이전 경로를 다시 스냅해야 합니다.

도로 X의 제한 속도가 잘못 표시되는 이유는 무엇인가요?
제한 속도는 정확도와 범위가 다양한 여러 소스에서 제공됩니다. 특정 도로 유형 또는 특정 지역의 제한 속도가 일관되게 잘못되는 등 패턴을 발견한 경우 다음 단계에 따라 Google에 알려주세요.
  1. 데스크톱 컴퓨터에서 Google 지도를 열거나 Android용 Google 지도 앱을 엽니다.
  2. 왼쪽 사이드 메뉴를 엽니다.
  3. 의견 보내기를 선택합니다. 참고: 로그인하라는 메시지가 표시될 수 있습니다.
  4. 지도 수정을 선택합니다.
  5. 수정할 도로 구간을 선택합니다.
  6. 다음을 선택합니다.
  7. '기타' 필드에 해당 도로의 제한속도가 잘못되었다고 표시합니다.
  8. 제출을 선택합니다.
도로 이름이 잘못되었거나, 도로가 잘못 그려졌거나, 도로가 폐쇄되었거나, 도로가 사유지인 경우와 같은 기타 문제도 여기에서 신고할 수 있습니다.
스냅된 경로가 도로를 따라가지 않고 지름길을 택하는 이유는 무엇인가요?
이 문제를 해결하려면 다음을 확인하세요.
  • interpolate 매개변수가 true로 설정되어 있는지 확인합니다.
  • 원래 데이터 포인트가 충분히 가까운 간격(1~10초마다)으로 샘플링되는지 확인합니다.
속도 제한이 변경되지 않은 도로의 스냅된 경로에 많은 도로 구간이 반환되는 이유는 무엇인가요?
interpolate 매개변수가 true로 설정된 경우 도로에 맞추기 쿼리는 모퉁이, 곡선, 로터리를 따라 도로를 따르는 폴리라인을 반환합니다. 도로가 구부러지면 속도 제한이 변경되지 않더라도 도로 형상을 밀접하게 따르는 폴리라인을 만들기 위해 여러 도로 세그먼트가 반환됩니다.