首页 > 解决方案 > 无法在 docker 容器内连接 SQLServer

问题描述

我正在创建一个容器,它有一个 .net 核心应用程序,基于官方的 microsoft 图像。

当应用程序尝试连接到 SQL 服务器时,我收到以下错误,它只发生在容器内:与服务器成功建立连接,但在登录前握手期间发生错误。(提供者:SSL 提供者,错误:31 - 加密(ssl/tls)握手失败)

我的应用程序使用以下包与 sqlserver 通信:

我的连接字符串如下所示:

Data Source=xxx.xxx.xxx.xxx;Initial Catalog=XXXXXXXX;User ID=XXXXX;Password=XXXX;MultipleActiveResultSets=True;Connect Timeout=60;TrustServerCertificate=true

我的 docker 版本是当时可用的最新版本:“Docker 版本 20.10.2,构建 2291f61”正在 Windows 上运行,这就是我创建 docher 映像的方式:

FROM mcr.microsoft.com/dotnet/sdk:3.1 AS build-env
WORKDIR /prj

COPY . .
RUN dotnet publish myapp.csproj -o /app 

FROM mcr.microsoft.com/dotnet/aspnet:3.1
WORKDIR /app

RUN update-ca-certificates --fresh

COPY --from=build-env /app .
ENTRYPOINT ["dotnet", "myapp.dll"]

我已经在谷歌上搜索了一段时间,但没有找到适合我的解决方案,有人可以帮忙吗?

标签: sql-serverdocker.net-core

解决方案


此错误通常发生在 docker 镜像容器、Unix 客户端或 Windows 客户端等客户端环境中,其中 TLS 1.2 是支持的最低 TLS 协议。

在 docker 镜像/客户端环境中配置 TLS/SSL 设置以连接 TLS 1.0。

MinProtocol = TLSv1 
CipherString = DEFAULT@SECLEVEL=1

推荐阅读