Docker-compose覆盖不覆盖连接字符串

时间:2019-06-23 08:36:40

标签: sql-server asp.net-core docker-compose

我有一个连接到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中定义的连接字符串。

有人可以帮忙吗?我看不到我在做什么错...

2 个答案:

答案 0 :(得分:1)

使用双下划线对我有用

ConnectionStrings__DefaultConnection = sql.data; database = WebRecipes-LocalDev;用户ID = sa;密码= Pass @ word

答案 1 :(得分:0)

environment variable configuration上的ASP.NET Core官方文档具有以下说明:

  

使用环境变量中的层次结构键时,冒号分隔符(:)可能不适用于所有平台(例如Bash)。所有平台均支持双下划线(__),并自动用冒号代替。