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

mrt*_*rtn 31 sql-server docker apple-m1

我正在尝试从创建一个 SQL Server 容器,docker-compose.yml但是当我运行它时,它直接停止并出现一些错误。注意:它运行在带有 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"
Run Code Online (Sandbox Code Playgroud)

我收到的错误:

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

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

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

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

sql-server-db | sql-server-db |

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

Бог*_*вич 25

您无法真正mcr.microsoft.com/mssql/server:2019-latest在 M1 上使用容器,因为 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:
Run Code Online (Sandbox Code Playgroud)

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

该数据库具有与 MSSQL DB 相同的 API,因此它可以与pyodbc(M1 上不支持)和pymssql库一起使用。

如果您在 M1 计算机上本地使用它 - 考虑使用pymssql库连接到 Azure SQL DB。这是我对/sf/answers/4684378051/问题的回答pyodbc


Bin*_*ode 21

Docker 现在支持使用 Rosetta(解释层)在 amd64 架构上模拟 x86 应用程序的实验性功能。这为我解决了这个问题。在此输入图像描述


小智 5

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

我也尝试过 Apple M1 芯片的 MSSQL 映像,但出现同样的错误。

使用 azure-sql-edge,我可以在配备 M1 芯片的 Apple BigSur 操作系统上使用 MSSQL

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

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


cha*_*win 0

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

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

唯一能解决这个问题的办法就是使用更复杂的密码。

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

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