SqlClient hangs while executing stored procedure on SQL DB with Always Encrypted #3176
Labels
🐛 Bug!
Issues that are bugs in the drivers we maintain.
✔️ Triage Done
Issues that are triaged by dev team and are in investigation.
Describe the bug
Application remains pending while executing ExecuteReader() or other commands upon an encrypted column. The issue can only be reproduced after several hours (usually we wait 24 hours but maybe less are needed) in which the application does not access the encrypted columns. This suggests a session problem.
Once the problem occurs each subsequent call remains pending, the only solution is to restart the microservice.
Adding a probe solves the problem but it is not possible to apply probes to all our microservices.
To reproduce
Below is the piece of code where the service hangs:
We use key vault as a key store provider.
The method used to register the key store provider is as follows:
The microservice is released on azure kubernetes service.
Expected behavior
The sdk should throw an exception or execute the command but not hang
Further technical details
.NET target: .NET 8
sdk references:
Microsoft.Data.SqlClient v5.2.1
Microsoft.Data.SqlClient.AlwaysEncrypted.AzureKeyVaultProvider v5.1.0
Microsoft.EntityFrameworkCore.SqlServer v8.0.6
Microsoft.EntityFrameworkCore v8.0.6
SQL DB references:
SQL Server version: Azure SQL Database, DC-series hardware, Always Encrypted with SGX secure enclaves
Additional context
data:image/s3,"s3://crabby-images/aa3e0/aa3e0c5310281297de22dc1d0873edae40219341" alt="Image"
the last log we see when the issue occur is this one:
From the logs we see that for each call that remains pending we find a call to the stored procedure ‘sp_describe_paramener_encryption’ but then the actual SP is not executed.
data:image/s3,"s3://crabby-images/2331e/2331ec8ea49ff24c67901cc363d085bd695ab120" alt="Image"
Together with the Microsoft support team, we have established that the issue is not related to azure services but to the sdk
The text was updated successfully, but these errors were encountered: