我试图为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然而,我一直收到这条登录失败的消息:
用户“sa”登录失败。原因:所提供的登录密码不匹配。
如果我手动传递密码,而不是使用环境变量,那么它就能正常工作,但我个人不喜欢不得不“重复”它的想法。
我还尝试使用${SA_PASSWORD}作为建议的这里。
我也得到了同样的结果。
我在这里错过了什么?
发布于 2021-03-13 10:35:33
您没有一个shell来展开变量,因此sqlcmd以字符串的形式接收$$SA_PASSWORD。
尝试用类似的方法替换命令,以便有一个shell来扩展环境中的变量。
test: ["CMD", "sh", "-c", "/opt/mssql-tools/bin/sqlcmd -U sa -P $$SA_PASSWORD -Q SELECT 1"]或者,您可以尝试告诉来展开变量,如下所示:
test: ["CMD", "/opt/mssql-tools/bin/sqlcmd", "-U", "sa", "-P ${self:services.mysql.environment.SA_PASSWORD}", "-Q", "SELECT 1"]https://stackoverflow.com/questions/66607571
复制相似问题