使用实体框架 app.config 如何在 Dev、Stage 和 Production 环境之间切换

Posted

技术标签:

【中文标题】使用实体框架 app.config 如何在 Dev、Stage 和 Production 环境之间切换【英文标题】:Using Entity Framework app.config how to switch between environments Dev, Stage and Production 【发布时间】:2015-07-09 02:53:43 【问题描述】:

我有一个使用 DataModel.edmx 访问 Dev 数据库的 Windows 应用程序,它工作正常。为了访问舞台环境数据库,我添加了另一个 StageDataModel.edmx。所以app.config中有两个连接字符串: 和 app.config中如何根据环境切换数据库?

提前致谢!

【问题讨论】:

数据库是不同的还是它们具有相同的结构(表、方案等)?为什么需要两个 edmx 文件? 是的,有两个结构相同的数据库。我是 edmx 的新手,所以不确定它是如何工作的 【参考方案1】:

通常情况下应该相反 - 为每个环境创建一个 EF edmx 模型和两个(或更多)配置文件。

在我的工作中,我们有三个环境:

发布 = 生产 阶段 = 上线前(生产副本、最终测试) 调试 = 新开发、开发团队测试

对于这三个环境,我们有三个数据库,它们(几乎)彼此相似。我们从 DEV 数据库创建我们的模型。每个与数据库通信的项目始终具有三个具有不同凭据的连接字符串。

为了实现这一点,您需要:

1) 使用 Visual Studio 配置管理器 创建不同的构建平台(在我的示例中,有三种构建配置 - Dev/Stage/Release):

2) 提取 app.settings 文件中的连接字符串配置。不要在app.settings 文件中指定连接,而是像这样使用configSource 参数(app.config 看起来像这样):

  <?xml version="1.0" encoding="utf-8" ?>
  <configuration>
    <connectionStrings configSource="App.ConnectionStrings.Config" />
  </configuration>

3) 现在为每个构建配置创建不同的文件,以每个构建配置命名(措辞必须准确!)并包含不同的服务器或数据库

App.ConnectionStrings.Debug.config App.ConnectionStrings.Stage.config App.ConnectionStrings.Release.config

例如,Debug 可能如下所示:

<?xml version="1.0" encoding="utf-8" ?>
<connectionStrings>
    <add name="Named.ConnectionString" 
            connectionString="metadata=res://*/Abstraction.DbDataContext.csdl|res://*/Abstraction.DbDataContext.ssdl|res://*/Abstraction.DbDataContext.msl;provider=System.Data.SqlClient;provider connection string=&quot;data source=sql.server.address;initial catalog=People;integrated security=False;user id=DbUser;password=DbPassword;multipleactiveresultsets=True;App=EntityFramework&quot;"
            providerName="System.Data.EntityClient" />
</connectionStrings>

4) 现在在 Visual Studio 中打开您的项目设置,转到 Build Events 并在 Post-Build event command line 中告诉 Visual Studio 以当前选定的构建平台命名的文件进行每个构建,并使用指定的(在app.config) 名称到输出目录:

copy $(ProjectDir)\App.ConnectionStrings.$(ConfigurationName).config $(TargetDir)App.ConnectionStrings.config

现在,当您构建和启动应用程序时,配置取决于构建配置,因此您甚至可以调试连接到 LIVE 环境的应用程序(当前选择的构建配置为 Release )。

更多关于如何使用外部配置文件和连接字符串的信息,可以在this MSDN article找到。

一个好的Entity Framework quick start。

【讨论】:

【参考方案2】:

我想您是在问如何使用不同的 app.config 文件进行调试/发布。

只需将它们命名为 app.Release.configapp.Debug.config 并在其中一个中设置调试或发布设置。

如果比较复杂,可以安装SlowCheetah之类的工具来修改XML文件,只需要设置不同的构建配置即可。

【讨论】:

通常 Dev/Stage/Prod 数据库应该是相似的,所以除了你的解释,我想说,只需要一个 edmx 而不是两个。 @pasty 是的,不确定他是如何在代码中处理两个不同的 edmx 文件,但实际上它们应该是相同的,唯一的区别应该是底层连接。 嗨@RonBeyer - 谢谢,很好的回答!我在.csproj 文件设置上添加了说明;在没有这些信息的情况下努力让它工作。希望你不介意:)

以上是关于使用实体框架 app.config 如何在 Dev、Stage 和 Production 环境之间切换的主要内容,如果未能解决你的问题,请参考以下文章

没有 App.config 的 SQLite 实体框架

c# - 在运行时更改 App.Config 后,实体框架 ConnectionString 不会更新

App.Config 中的实体框架连接字符串

我应该如何编辑实体框架连接字符串?

在运行时加载 App.Config

Postgresql 和实体框架