如何解决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 SQL:CREATE 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
如果对您有帮助,请不要忘记将其标记为已回答。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。