NetMsmqBinding クラス

定義

コンピューター間通信に適している、キューに置かれたバインドを表します。Represents a queued binding that is suitable for cross-machine communication.

public ref class NetMsmqBinding : System::ServiceModel::MsmqBindingBase
public class NetMsmqBinding : System.ServiceModel.MsmqBindingBase
type NetMsmqBinding = class
    inherit MsmqBindingBase
Public Class NetMsmqBinding
Inherits MsmqBindingBase
継承
NetMsmqBinding

次の例は、NetMsmqBinding バインドを使用するようにサービスを構成する方法を示しています。The following example shows how to configure a service to use the NetMsmqBinding binding.

まず、構成ファイルを示します。First, the configuration file.

次に、実際のサービス コードを示します。Next, the actual service code.

// Define a service contract. 
[ServiceContract(Namespace="http://Microsoft.ServiceModel.Samples")]
public interface IQueueCalculator
{
    [OperationContract(IsOneWay=true)]
    void Add(double n1, double n2);
    [OperationContract(IsOneWay = true)]
    void Subtract(double n1, double n2);
    [OperationContract(IsOneWay = true)]
    void Multiply(double n1, double n2);
    [OperationContract(IsOneWay = true)]
    void Divide(double n1, double n2);
}
' Define a service contract. 
<ServiceContract(Namespace:="http://Microsoft.ServiceModel.Samples")> _
Public Interface IQueueCalculator
    <OperationContract(IsOneWay:=True)> _
    Sub Add(ByVal n1 As Double, ByVal n2 As Double)
    <OperationContract(IsOneWay := True)> _
    Sub Subtract(ByVal n1 As Double, ByVal n2 As Double)
    <OperationContract(IsOneWay := True)> _
    Sub Multiply(ByVal n1 As Double, ByVal n2 As Double)
    <OperationContract(IsOneWay := True)> _
    Sub Divide(ByVal n1 As Double, ByVal n2 As Double)
End Interface
// Service class that implements the service contract.
// Added code to write output to the console window
public class CalculatorService : IQueueCalculator
{
    [OperationBehavior]
    public void Add(double n1, double n2)
    {
        double result = n1 + n2;
        Console.WriteLine("Received Add({0},{1}) - result: {2}", n1, n2, result);
    }

    [OperationBehavior]
    public void Subtract(double n1, double n2)
    {
        double result = n1 - n2;
        Console.WriteLine("Received Subtract({0},{1}) - result: {2}", n1, n2, result);
    }

    [OperationBehavior]
    public void Multiply(double n1, double n2)
    {
        double result = n1 * n2;
        Console.WriteLine("Received Multiply({0},{1}) - result: {2}", n1, n2, result);
    }

    [OperationBehavior]
    public void Divide(double n1, double n2)
    {
        double result = n1 / n2;
        Console.WriteLine("Received Divide({0},{1}) - result: {2}", n1, n2, result);
    }
}
' Service class that implements the service contract.
' Added code to write output to the console window
Public Class CalculatorService
    Implements IQueueCalculator
    <OperationBehavior> _
    Public Sub Add(ByVal n1 As Double, ByVal n2 As Double) Implements IQueueCalculator.Add
        Dim result As Double = n1 + n2
        Console.WriteLine("Received Add({0},{1}) - result: {2}", n1, n2, result)
    End Sub

    <OperationBehavior> _
    Public Sub Subtract(ByVal n1 As Double, ByVal n2 As Double) Implements IQueueCalculator.Subtract
        Dim result As Double = n1 - n2
        Console.WriteLine("Received Subtract({0},{1}) - result: {2}", n1, n2, result)
    End Sub

    <OperationBehavior> _
    Public Sub Multiply(ByVal n1 As Double, ByVal n2 As Double) Implements IQueueCalculator.Multiply
        Dim result As Double = n1 * n2
        Console.WriteLine("Received Multiply({0},{1}) - result: {2}", n1, n2, result)
    End Sub

    <OperationBehavior> _
    Public Sub Divide(ByVal n1 As Double, ByVal n2 As Double) Implements IQueueCalculator.Divide
        Dim result As Double = n1 / n2
        Console.WriteLine("Received Divide({0},{1}) - result: {2}", n1, n2, result)
    End Sub
End Class
// This is the hosting application. This code can appear directly in the service class as well.
class HostApp
{
    // Host the service within this EXE console application.
    public static void Main()
    {
        // Get MSMQ queue name from appsettings in configuration.
        string queueName = ConfigurationManager.AppSettings["queueName"];

        // Create the transacted MSMQ queue if necessary.
        if (!MessageQueue.Exists(queueName))
            MessageQueue.Create(queueName, true);

        // Get the base address that is used to listen for WS-MetaDataExchange requests.
        // This is useful to generate a proxy for the client.
        string baseAddress = ConfigurationManager.AppSettings["baseAddress"];

        // Create a ServiceHost for the CalculatorService type.
        using (ServiceHost serviceHost = new ServiceHost(typeof(CalculatorService), new Uri(baseAddress)))
        {
            // Open the ServiceHostBase to create listeners and start listening for messages.
            serviceHost.Open();

            // The service can now be accessed.
            Console.WriteLine("The service is ready.");
            Console.WriteLine("Press <ENTER> to terminate service.");
            Console.WriteLine();
            Console.ReadLine();

            // Close the ServiceHostBase to shutdown the service.
            serviceHost.Close();
        }
    }
}
' This is the hosting application. This code can appear directly in the service class as well.
Friend Class HostApp
    ' Host the service within this EXE console application.
    Public Shared Sub Main()
        ' Get MSMQ queue name from appsettings in configuration.
        Dim queueName As String = ConfigurationManager.AppSettings("queueName")

        ' Create the transacted MSMQ queue if necessary.
        If (Not MessageQueue.Exists(queueName)) Then
            MessageQueue.Create(queueName, True)
        End If

        ' Get the base address that is used to listen for WS-MetaDataExchange requests.
        ' This is useful to generate a proxy for the client.
        Dim baseAddress As String = ConfigurationManager.AppSettings("baseAddress")

        ' Create a ServiceHost for the CalculatorService type.
        Using serviceHost As New ServiceHost(GetType(CalculatorService), New Uri(baseAddress))
            ' Open the ServiceHostBase to create listeners and start listening for messages.
            serviceHost.Open()

            ' The service can now be accessed.
            Console.WriteLine("The service is ready.")
            Console.WriteLine("Press <ENTER> to terminate service.")
            Console.WriteLine()
            Console.ReadLine()

            ' Close the ServiceHostBase to shutdown the service.
            serviceHost.Close()
        End Using
    End Sub
End Class

注釈

NetMsmqBinding バインドは、Microsoft Message Queuing (MSMQ) をトランスポートとして使用することによってキューのサポートを提供し、疎結合アプリケーション、失敗の切り分け、読み込みの均一化、および切断操作のサポートを有効にします。The NetMsmqBinding binding provides support for queuing by using Message Queuing (MSMQ) as a transport and enables support for loosely-coupled applications, failure isolation, load leveling and disconnected operations. これらの機能の詳細については、「キューの概要」を参照してください。For a discussion of these features, see Queues Overview.

これは、Windows Communication Foundation (WCF) によって提供されるシステム指定のバインディングの1つです。This is one of the system-provided bindings provided by Windows Communication Foundation (WCF). 手順としては、構成値を使用するバインディングを定義し、コードベースの方法を使用しないことをお勧めします。ただし、サービスの初期化時に構成値を設定する必要がある特定の高度なシナリオの場合は除きます。The recommended procedure is to define the binding using configuration values and not to use a code-based approach, except in certain advanced scenarios where configuration values must be set as a service is initialized.

コンストラクター

NetMsmqBinding()

NetMsmqBinding クラスの新しいインスタンスを初期化します。Initializes a new instance of the NetMsmqBinding class.

NetMsmqBinding(NetMsmqSecurityMode)

指定したセキュリティ モードを使用して、NetMsmqBinding クラスの新しいインスタンスを初期化します。Initializes a new instance of the NetMsmqBinding class using the specified security mode.

NetMsmqBinding(String)

指定した構成バインド要素の設定から NetMsmqBinding クラスの新しいインスタンスを初期化します。Initializes a new instance of the NetMsmqBinding class from the settings of a specified configuration binding element.

プロパティ

CloseTimeout

接続の終了を待機する時間間隔を取得および設定します。これを超えるとトランスポートで例外が発生します。Gets or sets the interval of time provided for a connection to close before the transport raises an exception.

(継承元 Binding)
CustomDeadLetterQueue

各アプリケーションの配信不能キューの場所が含まれている URI を取得または設定します。この URI には、期限切れのメッセージや、転送または配信に失敗したメッセージが配置されます。Gets or sets a URI that contains the location of the dead-letter queue for each application, where messages that have expired or that have failed transfer or delivery are placed.

(継承元 MsmqBindingBase)
DeadLetterQueue

使用する配信不能キューの型を指定する列挙値を取得または設定します。Gets or sets an enumeration value that indicates the type of dead-letter queue to use.

(継承元 MsmqBindingBase)
Durable

このバインディングによって処理されるメッセージが永続的なものか不安定なものかを示す値を取得または設定します。Gets or sets a value that indicates whether the messages processed by this binding are durable or volatile.

(継承元 MsmqBindingBase)
EnvelopeVersion

このバインドによって処理されるメッセージで使用される SOAP のバージョンを取得します。Gets the version of SOAP that is used for messages processed by this binding.

ExactlyOnce

このバインディングによって処理されるメッセージが 1 回だけ受信されるものかどうかを示す値を取得または設定します。Gets or sets a value that indicates whether messages processed by this binding are received exactly once.

(継承元 MsmqBindingBase)
MaxBufferPoolSize

チャネルからメッセージを受け取るメッセージ バッファー マネージャーが使用するために割り当てられる最大メモリ量を取得または設定します。Gets or sets the maximum amount of memory that is allocated for use by the message buffer manager that receives messages from the channel.

MaxReceivedMessageSize

このバインディングで処理されるメッセージの最大サイズ (バイト単位) を取得または設定します。Gets or sets the maximum size, in bytes, for a message that is processed by this binding.

(継承元 MsmqBindingBase)
MaxRetryCycles

受信アプリケーションにメッセージを配信する再試行サイクルの最大数を取得または設定します。Gets or sets the maximum number of retry cycles to attempt delivery of messages to the receiving application.

(継承元 MsmqBindingBase)
MessageVersion

バインディングで構成されるクライアントとサービスが使用するメッセージ バージョンを取得します。Gets the message version used by clients and services configured with the binding.

(継承元 Binding)
Name

バインドの名前を取得または設定します。Gets or sets the name of the binding.

(継承元 Binding)
Namespace

バインドの XML 名前空間を取得または設定します。Gets or sets the XML namespace of the binding.

(継承元 Binding)
OpenTimeout

接続の確立を待機する時間間隔を取得および設定します。これを超えるとトランスポートで例外が発生します。Gets or sets the interval of time provided for a connection to open before the transport raises an exception.

(継承元 Binding)
QueueTransferProtocol

このバインディングが使用するキューに置かれた通信チャネルのトランスポートを示す列挙値を取得または設定します。Gets or sets an enumeration value that indicates the queued communication channel transport that this binding uses.

ReaderQuotas

このバインドに関連付けられる XmlDictionaryReaderQuotas を取得または設定します。Gets or sets the XmlDictionaryReaderQuotas that is associated with this binding.

ReceiveContextEnabled

受信コンテキストの動作が要求されているかどうかを示す値を取得または設定します。Gets or sets a value that indicates whether the receive context behavior is requested.

(継承元 MsmqBindingBase)
ReceiveErrorHandling

有害メッセージの処理方法を指定する列挙値を取得または設定します。Gets or sets an enumeration value that specifies how poison messages are handled.

(継承元 MsmqBindingBase)
ReceiveRetryCount

アプリケーション キューから読み取られるメッセージの即時配信試行の最大回数を取得または設定します。Gets or sets the maximum number of immediate delivery attempts on a message that is read from the application queue.

(継承元 MsmqBindingBase)
ReceiveTimeout

アプリケーション メッセージが受信されない間に、接続が非アクティブになってから切断されるまでの時間を取得または設定します。Gets or sets the interval of time that a connection can remain inactive, during which no application messages are received, before it is dropped.

(継承元 Binding)
RetryCycleDelay

すぐに配信できないメッセージの配信を試みるときの、再試行サイクルの時間遅延を示す値を取得または設定します。Gets or sets a value that indicates the time delay between retry cycles when attempting to deliver a message that cannot be delivered immediately.

(継承元 MsmqBindingBase)
Scheme

このバインドのスキーマを返します。Returns the scheme for this binding.

(継承元 MsmqBindingBase)
Security

このバインドに関連付けられる NetMsmqSecurity を取得または設定します。Gets or sets the NetMsmqSecurity that is associated with this binding.

SendTimeout

書き込み操作の完了を待機する時間間隔を取得および設定します。これを超えるとトランスポートで例外が発生します。Gets or sets the interval of time provided for a write operation to complete before the transport raises an exception.

(継承元 Binding)
TimeToLive

このバインドで処理されるメッセージの期限が切れるまで、キュー内で保持する期間を取得または設定します。Gets or sets the interval of time that indicates how long the messages processed by this binding can be in the queue before they expire.

(継承元 MsmqBindingBase)
UseActiveDirectory

キューのアドレスを Active Directory を使用して変換する必要があるかどうかを示す値を取得または設定します。Gets or sets a value that indicates whether queue addresses should be converted using Active Directory.

UseMsmqTracing

このバインディングにより処理されるメッセージをトレースするかどうかを示す値を取得または設定します。Gets or sets a value that indicates whether messages processed by this binding should be traced.

(継承元 MsmqBindingBase)
UseSourceJournal

このバインディングにより処理されるメッセージのコピーをソース ジャーナル キューに保存するかどうかを示す値を取得または設定します。Gets or sets a value that indicates whether copies of messages processed by this binding should be stored in the source journal queue.

(継承元 MsmqBindingBase)
ValidityDuration

メッセージが受信コンテキスト機能によってロックされる期間を指定する値を取得または設定します。Gets or sets a value that specifies the duration a message will be locked by the receive context feature.

(継承元 MsmqBindingBase)

メソッド

BuildChannelFactory<TChannel>(BindingParameterCollection)

指定した種類のチャネルを作成し、バインド パラメーターのコレクションで指定されている機能を満たすチャネル ファクトリ スタックを、クライアント上に構築します。Builds the channel factory stack on the client that creates a specified type of channel and that satisfies the features specified by a collection of binding parameters.

(継承元 Binding)
BuildChannelFactory<TChannel>(Object[])

指定した種類のチャネルを作成し、オブジェクト配列で指定されている機能を満たすチャネル ファクトリ スタックを、クライアント上に構築します。Builds the channel factory stack on the client that creates a specified type of channel and that satisfies the features specified by an object array.

(継承元 Binding)
BuildChannelListener<TChannel>(BindingParameterCollection)

指定した種類のチャネルを受け入れ、バインド パラメーターのコレクションで指定されている機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified by a collection of binding parameters.

(継承元 Binding)
BuildChannelListener<TChannel>(Object[])

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
BuildChannelListener<TChannel>(Uri, BindingParameterCollection)

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
BuildChannelListener<TChannel>(Uri, Object[])

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
BuildChannelListener<TChannel>(Uri, String, BindingParameterCollection)

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
BuildChannelListener<TChannel>(Uri, String, ListenUriMode, BindingParameterCollection)

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
BuildChannelListener<TChannel>(Uri, String, ListenUriMode, Object[])

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
BuildChannelListener<TChannel>(Uri, String, Object[])

指定した種類のチャネルを受け入れ、指定した機能を満たすチャネル リスナーを、サービス上に構築します。Builds the channel listener on the service that accepts a specified type of channel and that satisfies the features specified.

(継承元 Binding)
CanBuildChannelFactory<TChannel>(BindingParameterCollection)

指定したバインド パラメーターのコレクションを満たすチャネル ファクトリ スタックを、現在のバインドがクライアント上に構築できるかどうかを示す値を返します。Returns a value that indicates whether the current binding can build a channel factory stack on the client that satisfies the collection of binding parameters specified.

(継承元 Binding)
CanBuildChannelFactory<TChannel>(Object[])

オブジェクト配列で指定した要件を満たすチャネル ファクトリ スタックを、現在のバインドがクライアント上に構築できるかどうかを示す値を返します。Returns a value that indicates whether the current binding can build a channel factory stack on the client that satisfies the requirements specified by an object array.

(継承元 Binding)
CanBuildChannelListener<TChannel>(BindingParameterCollection)

指定したバインド パラメーターのコレクションを満たすチャネル リスナー スタックを、現在のバインドがサービス上に構築できるかどうかを示す値を返します。Returns a value that indicates whether the current binding can build a channel listener stack on the service that satisfies the collection of binding parameters specified.

(継承元 Binding)
CanBuildChannelListener<TChannel>(Object[])

オブジェクトの配列で指定した条件を満たすチャネル リスナー スタックを、現在のバインドがサービス上に構築できるかどうかを示す値を返します。Returns a value that indicates whether the current binding can build a channel listener stack on the service that satisfies the criteria specified in an array of objects.

(継承元 Binding)
CreateBindingElements()

現在のバインディングに含まれるバインディング要素の順序付けられたコレクションを返します。Returns an ordered collection of binding elements contained in the current binding.

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判定します。Determines whether the specified object is equal to the current object.

(継承元 Object)
GetHashCode()

既定のハッシュ関数として機能します。Serves as the default hash function.

(継承元 Object)
GetProperty<T>(BindingParameterCollection)

バインド スタックの適切な層から、要求のあった型指定されたオブジェクト (ある場合) を返します。Returns a typed object requested, if present, from the appropriate layer in the binding stack.

(継承元 Binding)
GetType()

現在のインスタンスの Type を取得します。Gets the Type of the current instance.

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。Creates a shallow copy of the current Object.

(継承元 Object)
ShouldSerializeName()

バインドの名前をシリアル化する必要があるかどうかを示す値を返します。Returns whether the name of the binding should be serialized.

(継承元 Binding)
ShouldSerializeNamespace()

バインドの名前空間をシリアル化する必要があるかどうかを示す値を返します。Returns whether the namespace of the binding should be serialized.

(継承元 Binding)
ShouldSerializeReaderQuotas()

ReaderQuotas プロパティが既定値から変更されたためにシリアル化する必要があるかどうかを示す値を返します。Returns a value that indicates whether the ReaderQuotas property has changed from its default value and should be serialized.

ShouldSerializeSecurity()

Security プロパティが既定値から変更されたためにシリアル化する必要があるかどうかを示す値を返します。Returns a value that indicates whether the Security property has changed from its default value and should be serialized.

ToString()

現在のオブジェクトを表す string を返します。Returns a string that represents the current object.

(継承元 Object)

明示的なインターフェイスの実装

IBindingRuntimePreferences.ReceiveSynchronously

受信した要求を処理するには同期と非同期のどちらの方が効率的かを示す値を取得します。Gets a value that indicates whether incoming requests can be handled more efficiently synchronously or asynchronously.

(継承元 MsmqBindingBase)

適用対象