Condividi tramite


<associazioneNetMsmq>

Definisce un'associazione in coda adatta per la comunicazione fra computer.

<system.serviceModel>
  <bindings>
    <associazioneNetMsmq>

<netMsmqBinding>
    <binding 
       closeTimeout="TimeSpan" 
       customDeadLetterQueue="Uri"
       deadLetterQueue="Uri"
       durable="Boolean"
       exactlyOnce="Boolean" 
       maxBufferPoolSize="Integer"
       maxReceivedMessageSize"Integer"
       maxRetryCycles="Integer" 
       name="string" 
       openTimeout="TimeSpan" 
       poisonMessageHandling="Disabled/EnabledIfSupported" 
       queueTransferProtocol="Native/Srmp/SrmpSecure"
       receiveErrorHandling="Drop/Fault/Move/Reject"
       receiveTimeout="TimeSpan" 
       receiveRetryCount="Integer"
       rejectAfterLastRetry="Boolean" 
       retryCycleDelay="TimeSpan"  
       sendTimeout="TimeSpan" 
       timeToLive="TimeSpan"  
       useActiveDirectory="Boolean"
       useMsmqTracing="Boolean
       useSourceJournal="Boolean"
          <security>
                  <message  
                        algorithmSuite="Basic128/Basic192/Basic256/Basic128Rsa15/Basic256Rsa15/TripleDes/TripleDesRsa15/Basic128Sha256/Basic192Sha256/TripleDesSha256/Basic128Sha256Rsa15/Basic192Sha256Rsa15/Basic256Sha256Rsa15/TripleDesSha256Rsa15"
            clientCredentialType="None/Windows/UserName/Certificate/InfoCard "/>
                  <transport msmqAuthenticationMode="None/WindowsDomain/Certificate"
            msmqEncryptionAlgorithm="RC4Stream/AES"
            msmqProtectionLevel="None/Sign/EncryptAndSign"
            msmqSecureHashAlgorithm="MD5/SHA1/SHA256/SHA512" />
          </security>
         <readerQuotas maxDepth="integer" 
               maxStringContentLength="integer"
              maxByteArrayContentLength="integer"
              maxBytesPerRead="integer"
               maxNameTableCharCount="integer" />
</netMsmqBinding>

Attributi ed elementi

Attributi

Attributo Descrizione

closeTimeout

Valore TimeSpan che specifica l'intervallo di tempo fornito per il completamento di un'operazione di chiusura. Questo valore deve essere maggiore o uguale a Zero. L'impostazione predefinita è 00:01:00.

customDeadLetterQueue

URI che contiene il percorso della coda dei messaggi non recapitabili per applicazione, in cui vengono collocati i messaggi scaduti o che non possono essere trasferiti o recapitati.

La coda dei messaggi non recapitabili è una coda del gestore delle code dell'applicazione di origine contenente i messaggi scaduti che sono risultati non recapitabili.

L'URI specificato da CustomDeadLetterQueue deve utilizzare lo schema net.msmq.

deadLetterQueue

Valore DeadLetterQueue che specifica quale tipo di coda dei messaggi non recapitabili utilizzare, se presente.

Una coda dei messaggi non recapitabili è una posizione nella quale vengono trasferiti i messaggi che sono stati recapitati.

Per i messaggi che richiedono la garanzia exactlyOnce, ovvero, che l'attributo exactlyOnce sia impostato su true, questo attributo viene impostato come valore predefinito su una coda dei messaggi non recapitabili transazionale a livello di sistema in MSMQ.

Per i messaggi che non richiedono alcuna garanzia, l'impostazione predefinita dell'attributo è null.

durable

Valore booleano che indica se il messaggio nella coda è durevole o volatile. Un messaggio durevole sopravvive a un arresto del gestore delle code, un messaggio volatile no. I messaggi volatili sono utili quando le applicazioni richiedono minore latenza e possono tollerare messaggi perduti occasionalmente. Se l'attributo exactlyOnce è impostato su true, i messaggi devono essere durevoli. Il valore predefinito è true.

exactlyOnce

Valore booleano che indica se ciascun messaggio elaborato da questa associazione viene recapitato una sola volta. Il mittente riceverà quindi una notifica degli errori di recapito. Quando durable è false, questo attributo viene ignorato e i messaggi vengono trasferiti senza garanzia di recapito. Il valore predefinito è true. Per ulteriori informazioni, vedere ExactlyOnce.

maxBufferPoolSize

Numero intero che specifica la dimensione del pool di buffer massima per questa associazione. L'impostazione predefinita è 8.

maxReceivedMessageSize

Numero intero positivo che definisce la dimensione massima del messaggio, in byte, incluso le intestazioni, elaborate da questa associazione. Il mittente di un messaggio che supera questo limite riceverà un errore SOAP. Il destinatario elimina il messaggio e crea una voce dell'evento nel registro di traccia. L'impostazione predefinita è 65536. Questo vincolo alla dimensione dei messaggi è volto a limitare l'esposizione agli attacchi di tipo Denial of Service (DoS).

maxRetryCycles

Numero intero che indica il numero di cicli di ripetizione utilizzati dalla funzionalità di rilevazione dei messaggi non elaborabili. Un messaggio diventa non elaborabile quando falliscono tutti i tentativi di recapito di tutti i cicli. L'impostazione predefinita è 3. Per ulteriori informazioni, vedere MaxRetryCycles.

name

Attributo obbligatorio. Stringa che contiene il nome della configurazione dell'associazione. Questo valore deve essere univoco perché viene utilizzato per identificare l'associazione.

openTimeout

Valore TimeSpan che specifica l'intervallo di tempo fornito per il completamento di un'operazione di apertura. Questo valore deve essere maggiore o uguale a Zero. L'impostazione predefinita è 00:01:00.

QueueTransferProtocol

Valore QueueTransferProtocol valido che specifica il trasporto del canale di comunicazione in coda utilizzato da questa associazione. MSMQ non supporta l'indirizzamento di Active Directory in caso di utilizzo di SOAP Reliable Messaging Protocol. Non è necessario, pertanto, impostare questo attributo su Srmp o su Srmps quando l'attributo useActiveDirectory è impostato su true.

receiveErrorHandling

Valore ReceiveErrorHandling che specifica come vengono gestiti i messaggi non elaborabili e non distribuibili.

receiveRetryCount

Numero intero che specifica il numero massimo di tentativi eseguiti dal gestore delle code per inviare un messaggio prima che questo venga trasferito alla coda di tentativi.

receiveTimeout

Valore TimeSpan che specifica l'intervallo di tempo fornito per il completamento di un'operazione di ricezione. Questo valore deve essere maggiore o uguale a Zero. L'impostazione predefinita è 00:10:00.

retryCycleDelay

Valore TimeSpan che specifica l'intervallo di tempo tra i cicli di ripetizione dei tentativi di recapitare un messaggio che è impossibile recapitare immediatamente. Il valore definisce solo il tempo di attesa minimo perché l'attesa effettiva può essere più lunga. Il valore predefinito è 00:10:00. Per ulteriori informazioni, vedere RetryCycleDelay.

sendTimeout

Valore TimeSpan che specifica l'intervallo di tempo fornito per il completamento di un'operazione di invio. Questo valore deve essere maggiore o uguale a Zero. L'impostazione predefinita è 00:01:00.

timeToLive

Un valore TimeSpan che specifica la durata di validità dei messaggi prima che siano scaduti e inseriti nella coda dei messaggi non recapitabili. L'impostazione predefinita è 1.00:00:00.

L'attributo è impostato per verificare che i messaggi a scadenza non risultino non aggiornati prima di essere elaborati dalle applicazioni riceventi. Un messaggio in una coda che non viene utilizzato dall'applicazione ricevente entro l'intervallo di tempo specificato viene considerato scaduto. I messaggi scaduti vengono inviati a una coda speciale denominata coda dei messaggi non recapitabili. Il percorso della coda dei messaggi non recapitabili viene impostato con l'attributo DeadLetterQueue o sul valore appropriato predefinito, in base alle garanzie.

usingActiveDirectory

Valore booleano che specifica se convertire gli indirizzi delle code mediante Active Directory.

Gli indirizzi delle code MSMQ possono essere costituiti da nomi di percorso o da nomi di formato Direct. Con un nome di formato Direct, MSMQ risolve il nome del computer utilizzando DNS, NetBIOS o IP. Con un nome di percorso, MSMQ risolve il nome del computer utilizzando Active Directory.

Per impostazione predefinita, il trasporto in coda del sistema Windows Communication Foundation (WCF) converte l'URI di una coda di messaggi in un nome di formato Direct. L'impostazione della proprietà UseActiveDirectory su true consente a un'applicazione di specificare che il trasporto in coda deve risolvere il nome del computer utilizzando Active Directory invece di DNS, NetBIOS o IP.

useMsmqTracing

Valore booleano che specifica se i messaggi elaborati da questa associazione devono essere tracciati. Il valore predefinito è false. Quando la traccia è attivata, i messaggi di report vengono creati e inviati alla coda dei report ogni volta che il messaggio lascia o arriva in un computer in cui è installato Accodamento messaggi.

useSourceJournal

Valore booleano che specifica se le copie dei messaggi elaborati da questa associazione devono essere archiviate nella coda journal di origine. Il valore predefinito è false.

Le applicazioni in coda che devono tenere un registro dei messaggi che hanno lasciato la coda in uscita del computer possono copiare i messaggi in una coda journal. Quando un messaggio lascia la coda in uscita e viene ricevuto un riconoscimento che il messaggio è stato ricevuto nel computer di destinazione, una copia del messaggio viene mantenuta nella coda journal del sistema del computer di invio.

Elementi figlio

Elemento Descrizione

<quoteReader>

Definisce i vincoli sulla complessità dei messaggi SOAP che possono essere elaborati dagli endpoint configurati con questa associazione. L'elemento è di tipo XmlDictionaryReaderQuotasElement.

<se&lt;curity> di <netMsmqBinding>

Definisce le impostazioni di protezione per l'associazione. L'elemento è di tipo NetMsmqSecurityElement.

Elementi padre

Elemento Descrizione

<bindings>

Questo elemento contiene un insieme di associazioni standard e personalizzate. Ciascuna voce è identificata dal relativo name. I servizi utilizzano le associazioni collegandole mediante il name.

Osservazioni

L'associazione netMsmqBinding fornisce il supporto per la gestione tramite coda basata sul sistema di accodamento dei messaggi MSMQ come trasporto. Tale associazione fornisce inoltre il supporto per le applicazioni a regime di controllo libero, per l'isolamento degli errori, per la distribuzione ottimale dei carichi e per le operazioni disconnesse. Per una discussione su queste funzionalità, vedere Queues in WCF.

Esempio

<configuration>
<system.ServiceModel>
    <bindings>
           <netMsmqBinding>
                <binding name="test"
                         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" 
                         maxMessageSize="1000"
                         maxRetries="11"
                         maxRetryCycles="12" 
                         poisonMessageHandling="Disabled" 
                         rejectAfterLastRetry="false" 
                         retryCycleDelay="00:05:55" 
                         timeToLive="00:11:11" 
                         sourceJournal="true"
                         useMsmqTracing="true"
                         useActiveDirectory="true">
                         <security>
                             <message clientCredentialType="Windows" />
                         </security>
            </netMsmqBinding>
    </bindings>
</system.ServiceModel>
</configuration>

Vedere anche

Riferimenti

NetMsmqBinding
NetMsmqBindingElement

Concetti

<associazione>

Altre risorse

Windows Communication Foundation Bindings
Configuring System-Provided Bindings
Using Bindings to Configure Services and Clients
Queues in WCF