ASP .NET CORE 根据环境变量支持多个 appsettings.json

  • 背景

在开发项目的过程当中,生产环境与调试环境的配置肯定是不一样的。拿个最简单的例子来说,比如连接字符串这种东西,调试环境肯定是不能连接生产数据库的。在之前的话,这种情况只能说是你 COPY 两个同名的配置文件来进行处理。然后你在本地就使用本地的配置,生产环境就使用生产环境的配置文件,十分麻烦。

而 ASP .NET CORE 支持利用环境变量来动态配置 JSON 文件,下面就来看一下吧。

  • 准备工作

首先在你的 ASP .NET CORE 项目当中添加几个文件 appsettings.json、 appsettings.Development.json、appsettings.Production.json和appsettings.Staging.json,.Net Core默认支持这几种环境配置文件,AppSettings部分的内容分别如下:


  "AppSettings": {
    "SystemName": "Basic Framework",
    "Ver": "Dev"
  }

  "AppSettings": {
    "SystemName": "Basic Framework",
    "Ver": "Dev"
  }


{
  "AppSettings": {
    "SystemName": "Basic Framework",
    "Ver": "Prd"
  }
}

{
  "AppSettings": {
    "SystemName": "Basic Framework",
    "Ver": "Qas"
  }
}

 

  • 环境控制

在项目调试的时候,我们可以通过右键项目属性,跳转到调试可以看到一个环境变量的设定,通过更改 ASPNETCORE_ENVIRONMENT 的值来切换不同环境。

可以看到目前我们处于 Development 也就是开发环境,就应该读取 appsettings.Development.json 的文件数据了,同样,将这里改为Production则会引用appsettings.Production.json的配置。

  注意:appsettings.json为基准配置,各appsettings.xxxx.json将以其为基础替换数据,并非排除了appsettings.json后只用appsettings.xxxx.json的数据。最终结果是二者拼接起来的。即:我们在appsettings.xxxx.json中只放入与appsettings.json中有差异的数据即可,类似之前的web.config替换。

  • 不同 OS 的环境变量配置

  •  Windows

直接右键计算机手动添加环境变量。

  •  Linux

使用 export 命令直接进行环境变量设置。

export ASPNETCORE_ENVIRONMEN='Production'
  •  Docker

Docker 配置最为简单,直接在启动容器的时候加上 -e 参数即可,例如:

docker run -d -e ASPNETCORE_ENVIRONMEN=Production --name testContainer testImage
  • 使用Web.config统一配置

使用OS环境变量方式配置不是太灵活,如一个服务器有多个环境需要部署就麻烦了,所以个人推荐继续使用web.config的方式改变环境设置。

站点下新建web.config:

<?xml version="1.0"?>
<configuration>
  <system.webServer>
    <handlers>
      <add name="aspNetCore" path="*" verb="*" modules="AspNetCoreModule" resourceType="Unspecified"/>
    </handlers>
    <aspNetCore processPath="%LAUNCHER_PATH%"
      arguments="%LAUNCHER_ARGS%"
      stdoutLogEnabled="false"
      stdoutLogFile=".\logs\stdout">
      <environmentVariables>
        <environmentVariable name="ASPNETCORE_ENVIRONMENT" value="Development" />
        <!--<environmentVariable name="CONFIG_DIR" value="f:\application_config" />-->
      </environmentVariables>
    </aspNetCore>
    <!--<aspNetCore processPath="%LAUNCHER_PATH%" arguments="%LAUNCHER_ARGS%" stdoutLogEnabled="false" stdoutLogFile=".\logs\stdout" forwardWindowsAuthToken="false" />-->
  </system.webServer>
</configuration>

 

其中environmentVariable 指定了具体的环境,在服务器上直接修改web.config即可切换引用的appsettings.XXXX.json文件。

注意,本机开发时,还是launchSettings.json中的值,web.config的值并不会起效。

 

参考:https://www.cnblogs.com/myzony/p/9418858.html

https://docs.microsoft.com/zh-cn/aspnet/core/fundamentals/environments?view=aspnetcore-2.1

https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/aspnet-core-module?view=aspnetcore-2.1

 
posted @ 2018-10-17 14:35  邑尘  阅读(2363)  评论(0编辑  收藏  举报