Objawy
Gdy użytkownik próbuje nawiązać połączenie Microsoft SQL Server 2012 poprzez detektor grupy dostępności (AlwaysOn) z aplikacji klienckiej, może wystąpić komunikat o błędzie limitu czasu logowania.
Na przykład po wybraniu polecenia Narzędzia SqlCmd , może zostać wyświetlony następujący komunikat o błędzie:
Polecenie sqlcmd: Błąd: Microsoft SQL Native Client: Upłynął limit czasu logowania.
[Microsoft] (Program SQL Server Native Client 11.0) Nie można ukończyć logowania przetworzyć ze względu na opóźnienia w otwarciu połączenia z serwerem
Kiedy używać programu Microsoft.NET Framework 3.5 na lub Microsoft.NET Framework 4.0, na aplikacji przy użyciu programu .net Framework Data provider for SQL Server może zostać wyświetlony następujący komunikat o błędzie:
Upłynął limit czasu. Limit upłynął przed ukończeniem operacji lub serwer nie odpowiada.
w System.Data.SqlClient.SqlInternalConnection.OnError (wyjątek, Boolean breakConnection)
w System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning()
w System.Data.SqlClient.TdsParserStateObject.ReadSniError (TdsParserStateObject stateObj, błąd UInt32)
w System.Data.SqlClient.TdsParserStateObject.ReadSni (DbAsyncResult asyncResult, TdsParserStateObject stateObj)
o System.Data.SqlClient.TdsParserStateObject.ReadNetworkPacket()
w System.Data.SqlClient.TdsParser.ConsumePreLoginHandshake (wartość logiczna zaszyfrować, trustServerCert typu Boolean, wartość logiczna & marsCapable)
w System.Data.SqlClient.TdsParser.Connect (serverInfo ServerInfo, SqlInternalConnectionTds connHandler, ignoreSniOpenTimeout typu Boolean, Int64 timerExpire zaszyfrować Boolean, Boolean trustServerCert, integratedSecurity typu Boolean, Boolean withFailover)
w system.Data.SqlClient.sqlinternalconnectiontds.attemptoneloginserverinfo (ServerInfo serverInfo, NoweHasło ciąg, ignoreSniOpenTimeout typu Boolean, limit czasu TimeoutTimer, SqlConnection owningObject, withFailover typu Boolean)
w system.Data.SqlClient.sqlinternalconnectiontds.loginnofailoverstring (ServerInfo serverInfo, NoweHasło ciąg, Boolean redirectedUserInstance, SqlConnection owningObject, SqlConnectionString connectionOptions, limit czasu TimeoutTimer)
w system.Data.SqlClient.sqlinternalconnectiontds.openloginenlistsqlconnection (SqlConnection owningObject, TimeoutTimer limit czasu, SqlConnectionString connectionOptions, NoweHasło ciąg, redirectedUserInstance typu Boolean)
w System.Data.SqlClient.SqlInternalConnectionTds... Konstruktor (identyczność, SqlConnectionString connectionOptions, sprzeciwiać się providerInfo, NoweHasło ciąg, SqlConnection owningObject, redirectedUserInstance typu Boolean)
Uwaga Jeśli możesz zwiększyć limit czasu logowania do 30 sekund, aplikacja kliencka ma około 20 sekund do pomyślnego ustanowienia połączenia.
Te symptomy występują, gdy spełnione są następujące warunki:
-
Grupy dostępności jest zdefiniowany w wielu podsieci.
-
Po podłączeniu określono parametru MultiSubnetFailover .
-
Masz sterownik filtru Driver Interface (TDI) dla aktywnego transportu zainstalowanego na aplikacji klienckiej stacji roboczej.
Przyczyna
Ten problem występuje, ponieważ sterownik Tdx.sys nie obsługuje funkcji Closesocket() poprawnie podczas wywołania funkcji w środku uzgadniania protokołu TCP/IP.
Rozwiązanie
Informacje o poprawce
Obsługiwana poprawka jest udostępniana przez firmę Microsoft. Jednak ta poprawka jest przeznaczona tylko do usunięcia problemu opisanego w tym artykule. Zastosuj poprawkę tylko w systemach, w których występuje problem opisany w tym artykule. Ta poprawka może być wciąż w fazie testowania. Jeśli dany system nie jest poważnie narażony na ten problem, firma Microsoft zaleca, aby poczekać na następną aktualizację oprogramowania zawierającą tę poprawkę.
Jeśli poprawka jest dostępna do pobrania, pojawi się sekcja "Poprawka dostępna do pobrania" na początku tego artykułu z bazy wiedzy Knowledge Base. Jeśli nie ma tej sekcji, skontaktuj się z Obsługą i Wsparciem Klienta Microsoft w celu uzyskania poprawki.
Uwaga Jeśli wystąpią dodatkowe błędy lub konieczność rozwiązania problemu, być może trzeba będzie utworzyć osobne zlecenie usługi. Zwykłe koszty obsługi będą zastosowane do dodatkowych pytań i problemów, których nie można rozwiązać przy użyciu określonej poprawki. Aby uzyskać pełną listę numerów telefonów działu obsługi klienta firmy Microsoft lub utworzyć osobne zlecenie usługi odwiedź następujące witryny firmy Microsoft:
http://support.microsoft.com/contactus/?ws=supportUwaga "Poprawka dostępna do pobrania" zawiera listę języków, dla których dostępna jest poprawka. Jeśli odpowiedni język nie jest widoczny, to dlatego, że poprawka nie jest dostępna dla danego języka.
Wymagania wstępne
Aby zastosować tę poprawkę, musisz korzystać z systemu Windows 7 z dodatkiem SP1 lub Windows Server 2008 R2 z dodatkiem SP1.
Aby uzyskać więcej informacji dotyczących sposobu uzyskiwania dodatku service pack dla systemu Windows 7 lub Windows Server 2008 R2, kliknij następujący numer artykułu w celu wyświetlenia tego artykułu z bazy wiedzy Microsoft Knowledge Base:
976932 Informacje o dodatku Service Pack 1 dla systemu Windows 7 i Windows Server 2008 R2
Informacje dotyczące rejestru
Aby zastosować tę poprawkę, nie trzeba wprowadzać żadnych zmian w rejestrze.
Wymagania dotyczące ponownego uruchomienia
Po zastosowaniu tej poprawki należy ponownie uruchomić komputer.
Informacje dotyczące zastępowania poprawek
Ta poprawka nie zastępuje wcześniej wydanej poprawki.
Wersja globalna tej poprawki instaluje pliki, których atrybuty wymieniono w poniższych tabelach. Daty i godziny odpowiadające tym plikom są podane w formacie uniwersalnego czasu koordynowanego (UTC, Coordinated Universal Time). Daty i godziny odpowiadające tym plikom na komputerze lokalnym są wyświetlane w formacie czasu lokalnego, wraz z Twoim bieżącym bias czasu letniego (DST). Dodatkowo, daty mogą ulec zmianie podczas wykonywania pewnych operacji na plikach.
Informacje o plikach w systemie Windows 7 i Windows Server 2008 R2
Ważne Poprawki systemu Windows 7 i Windows Server 2008 R2 są zawarte w tych samych opakowaniach. Jednak poprawki na stronie żądanie poprawki są wymienione w obu systemach operacyjnych. Aby zażądać pakietu poprawek, który dotyczy jednej lub obu systemów operacyjnych, wybierz poprawkę, która jest wyświetlana w obszarze "Windows 7/Windows Server 2008 R2" na stronie. Zawsze sprawdzaj w sekcji „Stosuje się do”, do jakiego systemu operacyjnego dotyczy każda z poprawek.
-
Pliki, które dotyczą określonego produktu, poziomu SR (RTM, SPn) i składnika usługi (LDR, GDR) można zidentyfikować przez sprawdzenie wersji pliku, jak pokazano w poniższej tabeli:
Wersja
Produkt
Kamień milowy
Składnik usługi
6.1.760
1,22 xxxWindows 7 i Windows Server 2008 R2
SP1
LDR
-
Pliki MANIFESTU (.manifest) i pliki MUM (.mum) zainstalowane dla każdego środowiska są wymienione osobno w sekcji „Informacje o dodatkowych plikach dla systemu Windows 7 i Windows Server 2008 R2”. Pliki MUM i pliki MANIFESTU oraz skojarzone zabezpieczeń pliki wykazu (.cat), są bardzo ważne dla utrzymania stanu zaktualizowanego składnika. Pliki katalogu zabezpieczeń, których atrybuty nie zostały wymienione, są podpisane za pomocą podpisu cyfrowego firmy Microsoft.
Wszystkie obsługiwane wersje systemu Windows 7 x86
Nazwa pliku |
Tdx.sys |
Wersja pliku |
6.1.7601.22382 |
Rozmiar pliku |
74,752 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
09:17 |
Platforma |
x86 |
Dla wszystkich obsługiwanych wersji systemu Windows 7 i Windows Server 2008 R2 z procesorami x64
Nazwa pliku |
Tdx.sys |
Wersja pliku |
6.1.7601.22382 |
Rozmiar pliku |
118,272 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
09:35 |
Platforma |
x64 |
Dla wszystkich obsługiwanych wersji systemu Windows Server 2008 R2 z procesorami IA-64
Nazwa pliku |
Tdx.sys |
Wersja pliku |
6.1.7601.22382 |
Rozmiar pliku |
236,544 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
09:03 |
Platforma |
IA-64 |
Obejście problemu
Aby obejść ten problem, użyj jednej z następujących metod:
-
Zwiększ limit czasu logowania aplikacji do 30 sekund.
-
Funkcja TDI została zaniechana w systemie Windows Vista, Windows Server 2008 lub nowszej wersji systemu Windows. Zamiast tego można użyć opartych na platformie filtrowania systemu Windows WFP sterowniki. Skontaktuj się z dostawcą zainstalowany sterownik filtru TDI na żądanie informacji o aktualizacje produktu, które implementują nowej platformy filtrowania systemu Windows. Uaktualnienie produktu, jeśli jest to możliwe.
-
Zamień TDI za pomocą porównywalnych produktu, w której postanowiono zaimplementować platformy filtrowania systemu Windows.
-
Ustaw właściwość RegisterAllProvidersIP na wartość 0 dla odbiornika zasobu grupy dostępności klastra systemu Windows. Gdy właściwość RegisterAllProvidersIP jest ustawiona na 0, nie trzeba określać parametru MultiSubnetFailover . Aby uzyskać więcej informacji o tym obejściu przejdź do następującej witryny sieci Web MSDN:
Tworzenie lub konfigurowanie detektor grupy dostępności (SQL Server)
Stan
Firma Microsoft potwierdziła, że jest to problem występujący w produktach firmy Microsoft wymienionych w sekcji „Dotyczy”.
Więcej informacji
Aby uzyskać więcej informacji dotyczących terminologii aktualizacji oprogramowania, kliknij następujący numer artykułu w celu wyświetlenia tego artykułu z bazy wiedzy Microsoft Knowledge Base:
824684 Opis standardowej terminologii używanej do opisywania aktualizacji oprogramowania firmy Microsoft
Produkty innych firm omówione w tym artykule są wytwarzane przez producentów niezależnych od firmy Microsoft. Firma Microsoft nie udziela żadnych gwarancji, domniemanych ani żadnego innego rodzaju, odnośnie do wydajności lub niezawodności tych produktów.
Informacje o dodatkowych plikach dla systemu Windows 7 i Windows Server 2008 R2
Dodatkowe pliki dla wszystkich obsługiwanych wersji systemu Windows 7 z procesorami x86
Nazwa pliku |
X86_2c94e745aaec3431931d51020305e2b9_31bf3856ad364e35_6.1.7601.22382_none_6fcc2f6025233efa.manifest |
Wersja pliku |
Nie dotyczy |
Rozmiar pliku |
702 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
17:26 |
Platforma |
Nie dotyczy |
Nazwa pliku |
X86_microsoft-windows-tdi-over-tcpip_31bf3856ad364e35_6.1.7601.22382_none_ec81028053b014a1.manifest |
Wersja pliku |
Nie dotyczy |
Rozmiar pliku |
2,924 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
11:37 |
Platforma |
Nie dotyczy |
Dodatkowe pliki dla wszystkich obsługiwanych wersji systemu Windows 7 i Windows Server 2008 R2 z procesorami x 64
Nazwa pliku |
Amd64_fe6f131c914351fbcf6c3bc973329866_31bf3856ad364e35_6.1.7601.22382_none_a8b3dc126d52c78a.manifest |
Wersja pliku |
Nie dotyczy |
Rozmiar pliku |
706 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
17:26 |
Platforma |
Nie dotyczy |
Nazwa pliku |
Amd64_microsoft-windows-tdi-over-tcpip_31bf3856ad364e35_6.1.7601.22382_none_489f9e040c0d85d7.manifest |
Wersja pliku |
Nie dotyczy |
Rozmiar pliku |
2,926 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
12:33 |
Platforma |
Nie dotyczy |
Dodatkowe pliki dla wszystkich obsługiwanych wersji systemu Windows Server 2008 R2 z procesorami IA-64
Nazwa pliku |
Ia64_649247023b89e8d48b1a96bffe9b85cd_31bf3856ad364e35_6.1.7601.22382_none_a9a13e5e5a562b37.manifest |
Wersja pliku |
Nie dotyczy |
Rozmiar pliku |
704 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
17:26 |
Platforma |
Nie dotyczy |
Nazwa pliku |
Ia64_microsoft-windows-tdi-over-tcpip_31bf3856ad364e35_6.1.7601.22382_none_ec82a67653ae1d9d.manifest |
Wersja pliku |
Nie dotyczy |
Rozmiar pliku |
2 925 |
Data (UTC) |
12-Jul-2013 |
Godzina (UTC) |
11:35 |
Platforma |
Nie dotyczy |