In this article, we’ll explain How to trace and solve the “Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment” error
Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment. This could be because the pre-login handshake failed or the server was unable to respond back in time.
data:image/s3,"s3://crabby-images/a969e/a969ea6c3e673e12245472a430e90b17c8ea6169" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment"
We will also concentrate on solving “Connection Timeout Expired pre-login handshake SQL Server” error by checking the following:
- 1 Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake
- 2 Why I get “Connection Timeout Expired pre-login handshake SQL Server”?
-
3
How to solve “Connection Timeout Expired pre-login handshake SQL Server”?
- 3.1 An instance of the SQL Server Database Engine is not running
- 3.2 The SQL Server Browser service is not running
- 3.3 TCP/IP is disabled
- 3.4 The server name was typed incorrectly
- 3.5 Check Network Connectivity
- 3.6 Use UDL file to test the SQL Server instance accessibility
- 3.7 Check If TCP/IP port for the Database Engine instance is blocked by Firewall
- 3.8 Client and Server are not configured to use the same network protocol
Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake
I have an ASP.Net website that connects to SQL server always-on failover cluster instance.
When I configured the Connection String inside Web.Config as SQL Authentication, the connection has been connected successfully.
Server=load balancer IP;Database=Database Name;User Id=User; Password=Password;
But when I tried to configure the Connection String as Windows Authentication.
Server=load balancer IP;Database=Database Name;Integrated Security =true;
I got the below error.
Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment.
This could be because the pre-login handshake failed or the server was unable to respond back in time.
By the way,
- The application pool service account has elevated privilege with SQL Server as
- The public server role and the user is mapping the correct database.
But unfortunately, I’m still getting “Connection Timeout Expired pre-login handshake SQL Server” error!
data:image/s3,"s3://crabby-images/a969e/a969ea6c3e673e12245472a430e90b17c8ea6169" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Connection Timeout Expired pre-login handshake SQL Server"
Why I get “Connection Timeout Expired pre-login handshake SQL Server”?
The “Connection Timeout Expired pre-login handshake SQL Server” error commonly occurs in the following cases:
- An instance of the SQL Server Database Engine is not running.
- The SQL Server Browser service is not running.
- The TCP/IP is disabled.
- The server name was typed incorrectly.
- There are network problems.
- The TCP/IP port for the Database Engine instance is blocked by a firewall.
- The client and server are not configured to use the same network protocol.
How to solve “Connection Timeout Expired pre-login handshake SQL Server”?
In this section, we’re gonna explain the above root causes of “Connection Timeout Expired pre-login handshake SQL Server” in more details.
An instance of the SQL Server Database Engine is not running
On each node, you should ensure that each SQL Server Database Engine is started and running properly by doing the following:
- Open SQL Server Configuration Manager.
data:image/s3,"s3://crabby-images/be61c/be61c69ec3d1e9ec0df5c714c6fee3ee1a862830" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Open SQL Server Configuration Manager"
- Make Sure that the SQL Server Services state is running.
- In case, it is not running try to start it.
- In case. it’s not started! Please, check SQL Server Service was unable to start.
data:image/s3,"s3://crabby-images/4442a/4442a4f014ba900ccb69f1814238fb5f6255b009" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Check SQL Server Services state is running"
The SQL Server Browser service is not running
- Again, Open SQL Server Configuration Manager.
data:image/s3,"s3://crabby-images/be61c/be61c69ec3d1e9ec0df5c714c6fee3ee1a862830" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Open SQL Server Configuration Manager"
- Make sure that The SQL Server Browser service is running.
data:image/s3,"s3://crabby-images/273fb/273fb4f73dab9de6ee0c95566dddb5f2f67cd815" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment SQL Server Browser"
TCP/IP is disabled
- Again, Open SQL Server Configuration Manager.
data:image/s3,"s3://crabby-images/be61c/be61c69ec3d1e9ec0df5c714c6fee3ee1a862830" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Open SQL Server Configuration Manager"
- From right side, Navigate to SQL Server Configuration Network.
- Make sure that TCP/IP is enabled.
data:image/s3,"s3://crabby-images/dddcf/dddcf49f753f9fdc32d354a12b660baf19092498" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment SQL Server Network Configuration - enable TCP/IP"
The server name was typed incorrectly
In my case, the problem was in the server name where I have used the Load Balancer IP that should be the SQL Alias name when using Windows Authentication. so that the connection string should be like this
Server=SQL Alias Name;Database=Database Name;Integrated Security =true
Get SQL Alias Name in Windows Server
Steps
- Run Command Prompt as Administrator.
data:image/s3,"s3://crabby-images/f8d57/f8d57dd41f7823c6d643cb993f4c6aba6381bba1" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Open Command Prompt as Administrator"
- Run the following Command.
CLICONFG.EXE
- The following Dialog should be shown > Click on Alias tab > Get the Server Alias.
data:image/s3,"s3://crabby-images/a0e31/a0e31247c5a623f5f7b6c33e665cbdc0a516c8f3" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Get SQL Alias Name in Windows Server"
In the end, you should make sure that you have provided the correct SQL Server name or (SQL Alias) to avoid this issue.
Check Network Connectivity
Of course, you will get “Connection Timeout Expired pre-login handshake SQL Server” if there is any issue related to network settings.
- At the Application server, try to open the CMD as Administrator.
data:image/s3,"s3://crabby-images/f8d57/f8d57dd41f7823c6d643cb993f4c6aba6381bba1" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Open Command Prompt as Administrator"
- Perform telnet cmdlet with the TCP/IP port (The default port is 1433) to make sure the port is opened and reachable.
telnet SQL Server Virtual IP Opened Port
Note: if the telnet command is not recognized, you should install the telnet feature as mentioned at ‘telnet’ is not recognized as an internal or external command, operable program or batch file.
- Again, perform a “Ping” command with the Database Server IP for each node and for SQL VIP to ensure that the application server can reach the database server and vice versa.
ping VIP
data:image/s3,"s3://crabby-images/fa17b/fa17b0302bd4f285f4b8d7b9e0c22d72ec6109cb" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Check if the SQL Server is reachable"
You might also like to check the detail steps at How to Check SQL Server Instance Connectivity from the application server to database server for a specific user
Use UDL file to test the SQL Server instance accessibility
It doesn’t mean you can reach the database server, you have access to the SQL server instance! So:
- Try to login with The application pool account that runs the website on the IIS to the application server.
- Then try to create a UDL file as mentioned at check SQL server instance connectivity from the application server to the database server.
data:image/s3,"s3://crabby-images/7dbf4/7dbf48a403c6f0032b47c7a2e87c21dc5ce0f9ea" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Check the port accessibility of the SQL Server instance"
Check If TCP/IP port for the Database Engine instance is blocked by Firewall
The default port for TCP/IP is 1433. so that you should make sure that The Database Engine is listening on the assigned TCP/IP port that is by default 1433.
Get SQL Server TCP/IP port number
Get SQL Server TCP/IP port number using SQL Management Studio
- Open SQL Server Configuration Wizard.
- Navigate to SQL Server Network Configuration.
- Right click on TCP/IP > Properties > IP Address.
- Scroll down to IPALL > Check TCP Port.
data:image/s3,"s3://crabby-images/25dd7/25dd7b90a235c5adb80082af168663f358ad54e8" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Get SQL Server TCP/IP port number"
Get SQL Server TCP/IP port number using T-SQL
- Open SQL Server Management Studio.
data:image/s3,"s3://crabby-images/f6dee/f6dee326753119a7090fd501ec9f2ddeb7fb6962" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Connect to SQL Server"
- Use Master Database > Click on New Query.
- Run the following Query.
SELECT DISTINCT local_tcp_portFROM sys.dm_exec_connections WHERE local_tcp_port IS NOT NULL
- The output should be retrieved as shown below.
data:image/s3,"s3://crabby-images/2f100/2f100f02969a63adc0736ce9dece07fdbe3ddcbf" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Get SQL Server TCP/IP port number using T-SQL"
- Try now to perform telnet the SQL Server VIP and its TCP/IP port.
data:image/s3,"s3://crabby-images/f3aee/f3aeef09c5ebee0f2931abd64492b0ba7e4039d6" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Perform telnet between app server and DB server"
Note: if the telnet command is not recognized, you should install the telnet feature as mentioned at ‘telnet’ is not recognized as an internal or external command, operable program or batch file.
- If the port is not blocked, you should get the below result.
data:image/s3,"s3://crabby-images/353e2/353e2dfe3d2677157c15e26b1e3503af19e2d93e" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Telnet is connected between app server and DB server"
- Otherwise, you will get the below message that means the port is blocked.
data:image/s3,"s3://crabby-images/1e89e/1e89e1e4b56d379bb205d225eaf6641a2cd239ba" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment telnet could not open connection between app server and DB server"
In this case, you must make sure that the SQL Server TCP/IP port is allowed by
- Firewall.
- Antivirus.
Allow SQL Server TCP/IP Port in Firewall
- In database Server > Open Windows Firewall.
data:image/s3,"s3://crabby-images/b2901/b2901da15ee9f30fd15271db693d3de38ebcdd26" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Configure SQL Server port in firewall"
- From right side > Select Inbound Rules.
- Right click on Inbound Rules > Select New Inbound Rule.
data:image/s3,"s3://crabby-images/660d0/660d0cbcab0a9da614d60abdbf1d22f9b052030e" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Allow SQL Server TCP/IP Port in Firewall"
- In Rule Type Step > Check Port.
data:image/s3,"s3://crabby-images/ba4e0/ba4e0a0aa44f81340aab53b3ed3d739ffd35f558" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment New Inbound rule for SQL Server Port in firewall"
- On Protocol and Port Step > Select TCP, Special Local Ports > Type the SQL Port.
data:image/s3,"s3://crabby-images/3ce8c/3ce8c41ba95c00c1d95aa3bf0a89cd8f72d73a81" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment New Inbound rule for SQL Server TCP Port in firewall"
Note: if you have an antivirus engine running on your server, so you should also make sure that the port is allowed.
Client and Server are not configured to use the same network protocol
- Open Network and sharing center on SQL Server.
data:image/s3,"s3://crabby-images/ecb0a/ecb0ab3df99ef0b0a8d56ba850cb0b22460bad26" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Network and Sharing Center"
- Change Adapter Settings.
data:image/s3,"s3://crabby-images/c2c16/c2c16d28337149f58b502e4ca4391a559f5c5f75" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Change Adapter Settings"
- Right Click on Ethernet > Properties.
data:image/s3,"s3://crabby-images/836f1/836f10ed923f793e46c9648fc2d5a1ff23b24403" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Ethernet Properties"
- If IPv6 has been checked, so It should be checked on the application server.
- If IPv6 has not been checked, so It should be unchecked on the application server.
data:image/s3,"s3://crabby-images/89e1c/89e1c1591f91af28e0ad7821bbff4af3716571ef" alt="Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment Ethernet Properties Internet Protocol Version 6"
Conclusion
In this article, we have tried to explain the common root causes for “Connection Timeout Expired. The timeout period elapsed while attempting to consume the pre-login handshake acknowledgment. This could be because the pre-login handshake failed or the server was unable to respond back in time” and providing the proposed solutions for each root cause in details.
Applies To
- SQL Server 2017.
- SQL Server 2014.
- SQL Server 2012.
You might also like to read
- SQL Server Best Practices for SharePoint 2019.
- How to Check SQL Server Instance Connectivity without using SQL Server Management Studio.
- ‘telnet’ is not recognized as an internal or external command, operable program or batch file.
- SQL Server Service was unable to start.
Have a Question?
If you have any related questions, please don’t hesitate to ask it at deBUG.to Community.
Hi I am so glad I found your site, I really found you by error, while I was looking on Bing for something else, Regardless I am here now and would just like to say many thanks for a remarkable post and a all round interesting blog (I also love the theme/design), I don’t have time to browse it all at the minute but I have bookmarked it and also added your RSS feeds, so when I have time I will be back to read a great deal more, Please do keep up the excellent work.
Thank you so much for your kind feedback ♥
Hi there, of course this article is truly good and I have learned lot of things from it on the topic of blogging. thanks.
Glad to hear it helped you 🙂
Thanks designed for sharing such a nice opinion, article is pleasant, thats why i have read it entirely
Welcome 🙂 thanks for your feedback!
Thank you for helping out, good info.
You’re welcome 🙂
Really wonderful visual appeal on this internet site, I’d rate it 10.
Thanks!