อาจดูเหมือนเป็นคำถามโง่ ๆ แต่ทุกอย่างใน WCF ดูเหมือนจะซับซ้อนกว่าใน asmx มากฉันจะเพิ่มระยะหมดเวลาของบริการ svc ได้อย่างไร
นี่คือสิ่งที่ฉันมีจนถึงตอนนี้:
<bindings>
<basicHttpBinding>
<binding name="IncreasedTimeout"
openTimeout="12:00:00"
receiveTimeout="12:00:00" closeTimeout="12:00:00"
sendTimeout="12:00:00">
</binding>
</basicHttpBinding>
</bindings>
จากนั้นจุดสิ้นสุดของฉันจะถูกแมปเช่นนี้:
<endpoint address=""
binding="basicHttpBinding" bindingConfiguration="IncreasedTimeout"
contract="ServiceLibrary.IDownloads">
<identity>
<dns value="localhost" />
</identity>
</endpoint>
ข้อผิดพลาดที่ฉันได้รับ:
ช่องคำขอหมดเวลาระหว่างรอการตอบกลับหลัง 00: 00: 59.9990000 เพิ่มค่าการหมดเวลาที่ส่งไปยังการเรียกร้องขอหรือเพิ่มค่า SendTimeout บนการผูก เวลาที่กำหนดให้กับการดำเนินการนี้อาจเป็นส่วนหนึ่งของการหมดเวลาที่นานขึ้น
ในไคลเอนต์การทดสอบ WCF มีไอคอนกำหนดค่าที่มีการกำหนดค่ารันไทม์ของบริการของฉัน:
อย่างที่คุณเห็นมันไม่ใช่ค่าเดียวกับที่ฉันตั้งไว้? ผมทำอะไรผิดหรือเปล่า?
<bindings>
<basicHttpBinding>
<binding name="BasicHttpBinding_IDownloads" closeTimeout="00:01:00"
openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"
allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"
maxBufferSize="65536" maxBufferPoolSize="524288" maxReceivedMessageSize="65536"
messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered"
useDefaultWebProxy="true">
<readerQuotas maxDepth="32" maxStringContentLength="8192" maxArrayLength="16384"
maxBytesPerRead="4096" maxNameTableCharCount="16384" />
<security mode="None">
<transport clientCredentialType="None" proxyCredentialType="None"
realm="">
<extendedProtectionPolicy policyEnforcement="Never" />
</transport>
<message clientCredentialType="UserName" algorithmSuite="Default" />
</security>
</binding>
</basicHttpBinding>
</bindings>