Kota çalışma zamanı hatasıyla ilgili sorunları giderme

Apigee Edge belgelerini görüntülüyorsunuz.
Apigee X belgelerine gidin.
info

InvalidMessageWeight

Hata kodu

policies.ratelimit.InvalidMessageWeight

Hata yanıtı gövdesi

{
    "fault": {
        "faultstring": "Invalid message weight value [invalid_value]",
        "detail": {
            "errorcode": "policies.ratelimit.InvalidMessageWeight"
        }
    }
}

Örnek Hata Mesajı

{
    "fault": {
        "faultstring": "Invalid message weight value 1.5",
        "detail": {
            "errorcode": "policies.ratelimit.InvalidMessageWeight"
        }
    }
}

Neden

Bu hata, bir akış değişkeni aracılığıyla belirtilen <MessageWeight> öğesinin değeri geçersizse (tamsayı olmayan bir değer) ortaya çıkar.

Örneğin, <MessageWeight> öğesi için belirtilen akış değişkeninin değeri 1,5 (tam sayı olmayan bir değer) ise bu hata meydana gelir.

Teşhis

  1. Kota politikasında <MessageWeight> öğesi için kullanılan geçersiz değeri tanımlayın. Bu bilgileri, hata yanıtının faultstring öğesinde bulabilirsiniz. Örneğin, aşağıdaki hatada <MessageWeight> öğesi için kullanılan geçersiz değer 1.5'tır:

    "faultstring": "Invalid message weight value 1.5"
    
  2. Hatanın oluştuğu belirli API Proxy'sindeki tüm kota politikalarını inceleyin. <MessageWeight> öğesinin belirtildiği bir veya daha fazla Kota politikası olabilir.

    Örneğin, aşağıdaki politika <MessageWeight>akış değişkeni aracılığıylamessage_weight belirtilmiştir:

    <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
        <Quota async="false" continueOnError="false" enabled="true" name="Quota_with_weight" type="calendar">
        <DisplayName>Quota_with_weight</DisplayName>
        <Properties/>
        <Allow count="3"/>
        <Interval>1</Interval>
        <TimeUnit>minute</TimeUnit>
        <StartTime>2017-7-16 12:00:00</StartTime>
        <MessageWeight ref="message_weight"/>
    </Quota>
    
  3. Tanımlanmış kota politikalarında <MessageWeight> için kullanılan değişkenin değerini belirleyin. Akış değişkeninin değeri, HTTP üstbilgilerinden, sorgu parametrelerinden, XML veya JSON istek yükü verisinden çıkarılabilir ya da başka bir politikada tanımlanabilir:

    1. API Proxy paketinde, değişkenin ilk tanımlandığı kodu bulun.
    2. Değişkenin tanımlandığı ve doldurulduğu politikayı öğrendikten sonra değişkenin değerinin nasıl ayarlandığını kontrol edin.
    3. Akış değişkeninin değeri yukarıdaki 1. adımda tanımlanan değerle eşleşiyorsa hatanın nedeni budur.

    Örneğin, Kota Politikası'ndan önce kullanılan bir JavaScript politikasının message_weight değişkenini aşağıda gösterildiği gibi istek türüne göre ayarladığını varsayalım:

    var verb = context.getVariable("request.verb");
    context.setVariable("message_weight", "1.5");
    if (verb == 'POST') {
      context.setVariable("message_weight", "2");
    }
    

    message_weight değişkeninin değerinin 1.5 olduğunu ve bunun geçersiz (tam sayı olmayan) bir değer olduğunu unutmayın.

Çözünürlük

Akış değişkeni tarafından belirtilen MessageWeight değerini temsil eden değerin geçerli bir değer (tam sayı değeri) olduğundan emin olun.

Yukarıda gösterilen örneği düzeltmek için JavaScript'teki message_weight değişkeninin değerini tam sayı olacak şekilde değiştirebilirsiniz.

var verb = context.getVariable("request.verb");
context.setVariable("message_weight", "1");
if (verb == 'POST') {
  context.setVariable("message_weight", "2");
}

FailedToResolveQuotaIntervalReference

Hata kodu

policies.ratelimit.FailedToResolveQuotaIntervalReference

Hata yanıtı gövdesi

{
    "fault": {
        "faultstring": "Failed to resolve quota interval reference [reference] in quota policy {1}",
        "detail": {
            "errorcode": "policies.ratelimit.FailedToResolveQuotaIntervalReference"
        }
    }
}

Örnek Hata Mesajı

{
    "fault": {
        "faultstring": "Failed to resolve quota interval reference api.product.developer.quota.interval in quota policy {1}",
        "detail": {
            "errorcode": "policies.ratelimit.FailedToResolveQuotaIntervalReference"
        }
    }
}

Neden

Bu hata, <Interval> öğesi Kota politikasında tanımlanmamışsa ortaya çıkar. Bu öğe zorunludur ve kota için geçerli zaman aralığını belirtmek üzere kullanılır. Zaman aralığı, <TimeUnit> öğesiyle tanımlandığı şekilde dakika, saat, gün, hafta veya ay olabilir.

Teşhis

  1. Hatanın oluştuğu API Proxy'sindeki kota politikalarının her birini inceleyin. Zorunlu öğe <Interval>'ün tanımlanmadığı bir kota politikası varsa hatanın nedeni budur.

    Örneğin, aşağıdaki kota politikasında zorunlu <Interval> öğesi yoktur:

    <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
        <Quota async="false" continueOnError="false" enabled="true" name="CheckQuota" type="calendar">
        <DisplayName>CheckQuota</DisplayName>
        <Properties/>
        <Allow count="3"/>
            <TimeUnit ref="verifyapikey.verify-api-key.apiproduct.developer.quota.timeunit">hour</TimeUnit>
        <StartTime>2017-7-16 12:00:00</StartTime>
    </Quota>
    

    Zorunlu öğe <TimeUnit> yukarıdaki kota politikasında tanımlanmadığından şu hata kodunu alırsınız:

    policies.ratelimit.FailedToResolveQuotaIntervalReference
    

Çözünürlük

Belirli bir API proxy'si için tüm kota politikalarında zorunlu <Interval> öğesinin düzgün şekilde tanımlandığından emin olun.

Yukarıda gösterilen örneği düzeltmek için politikayı aşağıda gösterildiği gibi <Interval> öğesini içerecek şekilde değiştirebilirsiniz.

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<Quota async="false" continueOnError="false" enabled="true" name="CheckQuota" type="calendar">
    <DisplayName>CheckQuota</DisplayName>
    <Properties/>
    <Allow count="3"/>
    <TimeUnit ref="verifyapikey.verify-api-key.apiproduct.developer.quota.timeunit">hour</TimeUnit>
    <Interval ref="verifyapikey.verify-api-key.apiproduct.developer.quota.interval">1</Interval>
    <StartTime>2017-7-16 12:00:00</StartTime>
</Quota>

FailedToResolveQuotaIntervalTimeUnitReference

Hata kodu

policies.ratelimit.FailedToResolveQuotaIntervalTimeUnitReference

Hata yanıtı gövdesi

{
    "fault": {
        "faultstring": "Failed to resolve quota time unit reference [reference] in quota policy {1}",
        "detail": {
            "errorcode": "policies.ratelimit.FailedToResolveQuotaIntervalTimeUnitReference"
        }
    }
}

Örnek Hata Mesajı

{
    "fault": {
        "faultstring": "Failed to resolve quota time unit reference apiproduct.developer.quota.timeunity in quota policy {1}",
        "detail": {
            "errorcode": "policies.ratelimit.FailedToResolveQuotaIntervalTimeUnitReference"
        }
    }
}

Neden

Bu hata, <TimeUnit> öğesi kota politikasında tanımlanmamışsa ortaya çıkar. Bu öğe zorunludur ve kota için geçerli zaman birimini belirtmek üzere kullanılır. Zaman aralığı dakika, saat, gün, hafta veya ay biçiminde olabilir.

Teşhis

  1. Hatanın oluştuğu API Proxy'sindeki kota politikalarının her birini inceleyin. Zorunlu öğe <TimeUnit>'ün tanımlanmadığı bir kota politikası varsa hatanın nedeni budur.

    Örneğin, aşağıdaki kota politikasında zorunlu <TimeUnit> öğesi yoktur:

    <Quota async="false" continueOnError="false" enabled="true" name="CheckQuota" type="calendar">
      <DisplayName>CheckQuota</DisplayName>
      <Properties/>
      <Allow count="3"/>
          <Interval ref="verifyapikey.verify-api-key.apiproduct.developer.quota.interval">1</Interval>
      <StartTime>2017-7-16 12:00:00</StartTime>
    </Quota>
    

    Zorunlu öğe <TimeUnit> yukarıdaki kota politikasında tanımlanmadığından şu hata kodunu alırsınız:

    policies.ratelimit.FailedToResolveQuotaIntervalTimeUnitReference
    

Çözünürlük

Belirli bir API proxy'si için tüm Kota politikalarında zorunlu <TimeUnit> öğesinin tanımlandığından emin olun.

Yukarıda gösterilen örneği düzeltmek için politikayı aşağıda gösterildiği gibi <TimeUnit> öğesini içerecek şekilde değiştirebilirsiniz.

<Quota async="false" continueOnError="false" enabled="true" name="CheckQuota" type="calendar">
    <DisplayName>CheckQuota</DisplayName>
    <Properties/>
    <Allow count="3"/>
    <TimeUnit ref="verifyapikey.verify-api-key.apiproduct.developer.quota.timeunit">hour</TimeUnit>
    <Interval ref="verifyapikey.verify-api-key.apiproduct.developer.quota.interval">1</Interval>
    <StartTime>2017-7-16 12:00:00</StartTime>
</Quota>