我正在尝试为 sql-server
容器创建一个简单的健康检查,如下所示:
version: "3.8"
volumes:
sql-server:
services:
sql-server:
image: "mcr.microsoft.com/mssql/server:2017-latest"
container_name: sql-server
environment:
- ACCEPT_EULA=Y
- SA_PASSWORD=sa@@2020
healthcheck:
test: ["CMD", "/opt/mssql-tools/bin/sqlcmd", "-U", "sa", "-P", "$$SA_PASSWORD", "-Q", "SELECT 1"]
ports:
- "1433:1433"
volumes:
- sql-server:/var/opt/mssql
但我一直收到此登录失败消息:
Login failed for user 'sa'. Reason: Password did not match that for the login provided.
如果我手动传递我的密码而不是使用环境变量,它工作得很好,但我个人不喜欢必须“重复”它的想法。
我还尝试按照建议使用 ${SA_PASSWORD}
here .
这让我得到了相同的结果。
我在这里错过了什么?
最佳答案
您没有用于扩展变量的 shell,因此 sqlcmd
正在接收字符串形式的 $$SA_PASSWORD
。
尝试用类似这样的东西替换命令,以便拥有一个从环境中扩展变量的 shell。
test: ["CMD", "sh", "-c", "/opt/mssql-tools/bin/sqlcmd -U sa -P $$SA_PASSWORD -Q SELECT 1"]
或者您可以尝试告诉 docker-compose 扩展变量,如下所示:
test: ["CMD", "/opt/mssql-tools/bin/sqlcmd", "-U", "sa", "-P ${self:services.mysql.environment.SA_PASSWORD}", "-Q", "SELECT 1"]
关于docker - 如何在 docker-compose healthchecks 上使用环境变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66607571/