<msmqIntegrationBinding><msmqIntegrationBinding>

MSMQ を介してメッセージをルーティングすることでキューのサポートを提供するバインディングを定義します。Defines a binding that provides queuing support by routing messages through MSMQ.

<system.ServiceModel ><system.ServiceModel>
<bindings><bindings>
msmqIntegrationBindingmsmqIntegrationBinding

構文Syntax

<msmqIntegrationBinding>
  <binding closeTimeout="TimeSpan"
           customDeadLetterQueue="Uri"
           deadLetterQueue="Uri"
           durable="Boolean"
           exactlyOnce="Boolean"
           maxReceivedMessageSize="Integer"
           maxRetryCycles="Integer"
           name="String"
           openTimeout="TimeSpan"
           receiveContextEnabled="Boolean"
           receiveErrorHandling="Drop/Fault/Move/Reject"
           receiveTimeout="TimeSpan"
           receiveRetryCount="Integer"
           retryCycleDelay="TimeSpan"
           sendTimeout="TimeSpan"
           serializationFormat="XML/Binary/ActiveX/ByteArray/Stream"
           timeToLive="TimeSpan"
           useMsmqTracing="Boolean"
           useSourceJournal="Boolean">
  </binding>
</msmqIntegrationBinding>

属性および要素Attributes and Elements

以降のセクションでは、属性、子要素、および親要素について説明します。The following sections describe attributes, child elements, and parent elements

属性Attributes

属性Attribute 説明Description
closeTimeoutcloseTimeout クローズ操作が完了するまでの期間を指定する TimeSpan 値。A TimeSpan value that specifies the interval of time provided for a close operation to complete. この値は必ず Zero 以上である必要があります。This value should be greater than or equal to Zero. 既定値は 00:01:00 です。The default is 00:01:00.
customDeadLetterQueuecustomDeadLetterQueue アプリケーションごとの配信不能キューの場所が含まれている URI です。ここには、期限切れのメッセージや、転送または配信に失敗したメッセージが配置されます。A URI that contains the location of the per-application dead letter queue, where messages that have expired or that have failed transfer or delivery are placed.

配信不能キューは、送信元アプリケーションのキュー マネージャーにある、配信に失敗した期限切れメッセージのキューです。The dead letter queue is a queue on the queue manager of the sending application for expired messages that have failed to be delivered.

CustomDeadLetterQueue によって指定される URI は、net.msmq スキームを使用する必要があります。The URI that is specified by CustomDeadLetterQueue must use the net.msmq scheme.
deadLetterQueuedeadLetterQueue 使用する配信不能キューがある場合にその種類を指定する DeadLetterQueue 値。A DeadLetterQueue.value specifying which type of dead-letter queue to use, if any

配信不能キューは、アプリケーションへの配信に失敗したメッセージが転送される場所です。A dead-letter queue is the location that messages that have failed to be delivered to the application will be transferred.

exactlyOnce 保証が必要なメッセージ (つまり、exactlyOnce 属性が true に設定される) の場合、この属性は、既定で MSMQ のトランザクション システム全体の配信不能キューになります。For messages that require exactlyOnce assurance (i.e., the exactlyOnce attribute is set to true), this attribute defaults to the system-wide transactional dead-letter queue in MSMQ.

保証が必要ないメッセージの場合、この属性の既定値は null です。For messages that require no assurances, this attribute defaults to null.
durabledurable メッセージがキューで非揮発性か揮発性かを示すブール値です。A Boolean value that indicates whether the message is durable or volatile in the queue. 非揮発性メッセージは、キュー マネージャーがクラッシュしても残り、揮発性メッセージは失われます。A durable message survives a queue manager crash, while a volatile message does not. アプリケーションで待ち時間の短縮が要求され、場合によってはメッセージが失われてもかまわない場合は、揮発性メッセージが適しています。Volatile messages are useful when applications require lower latency and can tolerate occasional lost messages. exactlyOnce 属性が true に設定されている場合、メッセージは永続的にする必要があります。If the exactlyOnce attribute is set to true, the messages must be durable. 既定値は true です。The default is true.
exactlyOnceexactlyOnce 各メッセージが 1 回だけ受信されるかどうかを示すブール値です。A Boolean value that indicates whether each message is delivered only once. その後、送信側に配信エラーが通知されます。The sender will then be notified of delivery failures. durablefalse の場合、この属性は無視されて、配信が保証されずにメッセージが転送されます。When durable is false, this attribute is ignored and messages are transferred without delivery assurance. 既定値は、true です。The default is true. 詳細については、「 ExactlyOnce 」を参照してください。For more information, see ExactlyOnce.
maxReceivedMessageSizemaxReceivedMessageSize このバインディングにより処理される最大メッセージ サイズ (ヘッダーを含む) をバイト単位で定義する正の整数です。A positive integer that defines the maximum message size, in bytes, including headers, that is processed by this binding. この制限を超えるメッセージの送信者が、SOAP エラーを受信します。The sender of a message exceeding this limit will receive a SOAP fault. メッセージは受信者によって破棄され、トレース ログにこのイベントのエントリが作成されます。The receiver drops the message and creates an entry of the event in the trace log. 既定値は 65536 です。The default is 65536. このメッセージ サイズの制限は、サービス拒否 (DoS) 攻撃への露出を制限するためのものです。This bound on message size is intended to limit exposure to Denial of Service (DoS) attacks.
maxRetryCyclesmaxRetryCycles 有害メッセージ検出機能により使用される再試行サイクルの回数を示す整数です。An integer that indicates the number of retry cycles used by the poison-message detection feature. すべてのサイクルの配信試行にすべて失敗すると、メッセージは有害メッセージになります。A message becomes a poison message when it fails all delivery attempts of all cycles. 既定値は 2 です。The default is 2. 詳細については、「 MaxRetryCycles 」を参照してください。For more information, see MaxRetryCycles.
namename バインディングの構成名を格納する文字列です。A string that contains the configuration name of the binding. この値は、バインディングの ID として使用されるため、一意にする必要があります。This value should be unique because it is used as an identification for the binding. .NET Framework 4.NET Framework 4 以降では、バインディングおよび動作に名前を付ける必要はありません。Starting with .NET Framework 4.NET Framework 4, bindings and behaviors are not required to have a name. 既定の構成と無名のバインディングおよび動作の詳細については、「簡略化された構成」と「WCF サービスの構成を簡略化」を参照してください。For more information about default configuration and nameless bindings and behaviors, see Simplified Configuration and Simplified Configuration for WCF Services.
openTimeoutopenTimeout 実行中の操作が完了するまでの時間間隔を指定する TimeSpan 値です。A TimeSpan value that specifies the interval of time provided for an open operation to complete. この値は必ず Zero 以上である必要があります。This value should be greater than or equal to Zero. 既定値は 00:01:00 です。The default is 00:01:00.
receiveErrorHandlingreceiveErrorHandling 有害メッセージおよびディスパッチ不能メッセージの処理方法を指定する ReceiveErrorHandling 値。A ReceiveErrorHandling value that specifies how poison and nondispatchable messages are handled.
receiveRetryCountreceiveRetryCount アプリケーション キューからアプリケーションへのメッセージの転送が失敗した場合に、キュー マネージャーが即時再試行を行う最大回数を指定する整数。An integer that specifies the maximum number of immediate retries the queue manager should attempt if transmission of a message from the application queue to the application fails.

配信試行を最大回数実行してもアプリケーションがメッセージにアクセスできない場合、メッセージは、後で再配信するために再試行キューに送信されます。If the maximum number of delivery attempts is reached and the message is not accessed by the application, then the message is sent to a retry queue for redelivery at a later time. メッセージが送信キューに戻されるまでの時間は、retryCycleDelay で制御されます。The amount of time before the message is transferred back to the sending queue is controlled by retryCycleDelay. 再試行サイクルが maxRetryCycles 値に達した場合は、メッセージが有害メッセージ キューに送信されるか、送信者に否定応答が返されます。If retry cycles reach the maxRetryCycles value, then the message is either sent to the poison-message queue, or a negative acknowledgement is sent back to the sender.
receiveTimeoutreceiveTimeout 受信操作が完了するまでの時間間隔を指定する TimeSpan 値です。A TimeSpan value that specifies the interval of time provided for a receive operation to complete. この値は必ず Zero 以上である必要があります。This value should be greater than or equal to Zero. 既定値は 00:10:00 です。The default is 00:10:00.
receiveContextEnabledreceiveContextEnabled キュー内のメッセージを処理するための受信コンテキストが有効になっているかどうかを指定するブール値。A Boolean that specifies if receive context for processing messages in queues is enabled. この設定されている場合true、サービスことができます「ピーク」キューにメッセージを処理を開始して、キューに残ります問題が発生した例外がスローされた場合は、します。When this is set to true, a service can "peek" a message on the queue to begin processing it, and, if anything goes wrong and an exception is thrown, it remains on the queue. サービスできますもメッセージを「ロック」時刻で、後で処理を再試行するためにします。Services can also "lock" messages in order to retry processing at a later point in time. ReceiveContext は、メッセージを「完了」キューから削除するために 1 回処理するためのメカニズムを提供します。メッセージは、ネットワーク経由で読み取りおよびに再書き込みキューを不要になったされていると、個々 のメッセージは処理中にさまざまなサービス インスタンス間でバウンスします。ReceiveContext provides a mechanism for "completing" the message once processed so it can be removed from the queue.Messages are no longer being read and re-written to queues over the network, and individual messages aren’t bouncing across different service instances during processing.
retryCycleDelayretryCycleDelay すぐに配信できなかったメッセージを配信しようとするときの、再試行サイクルの時間遅延を指定する TimeSpan 値です。A TimeSpan value that specifies the time delay between retry cycles when attempting to deliver a message that could not be delivered immediately. 実際の待機時間はさらに長くなる場合があるため、この値で定義されるのは最小待機時間だけです。The value defines only the minimum wait time because actual wait time can be longer. 既定値は、00:30:00 です。The default value is 00:30:00. 詳細については、「 RetryCycleDelay 」を参照してください。For more information, see RetryCycleDelay.
sendTimeoutsendTimeout 送信操作が完了するまでの時間間隔を指定する TimeSpan 値です。A TimeSpan value that specifies the interval of time provided for a send operation to complete. この値は必ず Zero 以上である必要があります。This value should be greater than or equal to Zero. 既定値は 00:01:00 です。The default is 00:01:00.
serializationFormatserializationFormat メッセージ本文のシリアル化に使用される形式を定義します。Defines the format used for serialization of the message body. この属性は MsmqMessageSerializationFormat 型です。This attribute is of type MsmqMessageSerializationFormat.
timeToLivetimeToLive メッセージの期限が切れて、配信不能キューに入れられるまでのメッセージの有効期間を指定する TimeSpan 値です。A TimeSpan value that specifies how long the messages are valid before they are expired and put into the dead-letter queue. 既定値は 1.00:00:00 です。The default is 1.00:00:00.

この属性を設定すると、タイムリーなメッセージが受信側アプリケーションで処理される前に古くなることがなくなります。This attribute is set to ensure that time-sensitive messages do not become stale before they are processed by the receiving applications. キュー内のメッセージのうち、指定された期間内に受信アプリケーションで処理されなかったメッセージは、期限切れと呼ばれます。A message in a queue that is not consumed by the receiving application within the time interval specified is said to be expired. 期限切れのメッセージは、配信不能キューと呼ばれる特別なキューに送信されます。Expired messages are sent to special queue called the dead letter queue. 配信不能キューの場所は、保証の内容に基づいて、DeadLetterQueue 属性を使用して設定されるか、適切な既定値に設定されます。The location of the dead letter queue is set with the DeadLetterQueue attribute or to the appropriate default, based on assurances.
useMsmqTracinguseMsmqTracing このバインディングにより処理されるメッセージをトレースするかどうかを指定するブール値です。A Boolean value that specifies whether messages processed by this binding should be traced. 既定値は、false です。The default is false. トレースが有効な場合、メッセージ キュー コンピューターでメッセージが送受信されるたびに、レポート メッセージが作成され、レポート キューに送信されます。When tracing is enabled, report messages are created and sent to the report queue each time the message leaves or arrives at a Message Queuing computer.
useSourceJournaluseSourceJournal このバインディングにより処理されるメッセージのコピーをソース ジャーナルに保存するかどうかを指定するブール値です。A Boolean value that specifies copies of messages processed by this binding should be stored in the source journal. 既定値は、false です。The default is false.

キューに置かれたアプリケーションでは、コンピューターの発信キューから送信されたメッセージの記録を残す場合は、メッセージをジャーナル キューにコピーできます。Queued applications that want to keep a record of messages that have left the computer's outgoing queue can copy the messages to a journal queue. メッセージが発信キューから送信され、送信先のコンピューターで受信されたという応答を受け取ると、メッセージのコピーが送信元のコンピューターのシステム ジャーナル キューに保持されます。Once a message leaves the outgoing queue and an acknowledgment is received that the message was received on the destination computer, a copy of the message is kept in the sending computer's system journal queue.

{SerializationFormat} 属性{serializationFormat} Attribute

[値]Value 説明Description
XmlXml XML 形式XML format
2 項Binary バイナリ形式Binary format
ActiveXActiveX ActiveX 形式ActiveX format
ByteArrayByteArray オブジェクトをバイト配列にシリアル化します。Serializes the object to an array of bytes.
ストリームStream ストリームとして書式設定された本文。The body formatted as a stream

子要素Child Elements

要素Element 説明Description
<security><security> バインディングのセキュリティ設定を定義します。Defines the security settings for the binding. この要素は MsmqIntegrationSecurityElement 型です。This element is of type MsmqIntegrationSecurityElement.

親要素Parent Elements

要素Element 説明Description
<bindings><bindings> この要素には、標準バインディングおよびカスタム バインドのコレクションが保持されます。This element holds a collection of standard and custom bindings.

RemarksRemarks

このバインド要素にメッセージを送信し、COM、MSMQ ネイティブ Api、またはで定義された型のいずれかを使用する既存の MSMQ アプリケーションからメッセージを受信する Windows Communication Foundation (WCF) アプリケーションを有効にするために使用できます、System.Messaging名前空間をメッセージを永続的に格納する必要があります、かどうかは、キュー、転送保証の対処方法を指定するには、この構成要素とメッセージを保護および認証する方法を使用できます。This binding element can be used to enable Windows Communication Foundation (WCF) applications to send messages to and receive messages from existing MSMQ applications that use either COM, MSMQ native APIs, or the types defined in the System.Messaging namespace You can use this configuration element to specify ways to address the queue, transfer assurances, whether messages must be durably stored, and how messages should be protected and authenticated. 詳細については、「方法 :WCF エンドポイントでメッセージを交換して、メッセージ キュー アプリケーションします。For more information, see How to: Exchange Messages with WCF Endpoints and Message Queuing Applications.

Example

<configuration>
  <system.ServiceModel>
    <bindings>
      <msmqIntegrationBinding>
        <binding closeTimeout="00:00:10"
                 openTimeout="00:00:20"
                 receiveTimeout="00:00:30"
                 sendTimeout="00:00:40"
                 deadLetterQueue="net.msmq://localhost/blah"
                 durable="true"
                 exactlyOnce="true"
                 maxReceivedMessageSize="1000"
                 maxImmediateRetries="11"
                 maxRetryCycles="12"
                 poisonMessageHandling="Disabled"
                 rejectAfterLastRetry="false"
                 retryCycleDelay="00:05:55"
                 timeToLive="00:11:11"
                 useSourceJournal="true"
                 useMsmqTracing="true"
                 serializationFormat="Binary">
          <security mode="None" />
        </binding>
      </msmqIntegrationBinding>
    </bindings>
  </system.ServiceModel>
</configuration>

関連項目See also