API Management: 고급 사용 할당량

5111 단어 apiazure

소개



Azure API Management is a hybrid, multicloud management platform for APIs across all environments.



API Management에 대한 자세한 내용은 Microsoft Docs를 확인하세요.
About API Management .

APIM(API Management)은 수명 주기 동안 API를 최고의 자산으로 관리할 수 있게 해주는 Azure 서비스입니다. API로 구성되어 있습니다.
게이트웨이, 관리 평면 및 개발자 포털. 이러한 모든 구성 요소는 Azure에서 호스팅되며 기본적으로 완전히 관리됩니다.
각 구성 요소는 생태계에서 고유한 위치를 가집니다.

  • API 게이트웨이
    백엔드 서비스의 외관 역할을 합니다
  • .

  • 관리 평면
    API Management 서비스 기능에 대한 전체 액세스를 제공합니다
  • .

  • 개발자 포털
    API를 검색하고, 이를 사용하기 위해 온보딩하고, 사용 방법을 배우는 데 사용됨


  • 속도 제한 및 할당량



    APIM의 장점은 다양한 수준에서 다양한 유형의 정책을 정의할 수 있어
    API가 사용되고 있습니다. 예를 들어 API에 대한 속도 제한 및 할당량을 정의할 수 있습니다. APIM에서 이를 정의하고 확인하면 다음을 수행할 수 있습니다.
    API 소비를 조기에 제어합니다. 속도 제한 또는 할당량을 초과하는 요청은 APIM 수준에서 거부되며
    백엔드 서비스를 누르십시오.

    그러나 때로는 기본 제공 할당량이 충분하지 않아 직접 할당량을 정의해야 할 수도 있습니다. 우리 고객 중 한 명에게는 다음과 같은 요구 사항이 있었습니다.
    두 가지 특정 API 작업에 대한 크레딧과 같은 것이 있습니다. 고객은 API 크레딧을 구매합니다(구독한 제품과 별도로).
    특정 양의 요청에 대해. API가 호출될 때마다 고객에게 아직 사용 가능한 신용이 있는지 확인합니다. 그들이 가지고 있다면,
    API는 정상적으로 호출됩니다. 그렇지 않으면 고객은 크레딧이 없으며 API를 호출할 수 없다는 응답을 받게 됩니다.
    더 이상 또는 더 많은 크레딧을 구매해야 합니다. 이 마지막 시나리오는 영업 팀에서 구성할 수 있어야 합니다.

    다시 말하지만 이러한 크레딧은 고객이 구독하는 제품과 연결되어 있지 않습니다. 그리고 고객마다 신용 수준이 다를 수 있습니다.
    동일한 API 작업. 요청된 구성의 용이성과 결합된 이러한 유연성으로 인해 이를 완전히 관리하는 것이 불가능했습니다.
    너무 복잡한 코드 및/또는 정책을 구축하지 않고 APIM.

    옵션



    API 엔드포인트의 예상 로드로 인해 예를 들어 Azure 함수를 호출하여 고객이 여전히
    사용 가능한 신용은 적합하지 않습니다. 이 고객이 APIM으로 이전한 최초의 이유는 성능 문제가 있었기 때문입니다.
    속도 제한을 구현할 수 있도록 사용 통계를 저장하려고 합니다.

    결국 우리는 특정 API의 신용 상태를 확인할 수 있는 API 미들웨어를 만들기로 결정했습니다. 그러나 그것은 미들웨어입니다.
    똑똑한 추가...

    해결책



    성능이 핵심이고 소수의 요청으로 할당량을 초과하는 것은 문제가 되지 않으므로 요청량과 고객 크레딧은
    일정 시간 동안 메모리에 캐시됩니다. 적어도 지금은. 필요한 경우 언제든지 Redis와 같은 분산 캐시로 이동할 수 있습니다. 하지만 어떻게
    고객이 요청한 양을 알 수 있습니까? 이곳은
    Azure API Management REST API이 들어오고 더 구체적으로 작업
    Quota By Counter Keys - List By Service .
    이 API ...

    Lists a collection of current quota counter periods associated with the counter-key configured in the policy on the specified service
    instance.



    이는 카운터가 호출된 횟수와 킬로바이트 단위로 전송된 데이터까지 검색할 수 있음을 의미합니다.

    {
      "value": [
        {
          "counterKey": "xxx.xxx.xxx.xxx",
          "periodKey": "SOME_PERIODKEY",
          "periodStartTime": "2022-07-01T00:00:00Z",
          "periodEndTime": "2022-12-31T00:00:00Z",
          "value":
          {
            "callsCount": 42,
            "kbTransferred": 1796.5453825
          }
        }
      ],
      "count": 1,
      "nextLink": null
    }
    


    API Management "Quota By Counter Keys"REST API의 정보와 고객 신용을 결합하여 미들웨어를 만들 수 있습니다.
    이루어진 요청 수에 대해 크레딧을 확인합니다. 미들웨어에 정보를 캐싱하는 것은 사용자의 재량에 달려 있습니다.

    좋은 웹페이지 즐겨찾기