我有一个连接到SQL数据库的ASP.NET Web应用。
在appsettings.Development.json
中,连接字符串定义为
"ConnectionStrings": {
"DefaultConnection": "Server=(localdb)\\mssqllocaldb;Database=WebRecipes-LocalDev;Trusted_Connection=True;ConnectRetryCount=0"
}
在我的docker-compose.yml
文件中,我得到了最新的mssql-server-linux
services:
sql.data:
image: microsoft/mssql-server-linux:2017-latest
webrecipes.api:
image: ${DOCKER_REGISTRY-}webrecipesapi
build:
context: .
dockerfile: src/WebRecipes.Api/Dockerfile
在docker-compose.override.yml
中,为sql.data
设置用户名和密码,并覆盖asp.net核心应用的连接字符串
services:
sql.data:
environment:
- SA_PASSWORD=Pass@word
- ACCEPT_EULA=Y
ports:
- "5533:1433"
webrecipes.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
- ASPNETCORE_HTTPS_PORT=44302
- ConnectionString=Server=sql.data;database=WebRecipes-LocalDev;User Id=sa;Password=Pass@word
ports:
- "2282:80"
- "44302:443"
volumes:
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
depends_on:
- sql.data
- ConnectionStrings:DefaultConnection=sql.data;database=WebRecipes-LocalDev;User Id=sa;Password=Pass@word
当我运行该应用程序时,它首先尝试访问数据库时,出现错误,提示不支持LocalDb,因为它使用的是
appsettings.Development.json
中定义的连接字符串。
有人可以帮忙吗?我看不到我在做什么错...
答案 0 :(得分:1)
使用双下划线对我有用
ConnectionStrings__DefaultConnection = sql.data; database = WebRecipes-LocalDev;用户ID = sa;密码= Pass @ word
答案 1 :(得分:0)
environment variable configuration上的ASP.NET Core官方文档具有以下说明:
使用环境变量中的层次结构键时,冒号分隔符(:)可能不适用于所有平台(例如Bash)。所有平台均支持双下划线(__),并自动用冒号代替。