2012-09-25 29 views
10

पर पुन: उत्पन्न नहीं किया जा सकता है व्यवसाय की हमारी लाइन में हम एक आरईएसटी आधारित एपीआई होस्ट कर रहे हैं जो विंडोज एज़ूर द्वारा होस्ट किया गया है और एसक्यूएल एज़ूर के साथ डेटाबेस स्टोरेज के रूप में होस्ट किया गया है।एसक्यूएल एज़ूर पर टाइमआउट समाप्त हो गया; ऑन-प्रिमाइज़ एसक्यूएल सर्वर

वेब रोल (विंडोज 2008R2, आईआईएस 7.5, डब्ल्यूसीएफ, बड़ा उदाहरण) और एसक्यूएल एज़ूर दोनों उत्तरी यूरोप क्षेत्र में होस्ट किए गए हैं।

समस्या यह है कि जब हम गहन एसक्यूएल काम करते हैं तो हमें अक्सर मिलता है "टाइमआउट समाप्त हो गया। ऑपरेशन पूरा होने से पहले टाइमआउट अवधि समाप्त हो गई है या सर्वर प्रतिक्रिया नहीं दे रहा है।"

मुझे यहां क्या परेशानी है, इससे कोई फर्क नहीं पड़ता कि हम क्या करते हैं, हम इसे हमारे ऑन-प्रिमाइज़ एसक्यूएल सर्वर (SQL सर्वर 2008R2) पर उत्तेजित नहीं कर सकते हैं।

इस रहस्य को स्पष्ट करने में कोई मदद की सराहना की जाती है क्योंकि ऐसा लगता है कि वेब रोल इंस्टेंस सीधे SQL Azure इंस्टेंस से बात नहीं कर रहा है हालांकि दोनों उत्तरी यूरोप में स्थित हैं।

एक अधिक विस्तृत अपवाद:

<SqlException> 
    <Message>Timeout expired. The timeout period elapsed prior to completion of the operation or the server is not responding.</Message> 
    <StackTrace> 
     <Line>at System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection)</Line> 
     <Line>at System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning()</Line> 
     <Line>at System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj)</Line> 
     <Line>at System.Data.SqlClient.SqlDataReader.ConsumeMetaData()</Line> 
     <Line>at System.Data.SqlClient.SqlDataReader.get_MetaData()</Line> 
     <Line>at System.Data.SqlClient.SqlCommand.FinishExecuteReader(SqlDataReader ds, RunBehavior runBehavior, String resetOptionsString)</Line> 
     <Line>at System.Data.SqlClient.SqlCommand.RunExecuteReaderTds(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, Boolean async)</Line> 
     <Line>at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method, DbAsyncResult result)</Line> 
     <Line>at System.Data.SqlClient.SqlCommand.RunExecuteReader(CommandBehavior cmdBehavior, RunBehavior runBehavior, Boolean returnStream, String method)</Line> 
     <Line>at System.Data.SqlClient.SqlCommand.ExecuteScalar()</Line> 
     <Line>at SyncInvokeAddCollaboratorFieldInstance(Object , Object[] , Object[])</Line> 
     <Line>at System.ServiceModel.Dispatcher.SyncMethodInvoker.Invoke(Object instance, Object[] inputs, Object[]&amp; outputs)</Line> 
     <Line>at System.ServiceModel.Dispatcher.DispatchOperationRuntime.InvokeBegin(MessageRpc&amp; rpc)</Line> 
     <Line>at System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage5(MessageRpc&amp; rpc)</Line> 
     <Line>at System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage31(MessageRpc&amp; rpc)</Line> 
     <Line>at System.ServiceModel.Dispatcher.MessageRpc.Process(Boolean isOperationContextSet)</Line> 
    </StackTrace> 
    <UserDefinedInformation> 
     <HelpLink.ProdName><![CDATA[Microsoft SQL Server]]></HelpLink.ProdName> 
     <HelpLink.ProdVer><![CDATA[11.00.2065]]></HelpLink.ProdVer> 
     <HelpLink.EvtSrc><![CDATA[MSSQLServer]]></HelpLink.EvtSrc> 
     <HelpLink.EvtID><![CDATA[-2]]></HelpLink.EvtID> 
     <HelpLink.BaseHelpUrl><![CDATA[http://go.microsoft.com/fwlink]]></HelpLink.BaseHelpUrl> 
     <HelpLink.LinkId><![CDATA[20476]]></HelpLink.LinkId> 
    </UserDefinedInformation> 
</SqlException> 
+0

दो डेटाबेस में समान इंडेक्स? हां, अजीब एसक्यूएल विलंबता के कारण सरल प्रश्नों के लिए धीमी गति से धीमा है, लेकिन 8-15 बार एक ही डेटाबेस स्कीमा के लिए काफी खड़ी लगता है। –

+0

हाँ, "समान" स्कीमा जहां एसएसएमएस 2012 एसक्यूएल एज़ूर के लिए स्क्रिप्ट उत्पन्न करता है। "समान" क्योंकि जेनरेट की गई स्क्रिप्ट SQL सर्वर 2008R2 के साथ 1-1 नहीं है। मैं कर सकता हूं - कुछ बिंदु पर - विलंबता को समझें, लेकिन क्या यह "उन्मूलन" नहीं होना चाहिए जब वेब और एसक्यूएल दोनों एक ही क्षेत्र में हों? –

+0

और आप सही हैं; 8-15 अतिरंजित था .. यह 4-8 गुना धीमा है (अलग-अलग परिदृश्य; इसके लिए यह केवल "केवल" 4-5 गुना धीमा है), लेकिन लापता रिकॉर्ड के साथ टाइमआउट पर होता है। –

उत्तर

6

आप एसक्यूएल गहन काम करने के लिए की जरूरत है (उदाहरण के लिए, एक सामान्यीकृत OLTP डेटाबेस में सम्मिलित बयान का एक बहुत) आपके पास करने के लिए असफल ओवर तर्क अपने कोड में की जरूरत है ।

ऑन-प्रिमाइज़ एसक्यूएल सर्वर इससे पीड़ित नहीं होगा, इसलिए SQL Azure पर स्विच करने से पहले इसे ध्यान में रखें।

इन दो लेख मुझे (जोआचिम Isaksson मार्गदर्शन के लिए करने के लिए विशेष धन्यवाद) प्रेरित:

http://blogs.msdn.com/b/sqlazure/archive/2010/05/11/10011247.aspx

http://social.msdn.microsoft.com/Forums/en-US/ssdsgetstarted/thread/7a50985d-92c2-472f-9464-a6591efec4b3/

परिणाम के सारांश में, मैं दो परिणाम जो अब उपलब्ध कराई है परिणामस्वरूप समान (जहां कुछ रिकॉर्ड्स पहले जोड़े गए हैं, मूल प्रश्न के संबंध में विफल-ओवर तर्क को याद करने के लिए नहीं किया गया है: टाइमआउट समाप्त हो गया):

ऑन-प्रिमाइज़ एसक्यूएल सर्वर: 177.285 रिकॉर्ड 427 सेकेंड में

एसक्यूएल एज़ूर डब्ल्यू। असफल तर्क: 17 9.285 रिकॉर्ड 2.247 सेकेंड में - 5.2 गुना धीमा!

मुझे आशा है कि यह एसक्यूएल एज़ूर के साथ संघर्ष करने में दूसरों की मदद कर सकता है। एक सकारात्मक नोट पर; आप सीखते हैं (कठिन तरीका) कि आप अपने देशी इन-हाउस अनुप्रयोगों पर भाग्यशाली और विशेषाधिकार प्राप्त कर चुके हैं :-)

नोट: मुझे अभी भी एक स्पष्टीकरण चाहिए कि यह कैसे हो सकता है .. विलंबता पर दोष देना आसान लगता है, नहीं?