我试图在位于我们在运行时的ServiceHost的App.Config中ConnectionString,以更改数据库名称,之后重新启动它连接到另一个数据库ConfigurationManager中缓存。这工作正常,但只有当应用程序关闭多秒。关闭几秒钟的应用程序似乎清除了ConfigurationManager.Connectionstrings的缓存。问题是,由于这需要关机时间,我不能在我的应用程序中使用Application.Restart()。我怎么能清除的ConnectionStrings
这个缓存行为奇怪的是,即使该值在内存(这是要求第二次在本例中)更新的正确显示更新后的值。但是当应用程序重新启动时,旧值似乎会重新出现。
要验证的行为,创建一个新的控制台应用程序。
添加App.config文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<connectionStrings>
<add name="DomainDBConnectionString" connectionString="Data Source=.\SQLEXPRESS;Initial Catalog=InitialDBName;Integrated Security=SSPI;" />
</connectionStrings>
</configuration>
然后将下面的代码添加到Main方法
ConfigurationManager.RefreshSection("connectionStrings");
DbConnectionStringBuilder builder = new DbConnectionStringBuilder();
Configuration appConfig = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
builder.ConnectionString = appConfig.ConnectionStrings.ConnectionStrings["DomainDBConnectionString"].ConnectionString;
//print initial value
Console.WriteLine("initial " + (string)builder["Initial Catalog"]);
//change value
builder["Initial Catalog"] = "ChangedDatabaseName";
appConfig.ConnectionStrings.ConnectionStrings.Remove("DomainDBConnectionString");
appConfig.ConnectionStrings.ConnectionStrings.Add(new ConnectionStringSettings("DomainDBConnectionString", builder.ConnectionString));
appConfig.ConnectionStrings.SectionInformation.ForceSave = true;
appConfig.Save(ConfigurationSaveMode.Full);
ConfigurationManager.RefreshSection("connectionStrings");
Console.ReadLine();
DbConnectionStringBuilder builder2 = new DbConnectionStringBuilder();
Configuration appConfig2 = ConfigurationManager.OpenExeConfiguration(ConfigurationUserLevel.None);
builder2.ConnectionString = appConfig.ConnectionStrings.ConnectionStrings["DomainDBConnectionString"].ConnectionString;
Console.WriteLine("changed " + (string)builder2["Initial Catalog"]);
Console.ReadLine();
要重现此问题,你需要运行的应用程序(通过按F5)和关闭它。 之后,solutionname.exe.config文件将显示修改后的值。 如果您第二次运行该应用程序(此时双击解锁名称.exe,则此时为),如果您在终止应用程序后立即执行此操作,或等待几秒钟后立即执行此操作,您将注意到行为上的差异。
在我看来,configsection应该重新阅读,因为 ConfigurationManager.RefreshSection(“connectionStrings”); 但apparenatelly这不起作用广告。
给编辑我的标签的人。这与ASP.Net无关。我的服务器是一个控制台应用程序。 – 2010-03-03 15:27:05
够公平的,但它仍然。净 - 没有正确标记问题的风险是,其他人会标记它给你,他们会得到错误:) – skaffman 2010-03-04 11:42:19