Đặt lại chính sách

Bạn đang xem tài liệu về Apigee Edge.
Chuyển đến Tài liệu về Apigee X.
thông tin

Nội dung

Dùng để sửa đổi linh động số lượng yêu cầu còn lại mà chính sách Hạn mức mục tiêu cho phép. Bạn thường dùng chính sách này để giảm số lượng hạn mức hiện tại của chính sách Hạn mức mục tiêu thay vì đợi số lượng hạn mức được đặt lại.

Ví dụ: Chính sách về hạn mức mục tiêu giới hạn nhà phát triển được phép gửi 1.000 yêu cầu mỗi tuần. Theo ngày thứ hai của tuần, nhà phát triển đã đạt đến giới hạn này. Sử dụng chính sách Đặt lại hạn mức trừ đi 500 từ bộ đếm hạn mức để cho phép thêm 500 yêu cầu cho phần còn lại của trong tuần. Vào cuối tuần, chính sách Hạn mức sẽ được đặt lại và nhà phát triển sẽ quay lại mức 1.000 yêu cầu trong tuần.

Xem Chính sách về hạn mức để biết thêm thông tin về chính sách về Hạn mức. Xem thêm bài viết này bài đăng trên thẻ Cộng đồng về cách sử dụng chính sách Đặt lại hạn mức.

Mẫu

Các mã mẫu về chính sách sau minh hoạ cách đặt lại bộ đếm hạn mức:

Đặt lại bộ đếm mặc định

<ResetQuota name="resetQuota">
   <Quota name="MyQuotaPolicy">
      <Identifier name="_default">
         <Allow>100</Allow>
      </Identifier>
   </Quota>
</ResetQuota>

Chính sách Đặt lại hạn mức chỉ định chính sách về Hạn mức mục tiêu bằng cách sử dụng thuộc tính name của thẻ <Capacity>. Trong ví dụ trên, chính sách MyCapacityPolicy là mục tiêu.

Tất cả các chính sách Đặt lại hạn mức đều yêu cầu thẻ &lt;Identifier&gt; để chỉ định trong chính sách về hạn mức để cập nhật. Theo mặc định, chính sách Hạn mức có một bộ đếm duy nhất, trừ phi chính sách về Hạn mức cũng bao gồm thẻ &lt;Identifier&gt;. Trong ví dụ này, chính sách Hạn mức mục tiêu không sử dụng thẻ &lt;Identifier&gt;, vì vậy, bạn chỉ định thuộc tính name thành _default.

Phần tử &lt;Allow&gt; chỉ định giá trị dùng để giảm số lượng hạn mức hiện tại cho chính sách mục tiêu. Trong phần này ví dụ: số lượng hạn mức giảm đi 100 để cho phép thêm 100 yêu cầu vào hạn mức mục tiêu . Khi bạn đặt lại chính sách Hạn mức mục tiêu, thay đổi này sẽ bị loại bỏ.

Dưới đây là định nghĩa về chính sách Hạn mức mục tiêu:

<Quota name="MyQuotaPolicy">
  <Interval>5</Interval>
  <TimeUnit>hour</TimeUnit>
  <Allow count="100"/>
</Quota>

Sử dụng tệp đối chiếu

<ResetQuota name="resetQuota">
   <Quota ref="request.header.quotapolicy">
      <Identifier name="_default">
         <Allow ref="request.header.allowquota" />
      </Identifier>
   </Quota>
</ResetQuota>

Trong ví dụ này, bạn chuyển tên của chính sách về hạn mức mục tiêu và nội dung thay đổi về hạn mức dưới dạng tiêu đề trong yêu cầu. Sau đó, bạn có thể tham chiếu các biến luồng chứa trong chính sách Đặt lại hạn mức.

Chỉ định giá trị nhận dạng

<ResetQuota name="resetQuota">
   <Quota name="QuotaPolicy">
      <Identifier ref="request.header.clientId">
         <Allow>100</Allow>
      </Identifier>
   </Quota>
</ResetQuota>

Nếu chính sách Hạn mức mục tiêu chỉ định thẻ &lt;Identifier&gt;, thì bạn có thể chỉ định cùng một giá trị cho thẻ &lt;Identifier&gt; của Đặt lại hạn mức để cập nhật số lượng hạn mức cụ thể. Lưu ý cách thẻ &lt;Identifier&gt; trong mục tiêu Chính sách về hạn mức bên dưới khớp với giá trị được chỉ định trong chính sách Đặt lại hạn mức:

<Quota name="QuotaPolicy">
  <Identifier ref="request.header.clientId"/> 
  <Interval>5</Interval>
  <TimeUnit>hour</TimeUnit>
  <Allow count="100"/>
</Quota>

Tham chiếu phần tử

Tài liệu tham khảo phần tử mô tả các phần tử và thuộc tính của chính sách Đặt lại hạn mức.

<ResetQuota async="false" continueOnError="false" enabled="true" name="Reset-Quota-1">
   <DisplayName>Reset Quota 1</DisplayName>
   <Quota name="quotaName" ref="request.header.quotapolicy">
      <Identifier name="identifierName" ref="request.header.identifier">
         <Class ref="request.header.classIdentifier" />
         <Allow>100</Allow>
      </Identifier>
   </Quota>
</ResetQuota>

&lt;ResetQuota&gt; thuộc tính

<ResetQuota async="false" continueOnError="false" enabled="true" name="Reset-Quota-1"> 

Bảng sau đây mô tả những thuộc tính chung cho tất cả phần tử mẹ của chính sách:

Thuộc tính Mô tả Mặc định Sự hiện diện
name

Tên nội bộ của chính sách. Giá trị của thuộc tính name có thể chứa chữ cái, số, dấu cách, dấu gạch nối, dấu gạch dưới và dấu chấm. Giá trị này không được vượt quá 255 ký tự.

(Không bắt buộc) Bạn có thể dùng phần tử <DisplayName> để gắn nhãn chính sách trong trình chỉnh sửa proxy giao diện người dùng quản lý bằng tên ngôn ngữ tự nhiên khác.

Không áp dụng Bắt buộc
continueOnError

Đặt thành false để trả về lỗi khi chính sách không thành công. Điều này là dự kiến đối với hầu hết các chính sách.

Đặt thành true để tiếp tục thực thi luồng ngay cả sau khi có chính sách không thành công.

false Không bắt buộc
enabled

Hãy đặt thành true để thực thi chính sách này.

Đặt thành false để tắt chính sách này. Chính sách này sẽ không được thực thi ngay cả khi luồng đó vẫn được liên kết với một luồng.

đúng Không bắt buộc
async

Thuộc tính này không được dùng nữa.

false Không được dùng nữa

&lt;DisplayName&gt; phần tử

Hãy sử dụng cùng với thuộc tính name để gắn nhãn chính sách trong phần trình chỉnh sửa proxy giao diện người dùng quản lý có tên ngôn ngữ tự nhiên khác.

<DisplayName>Policy Display Name</DisplayName>
Mặc định

Không áp dụng

Nếu bạn bỏ qua phần tử này, giá trị của thuộc tính name của chính sách sẽ là đã sử dụng.

Sự hiện diện Không bắt buộc
Loại Chuỗi

&lt;Quota&gt; phần tử

Xác định chính sách Hạn mức mục tiêu mà bộ đếm cần được cập nhật.

<Quota name="quotaName"  ref="request.header.quotapolicy">
   <Identifier name="identifierName" ref="request.header.identifier">
      <Allow>100</Allow>
   </Identifier>
</Quota>
Mặc định: Không áp dụng
Sự hiện diện: Bắt buộc
Loại: Không áp dụng

Thuộc tính

Thuộc tính Mô tả Mặc định Sự hiện diện
tên

Nêu tên của chính sách Hạn mức mục tiêu.

Không áp dụng Không bắt buộc
tham chiếu Biến luồng chứa tên của chính sách Hạn mức mục tiêu. Nếu cả refname đều được chỉ định, thì ref sẽ được ưu tiên. Nếu ref có không được phân giải trong thời gian chạy, thì name sẽ được sử dụng. Không áp dụng Không bắt buộc

&lt;Quota&gt;/&lt;Identifier&gt; phần tử

Biến được dùng để xác định duy nhất bộ đếm nếu chính sách Hạn mức mục tiêu chỉ định thẻ &lt;Identifier&gt;.

<Quota name="quotaName">
   <Identifier name="identifierName" ref="request.header.identifier">
      <Allow>100</Allow>
   </Identifier>
</Quota>
Mặc định: Không áp dụng
Sự hiện diện: Bắt buộc
Loại: Chuỗi

Thuộc tính

Thuộc tính Mô tả Mặc định Sự hiện diện
tên

Cho biết tên của giá trị nhận dạng số lượng trong chính sách Hạn mức mục tiêu. Đối với hạn mức chính sách không sử dụng thẻ &lt;Identifier&gt;, hãy chỉ định _default.

Không áp dụng Không bắt buộc
tham chiếu

Biến luồng chứa tên của giá trị nhận dạng số lượng trong Hạn mức mục tiêu . Nếu cả refname được chỉ định, thì ref sẽ được ưu tiên. Nếu ref không phân giải tại thời gian chạy, sau đó name sẽ được sử dụng.

Không áp dụng Không bắt buộc

&lt;Quota&gt;/&lt;Identifier&gt;/&lt;Allow&gt; phần tử

Chỉ định số tiền để giảm bộ đếm hạn mức. Bạn phải chỉ định &lt;Allow&gt;, nếu không, chính sách sẽ không sửa đổi hạn mức.

<Identifier name="identifierName" ref="request.header.identifier">
   <Allow ref="request.header.allowquota">100</Allow>
</Identifier>
Mặc định: Không áp dụng
Sự hiện diện: Bắt buộc
Loại: Số nguyên

Thuộc tính

Thuộc tính Mô tả Mặc định Sự hiện diện
tham chiếu

Biến luồng chứa thay đổi về số lượng hạn mức trong chính sách về hạn mức mục tiêu.

Không áp dụng Không bắt buộc

&lt;Quota&gt;/&lt;Identifier&gt;/&lt;Class&gt; phần tử

Chỉ định lớp được cập nhật Bộ đếm hạn mức. Để biết thêm thông tin về cách sử dụng lớp với Chính sách về hạn mức, hãy xem phần Hạn mức .

<Identifier name="_default">
   <Class ref="request.header.classIdentifier">
     <Allow>200</Allow>
   </Class>
</Identifier>
Mặc định: Không áp dụng
Sự hiện diện: Không bắt buộc
Loại: Không áp dụng

Thuộc tính

Thuộc tính Mô tả Mặc định Sự hiện diện
tham chiếu

Tham chiếu đến biến luồng chứa lớp hạn mức cần cập nhật.

Không áp dụng Không bắt buộc

Tham chiếu lỗi

Phần này mô tả các mã lỗi và thông báo lỗi được trả về, cũng như các biến lỗi do Edge đặt khi chính sách này kích hoạt lỗi. Thông tin này đóng vai trò quan trọng trong việc phát triển các quy tắc lỗi để xử lý lỗi. Để tìm hiểu thêm, hãy xem Những điều bạn cần biết về lỗi chính sáchXử lý lỗi.

Lỗi thời gian chạy

Những lỗi này có thể xảy ra khi thực thi chính sách.

Mã lỗi Trạng thái HTTP Nguyên nhân Khắc phục
policies.resetquota.InvalidRLPolicy 500 Chính sách hạn mức được chỉ định trong phần tử <Quota> của chính sách Đặt lại hạn mức không được xác định trong proxy API, do đó không dùng được trong quy trình. Phần tử <Quota> là bắt buộc và xác định chính sách Hạn mức mục tiêu có bộ đếm cần được cập nhật thông qua chính sách Đặt lại hạn mức.
policies.resetquota.FailedToResolveAllowCountRef Không áp dụng Không thể phân giải việc tham chiếu đến biến chứa số lượng cho phép trong phần tử <Allow> của chính sách thành một giá trị. Phần tử này là bắt buộc và chỉ định số lượng để giảm bộ đếm hạn mức.
policies.resetquota.FailedToResolveRLPolicy 500 Không thể phân giải biến được tham chiếu bởi thuộc tính ref trong phần tử <Quota>.

Lỗi triển khai

Những lỗi này có thể xảy ra khi bạn triển khai proxy chứa chính sách này.

Tên lỗi Nguyên nhân Khắc phục
InvalidCount Nếu giá trị số lượng được chỉ định trong phần tử <Allow> của Chính sách đặt lại hạn mức không phải là số nguyên, thì quá trình triển khai proxy API sẽ không thành công.

Giản đồ

Chủ đề có liên quan

Chính sách về hạn mức