4.12. 期限切れのメッセージを期限切れアドレスに移動する
最後の値キュー以外のキューでは、非破壊的なコンシューマーしかない場合、ブローカーはキューからメッセージを削除できず、キューのサイズが徐々に増加します。キューサイズで制約のない増加を防ぐには、メッセージの有効期限が切れるタイミングを設定し、ブローカーが期限切れのメッセージを移動するアドレスを指定します。
4.12.1. メッセージの有効期限の設定 リンクのコピーリンクがクリップボードにコピーされました!
以下の手順では、メッセージの有効期限を設定する方法を説明します。
手順
-
<broker_instance_dir>/etc/broker.xml設定ファイルを開きます。 core要素で、message-expiry-scan-periodを設定して、ブローカーが期限切れのメッセージをスキャンする頻度を指定します。<configuration ...> <core ...> ... <message-expiry-scan-period>1000</message-expiry-scan-period> ...<configuration ...> <core ...> ... <message-expiry-scan-period>1000</message-expiry-scan-period> ...Copy to Clipboard Copied! Toggle word wrap Toggle overflow 前述の設定に基づいて、ブローカーは 1000 ミリ秒ごとに期限切れのメッセージのキューをスキャンします。
一致するアドレスまたは一連のアドレスの
address-setting要素で、有効期限切れのアドレスを指定します。また、メッセージの有効期限を設定します。以下に例を示します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow expiry-address-
一致するアドレスや一連のアドレスの有効期限。前述の例では、ブローカーは
stocksアドレスに対する期限切れメッセージをExpiryAddressと呼ばれる期限切れアドレスに送信します。 expiry-delayデフォルトの有効期限を使用するメッセージにブローカーが適用される有効期限 (ミリ秒単位)。デフォルトでは、メッセージの有効期限は
0で、有効期限がないことを意味します。デフォルト以上の有効期限が設定されているメッセージに対しては、expiry-delayは効果がありません。例えば、先ほどの例のように、アドレスの
expiry-delayを10に設定したとします。デフォルトの有効期限が0のメッセージがこのアドレスのキューに到着した場合、ブローカーはメッセージの有効期限を0から10に変更します。しかし、有効期限を20に設定している別のメッセージが到着した場合、その有効期限は変更されません。expiry-delay を-1に設定した場合、この機能は無効になります。デフォルトでは、expiry-delayは-1に設定されます。
また、
expiry-delayに値を指定する代わりに、expiry delay の最小値と最大値を指定することもできます。以下に例を示します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow min-expiry-delay- ブローカーがメッセージに適用される最小有効期限 (ミリ秒単位)。
max-expiry-delayブローカーがメッセージに適用される最大有効期限 (ミリ秒単位)。
ブローカーは、以下のように
min-expiry-delayとmax-expiry-delayの値を適用します。-
デフォルトの有効期限が
0のメッセージに対して、ブローカーは有効期限を指定された値のmax-expiry-delayに設定します。max-expiry-delayの値を指定していない場合、ブローカーは指定されたmin-expiry-delayの値に満了時間を設定します。min-expiry-delayの値を指定しない場合、ブローカーはメッセージの有効期限を変更しません。 -
max-expiry-delayの値を上回る有効期限のあるメッセージの場合、ブローカーは有効期限をmax-expiry-delayの指定値に設定します。 -
有効期限が
min-expiry-delayの値以下のメッセージに対して、ブローカーは有効期限を指定されたmin-expiry-delayの値に設定します。 -
min-expiry-delayおよびmax-expiry-delayの値の間に有効期限のあるメッセージの場合、ブローカーはメッセージの有効期限を変更しません。 -
expiry-delayの値 (すなわちデフォルト値の-1以外) を指定すると、min-expiry-delayおよびmax-expiry-delayに指定する値が上書きされます。 -
min-expiry-delayとmax-expiry-delayの両方のデフォルト値は-1(つまり無効) です。
-
デフォルトの有効期限が
設定ファイルの
address要素で、以前にexpiry-addressに指定したアドレスを設定します。このアドレスにキューを定義します。以下に例を示します。Copy to Clipboard Copied! Toggle word wrap Toggle overflow 前述の設定例では、期限切れキュー
ExpiryQueueと期限切れアドレスExpiryAddressを関連付けています。