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
小智 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
如果对您有帮助,请不要忘记将其标记为“已答复”。
所以...这可能与您的特定问题无关。我有一种感觉,它不会为你解决这个问题,因为你的问题听起来要低得多(正如你所怀疑的),但值得一试。
我尝试复制粘贴您的确切 docker-compose 文件并在我的计算机(Windows 桌面)上运行它,我也得到了exited with code 1.
唯一能解决这个问题的办法就是使用更复杂的密码。
我连续测试了多次...我测试了你的密码,但失败了。我测试了一个复杂的密码,效果很好。
所以我建议使用更复杂的密码。我测试的密码是6Xy3LkV7!9lo2^h
| 归档时间: |
|
| 查看次数: |
18263 次 |
| 最近记录: |