Linux 上的 SQL Server:已知问题

以下部分介绍了 Linux 上 SQL Server 的已知问题。

常规

下表列出了 Linux 上的 SQL Server 最常见的问题。

问题 解决方案
安装 SQL Server 的主机名的长度不能超过 15 个字符。 将名称 /etc/hostname 更改为长度等于或小于 15 个字符的值。
手动向后设置系统时间会导致 SQL Server 停止更新数据库引擎中的内部系统时间。 请重新启动 SQL Server。
仅支持单个实例安装。 如果希望在给定主机上安装多个实例,请考虑使用虚拟机Linux 容器
SQL Server Configuration Manager 无法连接到 Linux 上的 SQL Server。 无。
sa 登录名的默认语言是英语。 使用 ALTER LOGIN 语句更改 sa 登录名的语言。
OLE DB 提供程序记录以下警告:

Failed to verify the Authenticode signature of 'C:\binn\msoledbsql.dll'. Signature verification of SQL Server DLLs will be skipped. Genuine copies of SQL Server are signed. Failure to verify the Authenticode signature might indicate that this isn't an authentic release of SQL Server. Install a genuine copy of SQL Server or contact customer support.
无需执行任何操作。 OLE DB 提供程序使用 SHA256 进行签名。 SQL Server 数据库引擎无法正确验证签名的 .dll。
使用 mssql-conf 的重置密码命令引发以下错误:

Unable to set the system administrator password. Please consult the ERRORLOG in /path for more information.
错误消息为误报。 密码重置成功,可以继续使用新密码。

仅适用于: SQL Server 2022 (16.x) 容器映像。

数据库

  • 不能使用 mssql-conf 实用工具移动 master 数据库。 可使用 mssql-conf 移动其他系统数据库。

  • 还原在 Windows 上 SQL Server 中备份的数据库时,必须在 Transact-SQL 语句中使用 WITH MOVE 子句。 有关更多信息,请参阅使用备份和还原将 SQL Server 数据库从 Windows 迁移到 Linux

  • 传输层安全性 (TLS) 的某些算法(密码套件)无法在 Linux 上的 SQL Server 中正常运行。 这会在尝试连接到 SQL Server 时导致连接失败,以及在高可用性组中的副本之间建立连接时出现问题。

    若要解决此问题,请通过执行以下步骤,修改 Linux 上的 SQL Server 的 mssql.conf 配置脚本以禁用有问题的密码套件:

    1. 将以下部分添加至 /var/opt/mssql/mssql.conf。 感叹号 (!) 否定表达式。 这向 OpenSSL 指明不使用后面的密码套件。

      [network]
      tlsciphers=AES256-GCM-SHA384:AES128-GCM-SHA256:AES256-SHA256:AES128-SHA256:AES256-SHA:AES128-SHA:!ECDHE-RSA-AES128-GCM-SHA256:!ECDHE-RSA-AES256-GCM-SHA384:!ECDHE-ECDSA-AES256-GCM-SHA384:!ECDHE-ECDSA-AES128-GCM-SHA256:!ECDHE-ECDSA-AES256-SHA384:!ECDHE-ECDSA-AES128-SHA256:!ECDHE-ECDSA-AES256-SHA:!ECDHE-ECDSA-AES128-SHA:!ECDHE-RSA-AES256-SHA384:!ECDHE-RSA-AES128-SHA256:!ECDHE-RSA-AES256-SHA:!ECDHE-RSA-AES128-SHA:!DHE-RSA-AES256-GCM-SHA384:!DHE-RSA-AES128-GCM-SHA256:!DHE-RSA-AES256-SHA:!DHE-RSA-AES128-SHA:!DHE-DSS-AES256-SHA256:!DHE-DSS-AES128-SHA256:!DHE-DSS-AES256-SHA:!DHE-DSS-AES128-SHA:!DHE-DSS-DES-CBC3-SHA:!NULL-SHA256:!NULL-SHA
      
    2. 使用以下命令重启 SQL Server。

      sudo systemctl restart mssql-server
      
  • Windows 上使用内存中 OLTP 的 SQL Server 2014 (12.x) 数据库无法还原到 Linux 上的 SQL Server。 如果 SQL Server 2014 (12.x) 数据库使用内存中 OLTP,请首先将数据库升级到 Windows 上较新版本的 SQL Server。 然后,可以通过备份/还原或分离/附加将其移动到 Linux 上的 SQL Server。

  • 目前 Linux 不支持用户权限 ADMINISTER BULK OPERATIONS

  • 使用 SQL Server 2019 (15.x) CU 16 及更高版本创建的 TDE 压缩备份无法还原到 SQL Server 2019 (15.x) 的早期 CU 版本。 有关详细信息,请参阅修复:执行 RESTORE LOG 或 RESTORE DATABASE 期间发生错误 3241

    使用 SQL Server 2019 (15.x) 的早期 CU 版本创建的透明数据加密 (TDE) 压缩备份仍可以使用 SQL Server 2019 (15.x) CU 16 及更高版本进行还原。

  • 在 Ubuntu 22.04 上安装 SQL Server 2022 (16.x) 时,可能会看到以下错误消息:Failed to start Microsoft SQL Server Database Engine。 如果查看错误日志,你会看到系统数据库的路径不正确。

    要解决此问题,请在单用户模式下启动实例,并使用 ALTER DATABASE ... MODIFY FILE 将系统数据库的已配置位置移动至默认位置 /var/opt/mssql/data。 进行此更改后,重启服务。

网络

如果满足以下两个条件,则涉及来自 sqlservr 进程的出站 TCP 连接(如链接服务器、PolyBase 或可用性组)的功能可能不起作用:

  • 目标服务器被指定为主机名而不是 IP 地址。

  • 源实例已在内核中禁用 IPv6。 要验证系统是否在内核中启用了 IPv6,以下所有测试都必须通过:

    • cat /proc/cmdline 将打印当前内核的引导 cmdline。 输出不得包含 ipv6.disable=1
    • /proc/sys/net/ipv6/ 目录必须存在。
    • 调用 socket(AF_INET6, SOCK_STREAM, IPPROTO_IP) 的 C 程序应成功,即系统调用必须返回一个 fd != -1 并且不会因 EAFNOSUPPORT 而失败。

确切的错误取决于该功能。 对于链接服务器,你会看到登录超时错误。 对于可用性组,辅助节点上的 ALTER AVAILABILITY GROUP JOIN DDL 将在 5 分钟后因 download configuration timeout 错误而失败。

若要解决此问题,请使用下列选项之一:

  • 使用 IP 而不是主机名来指定 TCP 连接的目标。

  • 从引导命令行中删除 ipv6.disable=1,在内核中启用 IPv6。 方法取决于 Linux 发行版和引导加载程序,例如“grub”。 如果希望禁用 IPv6,仍可通过在 sysctl 配置中设置 net.ipv6.conf.all.disable_ipv6 = 1 来禁用它(例如 /etc/sysctl.conf)。 尽管此设置会阻止系统的网络适配器获取 IPv6 地址,但允许 sqlservr 功能运行。

不支持 TLS 1.3

适用于:仅限 SQL Server 2022 (16.x)。

尽管适用于 Windows 的 SQL Server 2022 (16.x) 支持 TLS 1.3,但在 Linux 上必须使用 TLS 1.2。

网络文件系统 (NFS)

如果在生产中使用网络文件系统 (NFS) 远程共享,请注意以下支持要求:

  • 使用 NFS 版本 4.2 或更高版本。 较早版本的 NFS 不支持现代文件系统常用的必需功能,例如 fallocate 和稀疏文件创建。

  • 仅在 NFS 装载上查找 /var/opt/mssql 目录。 不支持其他文件,例如 SQL Server 系统二进制文件。

  • 安装远程共享时,请确保 NFS 客户端使用 nolock 选项。

本地化

  • 如果在安装过程中区域设置不是英语 (en_us),则必须在 bash 会话/终端中使用 UTF-8 编码。 如果使用 ASCII 编码,可能会看到类似于以下输出的错误:

    UnicodeEncodeError: 'ascii' 编解码器无法在位置 8 中对字符 u'\xf1' 进行编码:序号不在范围 (128)

    如果无法使用 UTF-8 编码,请使用 MSSQL_LCID 环境变量运行安装程序以指定语言选择。

    sudo MSSQL_LCID=<LcidValue> /opt/mssql/bin/mssql-conf setup
    
  • 运行 mssql-conf setup 并执行 SQL Server 的非英语安装时,在本地化文本“配置 SQL Server...”之后可能会显示错误的扩展字符。 或者,对于非拉丁语的安装,句子可能完全丢失。 丢失的句子应显示以下本地化字符串:

    已成功处理授权 PID。 新版本为[<名称>版本]。

    此字符串的输出仅供参考,不会以任何方式影响 SQL Server 的成功安装。

并非所有筛选器都适用于此版本,包括 Microsoft Office 文档筛选器。 有关支持的筛选器列表,请参阅在 Linux 上安装 SQL Server 全文搜索

SQL Server Integration Services (SSIS)

mssql-server-is 包在 SUSE Linux Enterprise Server (SLES) 上不受支持。 该软件包在 Ubuntu 和 Red Hat Enterprise Linux (RHEL) 上均受支持。

Integration Services 包可使用 Linux 上的 ODBC 连接。 虽然已使用 SQL Server 和 MySQL ODBC 驱动程序测试过该功能,但也希望该功能可以与任何遵循 ODBC 规范的 Unicode ODBC 驱动程序搭配使用。 在设计阶段,可以提供 DSN 或连接字符串以连接到 ODBC 数据,还可以使用 Windows 身份验证。 有关详细信息,请参阅宣布 Linux 上的 ODBC 支持的博客文章

在 Linux 上运行 SSIS 包时,此版本不支持以下功能:

  • Integration Services 目录数据库
  • SQL Server 代理计划的包执行
  • Windows 身份验证
  • 第三方组件
  • 变更数据捕获 (CDC)
  • Integration Services 横向扩展
  • 适用于 SSIS 的 Azure 功能包
  • Hadoop 和 HDFS 支持
  • Microsoft Connector for SAP BW

有关当前不受支持或提供有限支持的内置 SSIS 组件的列表,请参阅 Linux 上的 SSIS 的限制和已知问题

有关 Linux 上的 SSIS 的详细信息,请参阅以下文章:

SQL Server Management Studio (SSMS)

以下限制适用于 Windows 中连接到 Linux 上 SQL Server 的 SQL Server Management Studio。

  • 不支持维护计划。

  • 不支持管理数据仓库 (MDW) 和 SQL Server Management Studio 中的数据收集器。

  • 具有 Windows 身份验证或 Windows 事件日志选项的 SQL Server Management Studio UI 组件不适用于 Linux。 仍可通过其他选项(如 SQL Server 登录)使用这些功能。

  • 不能修改要保留的日志文件数。

高可用性和灾难恢复

适用于:仅限 SQL Server 2022 (16.x)。

对于 RHEL 9 和 Ubuntu 22.04 的 SQL Server 2022 (16.x) 包,在使用 Pacemaker 启用 HA/DR 堆栈时,可能会遇到自动和手动故障转移的问题。 这些问题当前仅限于 Pacemaker HA 堆栈。 其他 HA 堆栈(包括 HPE Serviceguard 和 DH2i DxEnterprise)不存在这些问题。

可用性组持续切换主角色

在 RHEL 8、Ubuntu 20.04 及更高版本中使用 SQL Server 2022(16.x)中的可用性组(AG)时,可能会遇到 AG 中的主要角色从一个节点持续切换到另一个节点的情况。 当前,可以通过以下步骤解决此问题:

  1. 若要将 ag_cluster 资源属性 failure-timeout 更新为 0s,请执行:

    pcs resource update ag_cluster meta failure-timeout=0s
    

    有关详细信息,请参阅为 SQL Server 可用性组配置 Pacemaker 群集

  2. 重置 Pacemaker 群集上的失败计数:

    crm_failcount -r ag_resource_name -delete
    

机器学习服务

适用于:仅限 SQL Server 2022 (16.x)。

对于 RHEL 9 和 Ubuntu 22.04 的 SQL Server 2022 (16.x) 包,在安装机器学习服务之前,cgroup-v1 需要考虑一些先决条件。

  1. 作为先决条件,需要按照 Red Hat 的使用 cgroupfs 手动管理 cgroups Red Hat Enterprise Linux 9 启用 cgroup-v1

  2. 然后按照说明安装 SQL 机器学习服务,如前所述。

  3. 禁用网络命名空间隔离。

    sudo /opt/mssql/bin/mssql-conf set extensibility outboundnetworkaccess 1
    
  4. 重启 mssql-launchpadd 服务,使这些更改生效。

    sudo systemctl restart mssql-launchpadd