Ser*_*046 4 sql-server docker docker-compose
我准备了一个 docker-compose 文件来部署带有数据库的容器:
services:
tmp-db:
image: microsoft/mssql-server-linux:latest
environment:
ACCEPT_EULA: Y
SA_PASSWORD: yourStrong(!)Password
ports:
- 1433:1433
Run Code Online (Sandbox Code Playgroud)
没关系。但现在我需要创建一个数据库并构建其结构。我需要执行一些sql命令。为了检查我是否能够做到这一点,我添加command到服务中:
services:
tmp-db:
image: microsoft/mssql-server-linux:latest
environment:
ACCEPT_EULA: Y
SA_PASSWORD: yourStrong(!)Password
command: /opt/mssql-tools/bin/sqlcmd -U sa -P yourStrong(!)Password -Q "SELECT [name] FROM sys.databases"
ports:
- 1433:1433
Run Code Online (Sandbox Code Playgroud)
但是我收到以下错误:
tmp-db_1 | Sqlcmd: Error: Microsoft ODBC Driver 13 for SQL Server : Login timeout expired.
tmp-db_1 | Sqlcmd: Error: Microsoft ODBC Driver 13 for SQL Server : TCP Provider: Error code 0x2749.
tmp-db_1 | Sqlcmd: Error: Microsoft ODBC Driver 13 for SQL Server : A network-related or instance-specific error has occurred while establishing a connection to SQL Server. Server is not found or not accessible. Check if instance name is correct and if SQL Server is configured to allow remote connections. For more information see SQL Server Books Online..
Run Code Online (Sandbox Code Playgroud)
我感觉该命令是在 Sql Server 实例启动之前执行的。我该如何修复它?Sql Server启动后如何执行一些sql?
问题是容器中只执行一个命令。当您在其中指定命令时docker-compose.yml,它将覆盖默认命令,该命令应该启动容器。所以你有两个选择
手动运行命令
services:
tmp-db:
image: microsoft/mssql-server-linux:latest
environment:
ACCEPT_EULA: Y
SA_PASSWORD: yourStrong(!)Password
ports:
- 1433:1433
Run Code Online (Sandbox Code Playgroud)
然后你可以执行
docker-compose exec tmp-db /opt/mssql-tools/bin/sqlcmd -U sa -P yourStrong(!)Password -Q "SELECT [name] FROM sys.databases"
Run Code Online (Sandbox Code Playgroud)
有两项服务 - 一项用于服务器,一项用于数据加载
services:
load-db:
image: microsoft/mssql-server-linux:latest
command: sh -c 'sleep 10 && /opt/mssql-tools/bin/sqlcmd -U sa -P yourStrong(!)Password -Q "SELECT [name] FROM sys.databases"'
network_mode: service:tmp-db
tmp-db:
image: microsoft/mssql-server-linux:latest
environment:
ACCEPT_EULA: Y
SA_PASSWORD: yourStrong(!)Password
ports:
- 1433:1433
Run Code Online (Sandbox Code Playgroud)
在这种方法中,我们使用加载数据的命令启动另一个容器,我们在数据库服务器容器的网络上运行它。这样做只是为了避免使用数据库的主机名,如果您愿意,也可以将主机名传递为tmp-db并删除network_mode: service:tmp-db.