views:

1817

answers:

5

We know that IIS caches ConfigurationManager.AppSettings so it reads the disk only once until the web.config is changed. This is done for performance purposes.

Someone at:

http://forums.asp.net/p/1080926/1598469.aspx#1598469

stated that .NET Framework doesn't do the same for app.config, but it reads from the disk for every request. But I find it hard to believe, 'cause it would be slower. Please tell me that he is wrong or I'll have to fix every Console/Windows Forms/Windows Services I wrote.

Update I regret that I misinterpreted what people said in the linked forum above.

+4  A: 

It doesn't matter if it does or not. Don't fix a performance problem if there isn't one.

John Sonmez
I somewhat disagree here. Configuration values like this are likely to be used in all kinds of places in your application, including nested loops and such. Grokking whether the read of a config file will take microseconds vs. milliseconds is important to know.
Dave Markle
+9  A: 

A quick test seems to show that these settings are only loaded at application startup.

//edit the config file now.
Console.ReadLine();

Console.WriteLine(ConfigurationManager.AppSettings["ApplicationName"].ToString());
Console.WriteLine("Press enter to redisplay");

//edit the config file again now.
Console.ReadLine();
Console.WriteLine(ConfigurationManager.AppSettings["ApplicationName"].ToString());
Console.ReadLine();

You'll see that all outputs remain the same.

ZombieSheep
Just to be picky, settings get loaded the first time they're referenced not necessarily at application startup.
Sam
+1  A: 

As John says only spend more time on this if you are actually seeing a performance hit.

Also I'm pretty sure that these applications hold the configuration in memory, and to see any changes within a config the application would have to be restarted.

For some further reading about remaining mysteries.

dove
+1  A: 

It reads the application configuration file (MyApp.exe.config) once at application startup, as can easily be verified by changing the file while the app is running.

The comment in the forum post referenced by the OP was:

The values for the Web.config are stored into cache/memory when the application starts hence why the app restarts when any changes are made to the web.config. Note that this only applies to the Web.config, any other .config files you may use are accessed from the disk by default

I would interpret this comment as meaning that config files other than web.config in an ASP.NET application are accessed from the disk by default. And similarly, config files other than MyApp.exe.config in a WinForms/Console application are accessed from the disk by default.

This comment is not stating that MyApp.exe.config is read from the disk by default.

Joe
A: 

AppSettings is cached. You can improve performance by further caching to limit namevaluecollection lookups.

See: http://dotnetperls.com/cache-settings-aspnet

Ben