1

ホストされているWCFサービスがあります。サービス呼び出しは、ビジネス要件に従って処理を実行するのに 30 秒または数分以上 (ただし 10 未満) かかります。クライアントがプロキシの背後にあり、サーバー側での処理が 1 分を超える場合、問題に直面しています。処理が 1 分未満の場合、呼び出しは問題なく成功します。これは、プロキシ経由のサーバーへの接続性に問題がないことを示しています。ただし、問題はプロキシ サーバーでのタイムアウトに関するものです。

次の例外が発生します

リクエスト チャネルは、00:09:59.9619962 の後に応答を待っている間にタイムアウトになりました。リクエストへの呼び出しに渡されるタイムアウト値を増やすか、Binding の SendTimeout 値を増やしてください。この操作に割り当てられた時間は、より長いタイムアウトの一部であった可能性があります。

サーバー スタック トレース: System.ServiceModel.Channels.RequestChannel.Request(メッセージ メッセージ、TimeSpan タイムアウト) で System.ServiceModel.Dispatcher.RequestChannelBinder.Request(メッセージ メッセージ、TimeSpan タイムアウト) で System.ServiceModel.Channels.ServiceChannel.Call(String)アクション、ブール一方向、ProxyOperationRuntime 操作、Object[] ins、Object[] outs、TimeSpan タイムアウト) System.ServiceModel.Channels.ServiceChannelProxy.InvokeService(IMethodCallMessage メソッド呼び出し、ProxyOperationRuntime 操作) System.ServiceModel.Channels.ServiceChannelProxy.Invoke(IMessage) でメッセージ)

[0] で例外が再スローされました。 IMyService.GeneratePackage(Guid clientId) at ConsoleApplication1.ServiceReference1.MyClient.GeneratePackage(Guid clientId) in F:\Code\Samples\ConsoleApplication1\ConsoleApplication1\Service References\ServiceReference1\Reference.cs:line 398 at ConsoleApplication1.Program.Main(String [] args) in F:\Code\Samples\ConsoleApplication1\ConsoleApplication1\Program.cs:line 26

私の構成セクションは次のようになります

<system.serviceModel>
    <diagnostics>
        <messageLogging logEntireMessage="true" logMalformedMessages="true"
            logMessagesAtServiceLevel="true" logMessagesAtTransportLevel="true" />
    </diagnostics>
    <bindings>
        <wsHttpBinding>
            <binding name="WSHttpBinding_IMyService" closeTimeout="00:10:00"
                openTimeout="00:10:00" receiveTimeout="00:10:00" sendTimeout="00:10:00"
                bypassProxyOnLocal="false" transactionFlow="false" hostNameComparisonMode="StrongWildcard"
                maxBufferPoolSize="524288" maxReceivedMessageSize="20000000"
                messageEncoding="Text" textEncoding="utf-8" useDefaultWebProxy="true"
                allowCookies="false">
                <readerQuotas maxDepth="32" maxStringContentLength="200000000"
                    maxArrayLength="16384" maxBytesPerRead="4096" maxNameTableCharCount="16384" />
                <reliableSession ordered="true" inactivityTimeout="00:10:00"
                    enabled="false" />
                <security mode="None">
                    <transport clientCredentialType="Windows" proxyCredentialType="None"
                        realm="" />
                    <message clientCredentialType="Windows" negotiateServiceCredential="true"
                        establishSecurityContext="true" />
                </security>
            </binding>
        </wsHttpBinding>
    </bindings>
    <client>
        <endpoint address="http://TestServer.abc.co.za:8432/TestManager/MyService"
            binding="wsHttpBinding" bindingConfiguration="WSHttpBinding_IMyService"
            contract="ServiceReference1.IMyService" name="WSHttpBinding_IMyService">
            <identity>
                <dns value="TestServer.abc.co.za" />
            </identity>
        </endpoint>
    </client>
</system.serviceModel>

次のオプションを試しました。

1) MessageInspector を実装し、「Keep-Alive」を「2000000」に設定しました。2) Fiddler を介して要求と応答を確認し、HTTP/1.1 504 接続タイムアウトを参照してください。

私の理解では、すべてのタイムアウトが WCF サービス レベルで設定されていても、プロキシは 1 分を超えて待機していません。

WCF サービス呼び出しが返されるまでプロキシが確実に待機するようにするにはどうすればよいですか?

この問題を解決するための入力を得ることができれば幸いです。

4

0 に答える 0