9

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

码头工人-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) 进程(自身或通过包装器)启动自己的运行环境,通过系统调用 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 退出

4

3 回答 3

8

你不能真正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:

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

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

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

于 2021-04-02T13:14:11.737 回答
1

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

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

于 2021-08-08T13:10:48.710 回答
0

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

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

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

我连续多次测试了这个......我测试了你的密码,但它失败了。我测试了一个复杂的密码,它工作正常。

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

于 2020-12-21T21:58:34.633 回答