Đặ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 để tự động sửa đổi 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. Thông thường, bạn dùng chính sách này để giảm 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 đặt lại hạn mức.

Ví dụ: Chính sách về hạn mức mục tiêu giới hạn nhà phát triển ở mức 1.000 yêu cầu mỗi tuần. Vào 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ừ 500 khỏi bộ đếm hạn mức của họ để cho phép thêm 500 yêu cầu trong thời gian còn lại của 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 quay lại 1.000 yêu cầu trong tuần.

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

Mẫu

Các mã mẫu sau đây 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 Hạn mức mục tiêu bằng cách sử dụng thuộc tính name của thẻ <Quota>. Trong ví dụ trên, chính sách MyQuotaPolicy 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ẻ <Identifier> để chỉ định bộ đếm trong chính sách 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 Hạn mức cũng bao gồm thẻ <Identifier>. Trong ví dụ này, chính sách Hạn mức mục tiêu không sử dụng thẻ <Identifier>, vì vậy, bạn chỉ định thuộc tính name_default.

Phần tử <Allow> chỉ định giá trị dùng để giảm hạn mức hiện tại trong chính sách mục tiêu. Trong ví dụ này, số lượng hạn mức giảm đi 100, để cho phép thêm 100 yêu cầu đối với chính sách 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 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 khảo các biến luồng chứa các giá trị này 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ẻ <Identifier>, thì bạn có thể chỉ định cùng một giá trị cho thẻ <Identifier> của chính sách Đặt lại hạn mức để cập nhật một số lượng hạn mức cụ thể. Hãy lưu ý cách thẻ <Identifier> trong chính sách Hạn mức mục tiêu bên dưới khớp với giá trị được chỉ định cho 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 về 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>

Thuộc tính <ResetQuota>

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

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

Thuộc tính Nội dung 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ự.

Nếu muốn, bạn có thể sử dụng phần tử <DisplayName> để gắn nhãn cho chính sách này 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 một chính sách không hoạt động. Đây là hành vi dự kiến đối với hầu hết các chính sách.

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

false Không bắt buộc
enabled

Đặt thành true để thực thi chính sách.

Đặ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 chính sách vẫn được đính kèm vào một quy trình.

đú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

Phần tử <DisplayName>

Sử dụng cùng với thuộc tính name để gắn nhãn cho 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 khác theo ngôn ngữ tự nhiên.

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

Không áp dụng

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

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

Phần tử <Hạn mức>

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 Nội dung mô tả Mặc định Sự hiện diện
tên

Chỉ định 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
giới thiệ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 bạn chỉ định cả refname, thì ref sẽ được ưu tiên. Nếu ref không phân giải được trong thời gian chạy, thì hệ thống sẽ sử dụng name. Không áp dụng Không bắt buộc

Phần tử <Quota>/<Identifier>

Biến được dùng để xác định riêng bộ đếm nếu chính sách Hạn mức mục tiêu chỉ định thẻ <Identifier>.

<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 Nội dung mô tả Mặc định Sự hiện diện
tên

Chỉ định 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 chính sách Hạn mức không sử dụng thẻ <Identifier>, hãy chỉ định _default.

Không áp dụng Không bắt buộc
giới thiệu

Một biến luồng chứa tên của giá trị nhận dạng số lượng trong chính sách về hạn mức mục tiêu. Nếu bạn chỉ định cả refname, thì ref sẽ được ưu tiên. Nếu ref không phân giải được trong thời gian chạy, thì hệ thống sẽ sử dụng name.

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

Phần tử <Quota>/<Identifier>/<Allow>

Chỉ định số tiền để giảm bộ đếm hạn mức. Bạn phải chỉ định <Allow>, 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 Nội dung mô tả Mặc định Sự hiện diện
giới thiệu

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

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

Phần tử <Quota>/<Identifier>/<Class>

Chỉ định lớp mà bộ đếm Hạn mức được cập nhật. Để biết thêm thông tin về cách sử dụng lớp có chính sách Hạn mức, hãy xem phần Chính sách về 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 Nội dung mô tả Mặc định Sự hiện diện
giới thiệ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