Docker 连接 SQL Server 容器非零代码:1

问题描述

我正在尝试从 docker-compose.yml 创建一个 SQL Server 容器,但是当我运行它时,它直接停止并出现一些错误。注意:它在带有 docker Preview 的 Apple M1 芯片上运行

docker-compose.yml:

version: "3.7"
services:
  sql-server-db:
    container_name: sql-server-db
    image: mcr.microsoft.com/mssql/server:2019-latest
    ports: 
      - "1433:1433"
    environment: 
      SA_PASSWORD: "ApplePassDockerConnect"
      ACCEPT_EULA: "Y"

我遇到的错误:

sql-server-db | /opt/mssql/bin/sqlservr:0x400000000000 以下保留地址空间中地址 0x40092b8000 的无效映射。可能的原因:

sql-server-db | 1) 进程(本身,或通过包装器)启动自己的运行环境,通过 syscall setrlimit(2) 将堆栈大小限制设置为无限制;

sql-server-db | 2) 进程(本身,或通过包装器)调整自己的执行域,并通过系统调用个性(2)标记系统其遗留个性;

sql-server-db | 3) sysadmin 通过调整 sysctl 旋钮 vm.legacy_va_layout 故意将系统设置为在传统 VA 布局模式下运行。

sql-server-db |

sql-server-db 退出,代码为 1

解决方法

您不能真正在 M1 上使用 mcr.microsoft.com/mssql/server:2019-latest 容器,因为 MSSQL DB 不支持 ARM 架构。我发现的唯一方法是使用支持 ARM 并且可以在 M1 上运行的 Azure SQL 容器。

这是我的 docker-compose.yml 配置示例:

version: "3.9"

services:
    # Database instance
    mssql:
      image: mcr.microsoft.com/azure-sql-edge:latest
      volumes:
        - events_mssql:/var/opt/mssql
      ports:
        - 1433:1433
      environment:
        - ACCEPT_EULA=1
        - MSSQL_SA_PASSWORD=Passw@rd

volumes:
    events_mssql:

您将能够使用用户名:sa、密码:Passw@rd 和数据库:master 连接到此数据库。如果您想要其他数据库名称 - 您可以创建一个新的 using SQLCREATE DATABASE TestDB

此数据库具有与 MSSQL DB 相同的 API,因此它适用于 pyodbc(M1 不支持)和 pymssql 库。

如果您在 M1 机器上本地使用它 - 考虑使用 pymssql 库连接到 Azure SQL DB。这是我对 pyodbc https://stackoverflow.com/a/66919686/11515610

问题的回答 ,

所以...这可能与您的特定问题无关。我觉得它不会为您解决问题,因为您的问题听起来要低得多(正如您怀疑的那样),但值得一试。

我尝试复制粘贴您的确切 docker-compose 文件并在我的机器(Windows 桌面)上运行它,我也得到 exited with code 1

似乎唯一能修复它的方法是使用更复杂的密码。

我连续测试了多次...我测试了你的密码,但它失败了。我测试了一个复杂的密码,效果很好。

所以我建议使用更复杂的密码。我测试的密码是 6Xy3LkV7!9lo2^h

,

Apple Chip M1 的 SQL 映像尚未容器化,但我们可以使用 azure-sql-edge。

我也为 Apple M1 芯片尝试过 MSSQL 镜像,但同样的错误。

使用 azure-sql-edge,我可以在带有 M1 芯片的 Apple BigSur OS 上使用 MSSQL

你可以通过这篇文章 https://medium.com/geekculture/docker-express-running-a-local-sql-server-on-your-m1-mac-8bbc22c49dc9

如果对您有帮助,请不要忘记将其标记为已回答。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...